java?線程池存在的意義
前言
再次之前我已經(jīng)花費(fèi)大量篇幅介紹了Java原聲鎖和Lock鎖。在文章中提到偏向送、輕量級鎖、重量級鎖、公平鎖、非公平鎖、自旋鎖、自適應(yīng)自旋鎖、分布式鎖、分段鎖等等鎖。所有的鎖都是為了解決一個(gè)問題應(yīng)運(yùn)而生的那就是并發(fā)。而產(chǎn)生并發(fā)的原因是CPU的發(fā)展導(dǎo)致我們程序多線程運(yùn)行。在代碼中我們也經(jīng)常通過多線程來提高產(chǎn)品的吞吐量。
在鎖章節(jié)中我們也是通過多線程案例模擬鎖的產(chǎn)生的。那么Java領(lǐng)域中有哪幾種方式生成線程呢?容我慢慢道來
創(chuàng)建線程
繼承Thread
創(chuàng)建線程的方式Java為我們提供了四種方式,首先是繼承Thread 。復(fù)寫run方法就可以了。
?public class ExtendThread extends Thread{
? ? ?private Integer index;
??
? ? ?public ExtendThread(Integer index) {
? ? ? ? ?this.index = index;
? ? }
? ? ?@Override
? ? ?public void run() {
? ? ? ? ?System.out.println("當(dāng)前索引值:"+index);
? ? }
??
? ? ?public static void main(String[] args) {
? ? ? ? ?for (int i = 0; i < 100; i++) {
? ? ? ? ? ? ?new ExtendThread(i).start();
? ? ? ? }
? ? }
?}實(shí)現(xiàn)Runnable接口
第二種方式就是實(shí)現(xiàn)Runnable接口。我們點(diǎn)進(jìn)Thread源碼也能看到,thread的構(gòu)造需要一個(gè)Runnable接口。
?public class TestRunnable implements Runnable{
? ? ?private String userName;
??
? ? ?public TestRunnable(String userName) {
? ? ? ? ?this.userName = userName;
? ? }
? ? ?@SneakyThrows
? ? ?@Override
? ? ?public void run() {
? ? ? ? ?TimeUnit.SECONDS.sleep(1);
? ? ? ? ?System.out.println("當(dāng)前名稱:"+userName);
? ? }
??
? ? ?public static void main(String[] args) {
? ? ? ? ?for (int i = 0; i < 100; i++) {
? ? ? ? ? ? ?new Thread(new TestRunnable(String.format("我是%s", i))).start();
? ? ? ? }
? ? }
?}實(shí)現(xiàn)Callable接口
除了上面兩種還有一個(gè)接口實(shí)現(xiàn)。還有一個(gè)Callable他和Runnable的區(qū)別在于有返回值
?public class TestCallable implements Callable {
? ? ?private int i;
??
? ? ?public TestCallable(int i) {
? ? ? ? ?this.i = i;
? ? }
? ? ?@Override
? ? ?public Object call() throws Exception {
? ? ? ? ?System.out.println(Thread.currentThread()+"我是"+i);
? ? ? ? ?return i;
? ? }
? ? ?public static void main(String[] args) throws ExecutionException, InterruptedException {
? ? ? ? ?final FutureTask futureTask = new FutureTask(new TestCallable(1));
? ? ? ? ?for (int i = 0; i < 100; i++) {
? ? ? ? ? ? ?new Thread(new FutureTask(new TestCallable(i))).start();
? ? ? ? }
? ? ? ? ?System.out.println(futureTask.get());
? ? }
?}線程池
上面三種應(yīng)該算是線程創(chuàng)建的基本方式。為了提高性能減少線程的開辟與銷毀,JDK提出了線程池的概念。線程池主要是在線程閑置后進(jìn)行回收防止被JVM銷毀。這樣下次在來任務(wù)的時(shí)候就可以直接將閑置的線程提供給任務(wù)使用就可以了。線程池的創(chuàng)建默認(rèn)有三種方式。這里我們使用其中一種,至于線程池我們后面會著重介紹。
?public class TPools {
? ? ?public static void main(String[] args) {
? ? ? ? ?final ExecutorService executorService = Executors.newCachedThreadPool();
? ? ? ? ?for (int i = 0; i < 100; i++) {
??
? ? ? ? ? ? ?int finalI = i;
? ? ? ? ? ? ?executorService.execute(new Runnable() {
? ? ? ? ? ? ? ? ?@Override
? ? ? ? ? ? ? ? ?public void run() {
? ? ? ? ? ? ? ? ? ? ?System.out.println("@@@@@"+ finalI);
? ? ? ? ? ? ? ? }
? ? ? ? ? ? });
? ? ? ? }
? ? }
?}小結(jié)
本章節(jié)我們簡單介紹了四種方式創(chuàng)建線程。使用上沒有區(qū)別。需要注意Callable接口是具有返回值的。這種方式其實(shí)我們可以用來確認(rèn)線程是否執(zhí)行了。然后就是線程池方式創(chuàng)建。從線程的角度四種方式創(chuàng)建出來的線程具有同等性質(zhì)。不同的是線程池會對線程進(jìn)行回收管理。關(guān)于他的回收策略JDK給我們提供了不同的默認(rèn)策略。也支持我們自定義線程結(jié)構(gòu)。
到此這篇關(guān)于java 線程池存在的意義的文章就介紹到這了,更多相關(guān)java 線程池內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
ReentrantLock條件變量使多個(gè)線程順序執(zhí)行
這篇文章主要為大家介紹了ReentrantLock條件變量使多個(gè)線程順序執(zhí)行,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12
SpringBoot如何實(shí)現(xiàn)接口版本控制
這篇文章主要介紹了SpringBoot如何實(shí)現(xiàn)接口版本控制,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-10-10
jmeter+ant+jenkins自動(dòng)化測試環(huán)境配置搭建過程
在搭建jmeter+ant+jenkins環(huán)境有些前提條件,那就是要先配置好java環(huán)境、安裝好jenkins以及配置好jmeter,這樣才能省去很多的事情,對jmeter+ant+jenkins自動(dòng)化測試環(huán)境配置搭建過程感興趣的朋友一起看看吧2021-12-12
JAVA發(fā)送HTTP請求,返回HTTP響應(yīng)內(nèi)容,應(yīng)用及實(shí)例代碼
這篇文章主要介紹了JAVA發(fā)送HTTP請求,返回HTTP響應(yīng)內(nèi)容,應(yīng)用及實(shí)例代碼,需要的朋友可以參考下2014-02-02
java線程中斷?interrupt?和?LockSupport解析
這篇文章主要為大家介紹了java線程中斷?interrupt?和?LockSupport示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02

