创建线程有哪几种方式
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了创建线程有哪几种方式相关的知识,希望对你有一定的参考价值。
一、继承Thread类创建通过继承Thread并且重写其run(),run方法中即线程执行任务。创建后的子类通过调用 start() 方法即可执行线程方法。
通过继承Thread实现的线程类,多个线程间无法共享线程类的实例变量。(需要创建不同Thread对象,自然不共享)
二、 通过Runnable接口创建线程类
该方法需要先 定义一个类实现Runnable接口,并重写该接口的 run() 方法,此run方法是线程执行体。接着创建 Runnable实现类的对象,作为创建Thread对象的参数target,此Thread对象才是真正的线程对象。通过实现Runnable接口的线程类,是互相共享资源的。
三、 使用Callable和Future创建线程
从继承Thread类和实现Runnable接口可以看出,上述两种方法都不能有返回值,且不能声明抛出异常。而Callable接口则实现了此两点,Callable接口如同Runable接口的升级版,其提供的call()方法将作为线程的执行体,同时允许有返回值。
但是Callable对象不能直接作为Thread对象的target,因为Callable接口是 Java 5 新增的接口,不是Runnable接口的子接口。对于这个问题的解决方案,就引入 Future接口,此接口可以接受call() 的返回值,RunnableFuture接口是Future接口和Runnable接口的子接口,可以作为Thread对象的target 。并且, Future 接口提供了一个实现类:FutureTask 。
FutureTask实现了RunnableFuture接口,可以作为 Thread对象的target。 参考技术A 1、newCachedThreadPool()
创建一个可缓存的线程池,如果线程池的规模超过了处理需求,将自动回收空闲线程,而当需求增加时,则可以自动添加新线程,线程池的规模不存在限制。
2、newFixedThreadPool(2)
创建一个固定长度的线程池,每当提交一个任务就创建一个线程,直到达到线程池的数量,超出的线程会在队列中等待。
3、newScheduledThreadPool(2)
创建了一个固定长度的线程池,而且以延迟或定时的方式来执行任务,类似于Timer。
4、newSingleThreadExecutor()
创建一个单线程化的线程池,它只会用的工作线程来执行任务,所有任务按照指定顺序(FIFO, LIFO, 优先级)执行。
5、newSingleThreadScheduledExecutor()
创建一个单例线程池,定期或延时执行任务。
6、newWorkStealingPool(3)
创建一个带并行级别的线程池,并行级别决定了同一时刻有多少个线程在执行,如不穿如并行级别参数,将默认为当前系统的CPU个数。
AOP的实现方式有哪几种?
如题,AOP的实现方式。但我知道2种,JDK动态代理和CGLIB库,貌似还有3种?
常见有三种实现方式:1.利用代理模式动态的实现AOP,从具体的技术细节又可以分为静态代理,动态代理,CGLIB生成子类代理。
2.使用预编译的方法静态进行代理。
3.使用自定义加载器的方法动态进行代理。
后两种代理都可以代理更多的内容(比如构造函数,静态方法,静态块,final方法,私有方法等)。 参考技术A 据我所知,就两种实现方式,就是楼主所说的JDK动态代理和CGLIB,
所谓其他实现方式应该是JDK动态代理的不同表现形式吧 参考技术B 专业人士还要问人哦,呵呵.看来学无止境啊.
以上是关于创建线程有哪几种方式的主要内容,如果未能解决你的问题,请参考以下文章