您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

java多线程如何实现

2024/6/23 21:39:15发布20次查看
java实现多线程的方法:(推荐:java视频教程)
方式一:继承thread类的方式
1、创建一个继承于thread类的子类
2、重写thread类中的run():将此线程要执行的操作声明在run()
3、创建thread的子类的对象
4、调用此对象的start():①启动线程 ②调用当前线程的run()方法
方式二:实现runnable接口的方式
1、创建一个实现runnable接口的类
2、实现runnable接口中的抽象方法:run():将创建的线程要执行的操作声明在此方法中
3、创建runnable接口实现类的对象
4、将此对象作为参数传递到thread类的构造器中,创建thread类的对象
5、调用thread类中的start():① 启动线程  ② 调用线程的run() --->调用runnable接口实现类的run()
以下两种方式是jdk1.5新增的!
方式三:实现callable接口
说明:
1、与使用runnable相比, callable功能更强大些
2、实现的call()方法相比run()方法,可以返回值
3、方法可以抛出异常
4、支持泛型的返回值
5、需要借助futuretask类,比如获取返回结果
future接口可以对具体runnable、callable任务的执行结果进行取消、查询是否完成、获取结果等。futuretask是futrue接口的唯一的实现类futuretask 同时实现了runnable, future接口。它既可以作为runnable被线程执行,又可以作为future得到callable的返回值
方式四:使用线程池
说明:
提前创建好多个线程,放入线程池中,使用时直接获取,使用完放回池中。可以避免频繁创建销毁、实现重复利用。类似生活中的公共交通工具。
好处:
1、提高响应速度(减少了创建新线程的时间)
2、降低资源消耗(重复利用线程池中线程,不需要每次都创建)
3、便于线程管理
示例:
import java.util.concurrent.callable;import java.util.concurrent.executorservice;import java.util.concurrent.executors;import java.util.concurrent.futuretask;import java.util.concurrent.threadpoolexecutor;//方式一class threadtest extends thread { @override public void run() { for (int i = 0; i < 10; i++) { system.out.println(thread.currentthread().getname() + ":" + i); } }}// 方式二class runnabletest implements runnable { @override public void run() { for (int i = 0; i < 10; i++) { system.out.println(thread.currentthread().getname() + ":" + i); } }}// 方式三class callabletest implements callable<integer> { @override public integer call() throws exception { int sum = 0; for (int i = 0; i < 10; i++) { system.out.println(thread.currentthread().getname() + ":" + i); sum += i; } return sum; }}// 方式四class threadpool implements runnable { @override public void run() { for (int i = 0; i < 10; i++) { system.out.println(thread.currentthread().getname() + ":" + i); } }}public class test { public static void main(string[] args) { // 继承thread threadtest thread = new threadtest(); thread.setname("方式一"); thread.start(); // 实现runnable runnabletest runnabletest = new runnabletest(); thread thread2 = new thread(runnabletest, "方式二"); thread2.start(); // 实现callable<> 有返回值 callabletest callabletest = new callabletest(); futuretask<integer> futuretask = new futuretask<>(callabletest); new thread(futuretask, "方式三").start(); // 返回值 try { integer integer = futuretask.get(); system.out.println("返回值(sum):" + integer); } catch (exception e) { e.printstacktrace(); } // 线程池 executorservice pool = executors.newfixedthreadpool(10); threadpoolexecutor executor = (threadpoolexecutor) pool; /* * 可以做一些操作: * corepoolsize:核心池的大小 * maximumpoolsize:最大线程数 * keepalivetime:线程没任务时最多保持多长时间后会终止 */ executor.setcorepoolsize(5); // 开启线程 executor.execute(new threadpool()); executor.execute(new threadpool()); executor.execute(new threadpool()); executor.execute(new threadpool()); }}
更多java知识请关注java基础教程栏目。
以上就是java多线程如何实现的详细内容。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product