一、多线程 1、操作系统有两个容易混淆的概念,进程和线程。 进程:一个计算机程序的运行实例,包含了需要执行的指令;有自己的独立地址空间,包含程序内容和数据;不同进程的地址空间是互相隔离的;进程拥有各种资源和状态信息,包括打开的文件、子进程和信
在Java5之前,线程是没有返回值的,常常为了“有”返回值,破费周折,而且代码很不好写。或者干脆绕过这道坎, 走别的路了。 现在Java终于有可返回值的任务(也可以叫做线程)了。 可返回值的任务必须实现Callable接口,类似的,无返回值的任务必须Runnable接口。 执行Callable任务后,可以获取一个Future的对象,在该对象上调用get就可以获取到Callable任务返回的Object了。 下面是个很简单的例子: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 package
com.ljq.test.thread;
import
java.util.concurrent.Callable; import
java.util.concurrent.ExecutionException; import
java.util.concurrent.ExecutorService; import
java.util.concurrent.Executors; import
java.util.concurrent.Future;
public
class
CallableFutureTest {
@SuppressWarnings ( "unchecked" )
public
static
void
main(String[] args)
throws
ExecutionException,
InterruptedException {
CallableFutureTest test =
new
CallableFutureTest();
// 创建一个线程池
ExecutorService pool = Executo2. 终止线程的方式 Thread中的stop()和suspend()方法,由于固有的不安全性,已经建议不再使用! 下面,我先分别讨论线程在“阻塞状态”和“运行状态”的终止方式,然后再总结出一个通用的方式。 2.1 终止处于“阻塞状态”的线程 通常,我们通过“中断”方式终rs.newFixedThreadPool( 2 );
// 创建两个有返回值的任务
Callable c1 = test. new
MyCallable( "A" );
Callable c2 = test. new
MyCallable( "B" );
// 执行任务并获取Future对象
Future f1 = pool.submit(c1);
Future f2 = pool.submit(c2);
// 从Future对象上获取任务的返回值,并输出到控制台
System.out.println( ">>>"
+ f1.get().toString());
System.out.println( ">>>"
+ f2.get().toString());
// 关闭线程池
pool.shutdown();
}
@SuppressWarnings ( "unchecked" )
class
MyCallable
implements
Callable {
private
String name;
MyCallable(String name) {
this .name = name;
}
public
Object call()
throws
Exception {
return
name +
"任务返回的内容" ;
}
} } >>>A任务返回的内容>>>B任务返回的内容