创建Java线程的3种方式及对比
class PrimeThread extends Thread { long minPrime; PrimeThread(long minPrime) { this.minPrime = minPrime; } public void run() { // compute primes larger than minPrime . . . } } The following code would then create a thread and start it running: PrimeThread p = new PrimeThread(143); p.start();
二:实现Runnable接口创建线程类( JAVA API中的介绍)
class PrimeRun implements Runnable { long minPrime; PrimeRun(long minPrime) { this.minPrime = minPrime; } public void run() { // compute primes larger than minPrime . . . } } The following code would then create a thread and start it running: PrimeRun p = new PrimeRun(143); new Thread(p).start();
三:使用Callable和FutureTask创建线程
//先使用lambda表达式创建callable对象,然后使用FutureTask来进行包装
FutureTask task = new FutureTask((Callable)()-> { int i = 0; for(; i < 100; i++) { System.out.println(Thread.currentThread().getName() + "循环变量i的值: "+i); } return i; });
//创建线程
new Thread(task, "有返回值的线程").start();
四:创建线程的三种方式对比
实现Runnable接口和Calable接口的方式基本相同,知识Calable接口定义的方法里面有返回值,可以声明抛出异常而已。因此将他们俩归为一类。这种方式与继承Thread方式之间的差别如下:
@采用实现接口的方式创建多线程的优缺点:
1)线程类知识实现了Runnable接口或者Calable接口,还可以继承其他类。
2)在这种方式下,多个线程可以共享一个target对象,非常适合多个相同线程来处理同一份资源的情况。
3)劣势是:编程比较的麻烦,如果需要访问当前线程,需要调用currentThread()方法。
@采用继承Thread类的方式创建多线程的优缺点:
1)劣势是已经继承了Thread类,所以不能在继承其他父类。
2)优势是:代码简单,可以直接通过this访问当前线程。
通过分析,一般推荐采用实现接口的方式来创建多线程。

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
-
上一篇
分布式任务调度解决方案(完结版)
Quartz是OpenSymphony开源组织在Job scheduling领域又一个开源项目,它可以与J2EE与J2SE应用程序相结合也可以单独使用。Quartz可以用来创建简单或为运行十个,百个,甚至是好几万个Jobs这样复杂的程序。Jobs可以做成标准的Java组件或 EJBs。 Quartz的优势: 1、Quartz是一个任务调度框架(库),它几乎可以集成到任何应用系统中。 2、Quartz是非常灵活的,它让您能够以最“自然”的方式来编写您的项目的代码,实现您所期望的行为 3、Quartz是非常轻量级的,只需要非常少的配置 —— 它实际上可以被跳出框架来使用,如果你的需求是一些相对基本的简单的需求的话。 4、Quartz具有容错机制,并且可以在重启服务的时候持久化(”记忆”)你的定时任务,你的任务也不会丢失。 5、可以通过Quartz,封装成自己的分布式任务调度,实现强大的功能,成为自己的产品 6、有很多的互联网公司也都在使用Quartz。 课程说明: 在我们的日常开发中,各种大型系统的开发少不了任务调度,简单的单机任务调度已经满足不了我们的系统需求,复杂的任务会让程序猿头疼,...
-
下一篇
利用Redis实现分布式锁
秒杀系统的架构设计 秒杀系统,是典型的短时大量突发访问类问题。对这类问题,有三种优化性能的思路: 1:写入内存而不是写入硬盘 2:异步处理而不是同步处理 3:分布式处理 用上这三招,不论秒杀时负载多大,都能轻松应对。更好的是,Redis能够满足上述三点。因此,用Redis就能轻松实现秒杀系统。用我这个方案,无论是电商平台特价秒杀,12306火车票秒杀,都不是事:) 下面介绍一下为什么上述三种性能优化思路能够解决秒杀系统的性能问题: 写入内存而不是写入硬盘 传统硬盘的读写性能是相当差的。SSD硬盘比传统硬盘快100倍。而内存又比SSD硬盘快10倍以上。因此,写入内存而不是写入硬盘,就能使系统的能力提升上千倍。也就是说,原来你的秒杀系统可能需要1000台服务器支撑,现在1台服务器就可以扛住了。你可能会有这样的疑问:写入内存而不是持久化,那么如果此时计算机宕机了,那么写入的数据不就全部丢失了吗?如果你就这么倒霉碰到服务器宕机,那你就没秒到了,有什么大不了?最后,后面真正处理秒杀订单时,我们会把信息持久化到硬盘中。因此不会丢失关键数据。Redis是一个缓存系统,数据写入内存后就返回给客户端了,...
相关文章
文章评论
共有0条评论来说两句吧...