多线程三种主要实现方式:继承Thread类,实现Runnable接口、Callable和Futrue。
一、简单实现
				?
			
                	
    
	
	
		
		
	
 
	
		
			
	
	 
     
	
			
                 
			
		
		
			
			
			
    
        
        
	
			
						
			
            			
    		
    		
		
	    
    	
    	
        
    	
    
| 
 
								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
 
								46
 
								47
 
								48
 
								49
 
								50
 
								51
 
								52
						  | 
import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.FutureTask;
import java.util.concurrent.TimeUnit;
public class T02_HowToCreateThread {
//1.继承Thread类
static class MyThread extends Thread{
@Override
public void run() {
System.out.println("MyThread-->");
}
}
//3.实现Runnable接口
static class MyRun implements Runnable{
@Override
public void run() {
System.out.println("MyRunable-->");
}
}
//4.实现Callable接口
static class MyCall implements Callable{
@Override
public Object call() throws Exception {
System.out.println("myCallable-->");
return 1;
}
}
public static void main(String[] args) throws ExecutionException, InterruptedException {
//1.继承Thread类
new MyThread().start();
//2.lambda与继承Thread类类//1.继承Thread类似,最简单
new Thread(()->{
System.out.println("lambda-->");
}).start();
//3.实现Runnable接口
new Thread(new MyRun()).start();
new Thread(new Runnable() {
@Override
public void run() {
System.out.println("simple->Runnable");
}
}).start();
//4.实现Callable接口,并用包装器FutureTask来同时实现Runable、Callable两个接口,可带返回结果
MyCall mycall = new MyCall();
FutureTask futureTask = new FutureTask(mycall);
new Thread(futureTask).start();
System.out.println(futureTask.get());
}
}
 | 
二、使用ExecutorService、Callable和Future一起实现带返回值
				?
			
	
						
						
						
						
						
						
						
																		
    
        
    
        
                        
                
                    
                
                
                
                    
                
                
                
                    
                
                
                
                    
                
                        
    
 																		
						
																		
    
        
 												
						
																		
	
	
		
				
			
																		
						
						
					
				
				                | 
 
								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
						  | 
import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.*;
/**
* 使用ExecutorsService、Callable、Future来实现多个带返回值的线程
*/
public class T02_HowToCreateThread02 {
static class MyCallable implements Callable{
private int taskNum;
public MyCallable(int taskNum){
this.taskNum = taskNum;
}
@Override
public Object call() throws Exception {
System.out.println("任务"+taskNum);
return "MyCallable.call()-->task"+taskNum;
}
}
public static void main(String[] args) throws ExecutionException, InterruptedException {
int num = 5;
//创建一个线程池
ExecutorService pool = Executors.newFixedThreadPool(num);
List<Future> futureList = new ArrayList<Future>();
for (int i = 0; i < num; i++){
MyCallable mc = new MyCallable(i);
//执行任务,并返回值
Future future = pool.submit(mc);
futureList.add(future);
}
pool.shutdown();
for (Future f: futureList){
System.out.println(f.get());
}
}
}
 | 
结果:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持快网idc。
原文链接:https://www.cnblogs.com/helq/p/13264050.html
相关文章
             猜你喜欢
        
        - 64M VPS建站:能否支持高流量网站运行? 2025-06-10
 - 64M VPS建站:怎样选择合适的域名和SSL证书? 2025-06-10
 - 64M VPS建站:怎样优化以提高网站加载速度? 2025-06-10
 - 64M VPS建站:是否适合初学者操作和管理? 2025-06-10
 - ASP.NET自助建站系统中的用户注册和登录功能定制方法 2025-06-10
 
			TA的动态
			
		
				- 2025-07-10 怎样使用阿里云的安全工具进行服务器漏洞扫描和修复?
 - 2025-07-10 怎样使用命令行工具优化Linux云服务器的Ping性能?
 - 2025-07-10 怎样使用Xshell连接华为云服务器,实现高效远程管理?
 - 2025-07-10 怎样利用云服务器D盘搭建稳定、高效的网站托管环境?
 - 2025-07-10 怎样使用阿里云的安全组功能来增强服务器防火墙的安全性?
 
快网idc优惠网
QQ交流群
				您的支持,是我们最大的动力!				
			
		
        热门文章
        
    
    - 
            2025-05-29 95
 - 
            2025-05-26 104
 - 
            2025-05-29 101
 - 
            2025-05-29 26
 - 
            2025-05-25 16
 
		热门评论
	
	
        

    		
            	
        
        
        