成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Java 5.0 多線程編程實踐

開發(fā) 后端
Java5增加了新的類庫并發(fā)集java.util.concurrent,該類庫為并發(fā)程序提供了豐富的API多線程編程在Java 5中更加容易,靈活。本文通過一個網(wǎng)絡(luò)服務(wù)器模型,來實踐Java5的多線程編程。

Java5增加了新的類庫并發(fā)集java.util.concurrent,該類庫為并發(fā)程序提供了豐富的API多線程編程在Java 5中更加容易,靈活。本文通過一個網(wǎng)絡(luò)服務(wù)器模型,來實踐Java5的多線程編程,該模型中使用了Java5中的線程池,阻塞隊列,可重入鎖等,還實踐了Callable, Future等接口,并使用了Java 5的另外一個新特性泛型。

簡介

本文將實現(xiàn)一個網(wǎng)絡(luò)服務(wù)器模型,一旦有客戶端連接到該服務(wù)器,則啟動一個新線程為該連接服務(wù),服務(wù)內(nèi)容為往客戶端輸送一些字符信息。一個典型的網(wǎng)絡(luò)服務(wù)器模型如下:

1. 建立監(jiān)聽端口。

2. 發(fā)現(xiàn)有新連接,接受連接,啟動線程,執(zhí)行服務(wù)線程。 3. 服務(wù)完畢,關(guān)閉線程。

這個模型在大部分情況下運行良好,但是需要頻繁的處理用戶請求而每次請求需要的服務(wù)又是簡短的時候,系統(tǒng)會將大量的時間花費在線程的創(chuàng)建銷毀。Java 5的線程池克服了這些缺點。通過對重用線程來執(zhí)行多個任務(wù),避免了頻繁線程的創(chuàng)建與銷毀開銷,使得服務(wù)器的性能方面得到很大提高。因此,本文的網(wǎng)絡(luò)服務(wù)器模型將如下:

1. 建立監(jiān)聽端口,創(chuàng)建線程池。
2. 發(fā)現(xiàn)有新連接,使用線程池來執(zhí)行服務(wù)任務(wù)。

3. 服務(wù)完畢,釋放線程到線程池。

下面詳細(xì)介紹如何使用Java 5的concurrent包提供的API來實現(xiàn)該服務(wù)器。

初始化

初始化包括創(chuàng)建線程池以及初始化監(jiān)聽端口。創(chuàng)建線程池可以通過調(diào)用java.util.concurrent.Executors類里的靜態(tài)方法newChahedThreadPool或是newFixedThreadPool來創(chuàng)建,也可以通過新建一個java.util.concurrent.ThreadPoolExecutor實例來執(zhí)行任務(wù)。這里我們采用newFixedThreadPool方法來建立線程池。

 ExecutorService pool = Executors.newFixedThreadPool(10);

表示新建了一個線程池,線程池里面有10個線程為任務(wù)隊列服務(wù)。

使用ServerSocket對象來初始化監(jiān)聽端口。

private static final int PORT = 19527;

serverListenSocket = new ServerSocket(PORT);

serverListenSocket.setReuseAddress(true);

serverListenSocket.setReuseAddress(true);

服務(wù)新連接

當(dāng)有新連接建立時,accept返回時,將服務(wù)任務(wù)提交給線程池執(zhí)行。

while(true){

Socket socket = serverListenSocket.accept();

pool.execute(new ServiceThread(socket));

}

這里使用線程池對象來執(zhí)行線程,減少了每次線程創(chuàng)建和銷毀的開銷。任務(wù)執(zhí)行完畢,線程釋放到線程池。#p#

服務(wù)任務(wù)

服務(wù)線程ServiceThread維護一個count來記錄服務(wù)線程被調(diào)用的次數(shù)。每當(dāng)服務(wù)任務(wù)被調(diào)用一次時,count的值自增1,因此ServiceThread提供一個increaseCount和getCount的方法,分別將count值自增1和取得該count值。由于可能多個線程存在競爭,同時訪問count,因此需要加鎖機制,在Java 5之前,我們只能使用synchronized來鎖定。Java 5中引入了性能更加粒度更細(xì)的重入鎖ReentrantLock。我們使用ReentrantLock保證代碼線程安全。下面是具體代碼:

private static ReentrantLock lock = new ReentrantLock ();
 
   private static int count = 0;
 
   private int getCount(){
 
   int ret = 0;

    try{
 
   lock.lock();
 
   ret = count;
 
   }finally{
 
   lock.unlock();
 
   }
 
   return ret;
 
   }
 
   private void increaseCount(){
 
   try{
 
  lock.lock();
 
   ++count;
 
   }finally{
 
   lock.unlock();
 
   }
 
  }

服務(wù)線程在開始給客戶端打印一個歡迎信息,

increaseCount();

  int curCount = getCount();

 helloString = "hello, id = " + curCount+"\r\n";

 dos = new DataOutputStream(connectedSocket.getOutputStream());
 
  dos.write(helloString.getBytes());

然后使用ExecutorService的submit方法提交一個Callable的任務(wù),返回一個Future接口的引用。這種做法對費時的任務(wù)非常有效,submit任務(wù)之后可以繼續(xù)執(zhí)行下面的代碼,然后在適當(dāng)?shù)奈恢每梢允褂肍uture的get方法來獲取結(jié)果,如果這時候該方法已經(jīng)執(zhí)行完畢,則無需等待即可獲得結(jié)果,如果還在執(zhí)行,則等待到運行完畢。

ExecutorService executor = Executors.newSingleThreadExecutor();
 
   Future future = executor.submit(new TimeConsumingTask());
 
   dos.write("let's do soemthing other".getBytes());
 
   String result = future.get();

    dos.write(result.getBytes());
 
   //其中TimeConsumingTask實現(xiàn)了Callable接口
 
   class TimeConsumingTask implements Callable {
 
   public String call() throws Exception {
 
   System.out.println("It's a time-consuming task,
       you'd better retrieve your result in the furture");
 
   return "ok, here's the result: It takes me lots of time to produce this result";
 
   }
 
   }

這里使用了Java 5的另外一個新特性泛型,聲明TimeConsumingTask的時候使用了String做為類型參數(shù)。必須實現(xiàn)Callable接口的call函數(shù),其作用類似與Runnable中的run函數(shù),在call函數(shù)里寫入要執(zhí)行的代碼,其返回值類型等同于在類聲明中傳入的類型值。在這段程序中,我們提交了一個Callable的任務(wù),然后程序不會堵塞,而是繼續(xù)執(zhí)行dos.write("let's do soemthing other".getBytes());當(dāng)程序執(zhí)行到String result = future.get()時如果call函數(shù)已經(jīng)執(zhí)行完畢,則取得返回值,如果還在執(zhí)行,則等待其執(zhí)行完畢。

【編輯推薦】

  1. J2ME中多線程網(wǎng)絡(luò)連接編程的分析
  2. 使用Java建立穩(wěn)定的多線程服務(wù)器
  3. Java多線程程序設(shè)計初步
責(zé)任編輯:佚名 來源: IBM
相關(guān)推薦

2023-06-16 08:36:25

多線程編程數(shù)據(jù)競爭

2009-03-12 10:52:43

Java線程多線程

2013-05-28 15:35:47

html5多線程

2024-10-10 09:46:18

2013-07-16 10:12:14

iOS多線程多線程概念多線程入門

2018-10-25 15:55:44

Java多線程鎖優(yōu)化

2011-07-22 14:55:20

多線程

2009-07-29 16:42:35

Java多線程編程

2011-06-13 10:41:17

JAVA

2023-06-13 13:39:00

多線程異步編程

2009-06-16 13:48:42

Java多線程

2023-04-02 17:53:10

多線程編程自測

2023-06-07 13:49:00

多線程編程C#

2023-06-05 07:56:10

線程分配處理器

2023-06-06 08:17:52

多線程編程Thread類

2023-05-12 14:14:00

Java線程中斷

2013-07-16 12:13:27

iOS多線程多線程概念GCD

2013-07-16 10:57:34

iOS多線程多線程概念多線程入門

2011-06-07 17:35:39

iphone 多線程

2013-07-15 15:35:06

點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 超碰3 | 狠狠操狠狠搞 | 亚洲精品久久久久久久久久久 | 国产精品久久影院 | 亚洲小说图片 | 国产一级免费在线观看 | 国产乱码久久久久久 | 欧美在线视频一区二区 | 51ⅴ精品国产91久久久久久 | 免费精品一区 | 欧美一区二区三区视频在线观看 | 成人在线观看黄 | 本地毛片 | 91亚洲一区| 日韩精品极品视频在线观看免费 | 一区二区三区视频 | 成人精品国产免费网站 | 久久亚洲春色中文字幕久久久 | 97精品国产 | 久久精品国产亚洲一区二区三区 | 成人在线免费观看av | 中文字幕日韩欧美一区二区三区 | 日韩在线小视频 | 久久久日韩精品一区二区三区 | 国产精品久久久爽爽爽麻豆色哟哟 | 中文字幕第三页 | 国产高清在线精品一区二区三区 | 成人3d动漫一区二区三区91 | 毛片免费看 | 亚洲午夜精品视频 | 久久久久久久久国产精品 | 大陆一级毛片免费视频观看 | 亚洲一卡二卡 | 色婷婷亚洲国产女人的天堂 | 在线观看成人精品 | 久久噜噜噜精品国产亚洲综合 | 色偷偷888欧美精品久久久 | 操亚洲 | 国产成人免费视频 | 在线观看www高清视频 | 91精品久久久久久久久久 |