package multiThread;
import java.util.concurrent.Callable;
//带返回值的任务
public class TaskWithResult implements Callable<String> {
private int id;
public TaskWithResult(int id){
this.id=id;
}
public String call(){
return "TaskWithResult "+id;
}
}
//test
ExecutorService exec=Executors.newCachedThreadPool();
ArrayList<Future<String>> results=new ArrayList<Future<String>>();
for(int i=0;i<10;++i){
results.add(exec.submit(new TaskWithResult(i)));
}
for (Future<String> future : results) {
try {
System.out.println(future.get());
} catch (InterruptedException ie) {
System.out.println(ie.getMessage());
}finally{
exec.shutdown();
}
}
结果如下:
2、我们可以调用sleep方法让线程休眠一会例如:
public void run(){
while(countDown-->0){
System.out.println(status());
//Thread.yield();
try {
TimeUnit.MILLISECONDS.sleep(1000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
3、线程的优先级
优先级的设置一般会在run函数里面进行
例如:
package multiThread;
public class SimplePriorities implements Runnable {
private int countDown=5;
private volatile double d;//no optimization
private int priority;
public SimplePriorities(int priority){
this.priority=priority;
}
public String toString(){
return Thread.currentThread()+": "+countDown;
}
public void run(){
Thread.currentThread().setPriority(priority);
while(true){
for(int i=1;i<10000;++i){
d+=(Math.PI+Math.E)/(double)i;
if(i%1000==0)
Thread.yield();//suggest other threads to run
}
System.out.println(this);
if(--countDown==0)return;
}
}
}
ExecutorService executorService=Executors.newCachedThreadPool();
for(int i=0;i<5;++i){
executorService.execute(new SimplePriorities(Thread.MIN_PRIORITY));
}
executorService.execute(new SimplePriorities(Thread.MAX_PRIORITY));
executorService.shutdown();