一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務(wù)器之家 - 編程語言 - Java教程 - java多線程編程技術(shù)詳解和實(shí)例代碼

java多線程編程技術(shù)詳解和實(shí)例代碼

2020-09-11 10:18Java之家 Java教程

這篇文章主要介紹了 java多線程編程技術(shù)詳解和實(shí)例代碼的相關(guān)資料,需要的朋友可以參考下

 java多線程編程技術(shù)詳解和實(shí)例代碼

1.   Java和他的API都可以使用并發(fā)。

可以指定程序包含不同的執(zhí)行線程,每個(gè)線程都具有自己的方法調(diào)用堆棧和程序計(jì)數(shù)器,使得線程在與其他線程并發(fā)地執(zhí)行能夠共享程序范圍內(nèi)的資源,比如共享內(nèi)存,這種能力被稱為多線程編程(multithreading),在核心的C和C++語言中并不具備這種能力,盡管他們影響了JAVA的設(shè)計(jì)。

2.   線程的生命周期

新線程的生命周期從“新生”狀態(tài)開始。程序啟動(dòng)線程前,線程一直是“新生”狀態(tài);程序啟動(dòng)線程后,線程進(jìn)入“可運(yùn)行”狀態(tài)。“可運(yùn)行”狀態(tài)的線程,被認(rèn)為是正在執(zhí)行他的任務(wù)。

在程序啟動(dòng)線程之前,線程一直處于“等待”狀態(tài),只有當(dāng)另一個(gè)線程通知正在等待的線程繼續(xù)執(zhí)行時(shí),這個(gè)線程才會(huì)從“等待”狀態(tài)恢復(fù)到“可運(yùn)行”狀態(tài)。

“可運(yùn)行”狀態(tài)的線程可以進(jìn)入“定時(shí)等待”狀態(tài),等待一個(gè)指定的時(shí)間段。當(dāng)時(shí)間到達(dá)或線程正在等待的某個(gè)事件發(fā)生時(shí),該線程就會(huì)返回“可運(yùn)行”狀態(tài)。即使處理器可以使用,處于“定時(shí)等待”狀態(tài)和“等待”狀態(tài)的線程也不能用它。當(dāng)處于“可運(yùn)行”狀態(tài)的線程正在等待另一個(gè)線程執(zhí)行任務(wù)時(shí),如果它提供了可選的等待時(shí)間段,則這個(gè)線程會(huì)進(jìn)入“定時(shí)等待”狀態(tài)。當(dāng)另一個(gè)線程通知了這個(gè)線程,或者當(dāng)定時(shí)的時(shí)間段到達(dá)時(shí)(以先滿足的為準(zhǔn)),這個(gè)線程就會(huì)返回到“可運(yùn)行”狀態(tài).。使線程進(jìn)入“定時(shí)等待”狀態(tài)的另一方法是是處于“可運(yùn)行”狀態(tài)的線程睡眠。睡眠線程會(huì)在“定時(shí)等待”狀態(tài)維持一個(gè)指定的時(shí)間段(稱為睡眠時(shí)間段),過了這段時(shí)間,它會(huì)返回到“可運(yùn)行”狀態(tài)。當(dāng)線程沒有工作要執(zhí)行時(shí),它會(huì)立即睡眠。;例
當(dāng)線程試圖執(zhí)行某個(gè)任務(wù),而任務(wù)又不能立即完成,線程就從“可運(yùn)行”狀態(tài)轉(zhuǎn)到“阻塞”狀態(tài)。;例。即使有處理器可供使用,“阻塞”狀態(tài)的線程也不能使用它。

線程成功完成任務(wù),或者(由于出錯(cuò))終止了時(shí),“可運(yùn)行”線程就會(huì)進(jìn)入“終止”狀態(tài)(有時(shí)稱“停滯”狀態(tài))。
在操作系統(tǒng)級(jí)別,JAVA的“可運(yùn)行”狀態(tài)通常包含兩個(gè)獨(dú)立的狀態(tài)。當(dāng)線程首先從“新生”狀態(tài)轉(zhuǎn)到“可運(yùn)行”狀態(tài),線程處于“就緒”狀態(tài)。當(dāng)操作系統(tǒng)將線程給處理器時(shí),線程就從“就緒”狀態(tài)進(jìn)入“運(yùn)行”狀態(tài)(即開始執(zhí)行),這也被稱為“調(diào)度線程”。大多數(shù)操作系統(tǒng)中,每個(gè)線程被賦予一小段處理器時(shí)間(時(shí)間片)來執(zhí)行任務(wù)。當(dāng)時(shí)間片到達(dá)時(shí),線程就會(huì)返回到“就緒”狀態(tài),而操作系統(tǒng)將另一個(gè)線程給予處理器。

3.   線程優(yōu)先級(jí)與線程調(diào)度

JAVA的線程優(yōu)先級(jí)范圍為MIN_PRIORITY(常量1)到MAX_PRIORITY(常量10),默認(rèn)是NORM_PRIORITY(常量5)

4.   創(chuàng)建并執(zhí)行線程

創(chuàng)建線程推介實(shí)現(xiàn)Runnable接口

(1)Runnable與Thread類

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
// Fig. 4.1: PrintTask.java
 
// PrintTask class sleeps for a random time from 0 to 5 seconds
 
import java.util.Random;
 
  
 
public class PrintTask implements Runnable 
 
{
 
  private final int sleepTime; // random sleep time for thread
 
  private final String taskName; // name of task
 
  private final static Random generator = new Random();
 
   
 
  public PrintTask( String name )
 
  {
 
   taskName = name; // set task name
 
     
 
   // pick random sleep time between 0 and 5 seconds
 
   sleepTime = generator.nextInt( 5000 ); // milliseconds
 
  } // end PrintTask constructor
 
  
 
  // method run contains the code that a thread will execute
 
  public void run()
 
  {
 
   try // put thread to sleep for sleepTime amount of time 
 
   {
 
     System.out.printf( "%s going to sleep for %d milliseconds.\n"
 
      taskName, sleepTime );
 
     Thread.sleep( sleepTime ); // put thread to sleep
 
   } // end try    
 
   catch ( InterruptedException exception )
 
   {
 
     System.out.printf( "%s %s\n", taskName,
 
      "terminated prematurely due to interruption" );
 
   } // end catch
 
     
 
   // print task name
 
   System.out.printf( "%s done sleeping\n", taskName ); 
 
  } // end method run
 
} // end class PrintTask
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
// Fig. 4.2 ThreadCreator.java
 
// Creating and starting three threads to execute Runnables.
 
import java.lang.Thread;
 
  
 
public class ThreadCreator
 
{
 
  public static void main( String[] args )
 
  {
 
   System.out.println( "Creating threads" );
 
  
 
   // create each thread with a new targeted runnable
 
   Thread thread1 = new Thread( new PrintTask( "task1" ) );
 
   Thread thread2 = new Thread( new PrintTask( "task2" ) );
 
   Thread thread3 = new Thread( new PrintTask( "task3" ) );
 
  
 
   System.out.println( "Threads created, starting tasks." );
 
  
 
   // start threads and place in runnable state
 
   thread1.start(); // invokes task1抯 run method
 
   thread2.start(); // invokes task2抯 run method
 
   thread3.start(); // invokes task3抯 run method
 
  
 
   System.out.println( "Tasks started, main ends.\n" );
 
  } // end main
 
} // end class RunnableTester  

     (2)線程管理與Executor框架

       5為顯示的創(chuàng)建線程,但推介使用Executor接口,用來管理Runnable對(duì)象的執(zhí)行。Executor對(duì)象創(chuàng)建并管理一組Runnable對(duì)象的線程,這組線程就做線程池(thread pool).優(yōu)點(diǎn)是Executor對(duì)象能復(fù)用了已經(jīng)有的線程,減少為每個(gè)任務(wù)創(chuàng)建新線程的開銷,提高性能。

       Executor接口只聲明了一個(gè)名稱為execute的方法,接收一個(gè)Runnable實(shí)參。Executor會(huì)將傳遞給他的execute方法的每個(gè)Runnable對(duì)象賦予線程池中可以用的線程。如果沒有可以用的線程,則Executor會(huì)創(chuàng)建一個(gè)新線程,或等待某個(gè)線程會(huì)成為可用的,并會(huì)將這個(gè)線程賦予傳遞給execute方法的Runnable對(duì)象。

       ExecutorService接口擴(kuò)展了Executor接口。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
// Fig. 4.3: TaskExecutor.java
// Using an ExecutorService to execute Runnables.
import java.util.concurrent.Executors;
import java.util.concurrent.ExecutorService;
 
public class TaskExecutor
{
  public static void main( String[] args )
  {
   // create and name each runnable
   PrintTask task1 = new PrintTask( "task1" );
   PrintTask task2 = new PrintTask( "task2" );
   PrintTask task3 = new PrintTask( "task3" );
     
   System.out.println( "Starting Executor" );
 
   // create ExecutorService to manage threads
   ExecutorService threadExecutor = Executors.newCachedThreadPool();
 
   // start threads and place in runnable state
   threadExecutor.execute( task1 ); // start task1  
   threadExecutor.execute( task2 ); // start task2
   threadExecutor.execute( task3 ); // start task3
 
   // shut down worker threads when their tasks complete
   threadExecutor.shutdown(); 
 
   System.out.println( "Tasks started, main ends.\n" );
  } // end main
} // end class TaskExecutor

5.       線程同步 

(1)線程同步(thread synchronization),協(xié)調(diào)多個(gè)并發(fā)線程對(duì)共享數(shù)據(jù)的訪問。這種方式同步多個(gè)線程,就可以保證訪問共享對(duì)象的每個(gè)線程都能同步地將其他所有線程排除在外,這被稱為“互斥”。
另一個(gè)方法,使用JAVA內(nèi)置的監(jiān)控器(monitor)。每個(gè)對(duì)象都有一個(gè)監(jiān)控器和監(jiān)控鎖(或內(nèi)置鎖)。監(jiān)控器保證任何時(shí)候監(jiān)控鎖由具有最大可能的唯一一個(gè)線程持有。

(2)同步的數(shù)據(jù)共享:執(zhí)行原子操作。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
// Adds integers to an array shared with other Runnables
 
import java.lang.Runnable;
 
  
 
public class ArrayWriter implements Runnable
 
{
 
  private final SimpleArray sharedSimpleArray;
 
  private final int startValue;
 
  
 
  public ArrayWriter( int value, SimpleArray array )
 
  {
 
   startValue = value;
 
   sharedSimpleArray= array;
 
  } // end constructor
 
  
 
  public void run()
 
  {
 
   for ( int i = startValue; i < startValue + 3; i++ )
 
   {
 
     sharedSimpleArray.add( i ); // add an element to the shared array
 
   } // end for
 
  } // end method run
 
} // end class ArrayWrite
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
// Fig 5.2: SharedArrayTest.java
 
// Executes two Runnables to add elements to a shared SimpleArray.
 
import java.util.concurrent.Executors;
 
import java.util.concurrent.ExecutorService;
 
import java.util.concurrent.TimeUnit;
 
  
 
public class SharedArrayTest
 
{
 
  public static void main( String[] arg )
 
  {
 
   // construct the shared object
 
   SimpleArray sharedSimpleArray = new SimpleArray( 6 );
 
  
 
   // create two tasks to write to the shared SimpleArray
 
   ArrayWriter writer1 = new ArrayWriter( 1, sharedSimpleArray );
 
   ArrayWriter writer2 = new ArrayWriter( 11, sharedSimpleArray );
 
  
 
   // execute the tasks with an ExecutorService
 
   ExecutorService executor = Executors.newCachedThreadPool();
 
   executor.execute( writer1 );
 
   executor.execute( writer2 );
 
  
 
   executor.shutdown();
 
  
 
   try
 
   {
 
     // wait 1 minute for both writers to finish executing
 
     boolean tasksEnded = executor.awaitTermination( 
 
      1, TimeUnit.MINUTES );
 
  
 
     if ( tasksEnded )
 
      System.out.println( sharedSimpleArray ); // print contents
 
     else
 
      System.out.println( 
 
        "Timed out while waiting for tasks to finish." );
 
   } // end try
 
   catch ( InterruptedException ex )
 
   {
 
     System.out.println( 
 
      "Interrupted while wait for tasks to finish." );
 
   } // end catch
 
  } // end main
 
} // end class SharedArrayTest
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
// Fig.5.3 : SimpleArray.java
 
// Class that manages an integer array to be shared by multiple 
 
// threads with synchronization.
 
import java.util.Random;
 
  
 
public class SimpleArray
 
{
 
  private final int array[]; // the shared integer array
 
  private int writeIndex = 0; // index of next element to be written
 
  private final static Random generator = new Random();
 
  
 
  // construct a SimpleArray of a given size
 
  public SimpleArray( int size )
 
  {
 
   array = new int[ size ];
 
  } // end constructor
 
  
 
  // add a value to the shared array
 
  public synchronized void add( int value )
 
  {
 
   int position = writeIndex; // store the write index
 
  
 
   try
 
   {
 
     // put thread to sleep for 0-499 milliseconds
 
     Thread.sleep( generator.nextInt( 500 ) ); 
 
   } // end try
 
   catch ( InterruptedException ex )
 
   {
 
     ex.printStackTrace();
 
   } // end catch
 
  
 
   // put value in the appropriate element
 
   array[ position ] = value;
 
   System.out.printf( "%s wrote %2d to element %d.\n"
 
     Thread.currentThread().getName(), value, position );
 
  
 
   ++writeIndex; // increment index of element to be written next
 
   System.out.printf( "Next write index: %d\n", writeIndex );
 
  } // end method add
 
   
 
  // used for outputting the contents of the shared integer array
 
  public String toString()
 
  {
 
   String arrayString = "\nContents of SimpleArray:\n";
 
   
 
   for ( int i = 0; i < array.length; i++ )
 
     arrayString += array[ i ] + " ";
 
   
 
   return arrayString;
 
  } // end method toString
 
} // end class SimpleArray
 
<br>

感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!

原文鏈接:http://blog.csdn.net/kkkloveyou/article/details/6724083

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 日本乱人伦中文在线播放 | 性欧美video 性满足久久久久久久久 | 色哟哟在线资源 | 亚洲 综合 欧美在线 热 | 婷婷婷色| 国产日韩欧美综合一区二区三区 | 武侠艳妇屈辱的张开双腿 | 肥奶丰熟肥妇 | 婷婷婷色 | 边摸边吃奶又黄激烈视频韩国 | 亚洲天堂视频在线观看 | 国产麻豆成91 | aⅴ免费视频 | 韩国三级日本三级香港三级黄 | 日本一区二区视频免费播放 | 国产久草在线 | 贰佰麻豆剧果冻传媒一二三区 | 99久9在线视频 | 婷婷色在线播放 | 秋霞一级黄色片 | 欧美整片在线 | 久久中文字幕亚洲精品最新 | 日本乱子 | 亚洲图片 自拍偷拍 | 亚洲男人第一天堂 | 福利片福利一区二区三区 | 美女扒开腿让男生桶爽漫画 | 亚洲成人91 | 欧美综合在线 | 免费看又黄又爽又猛的视频软件- | 91精品天美精东蜜桃传媒免费 | 欧美作爱福利免费观看视频 | 欧美日韩在线观看区一二 | 国产成人在线视频播放 | 国产精品第1页在线播放 | 被强迫变性翘秘书 | futa百合文| 好猛好紧好硬使劲好大刺激视频 | 91外围| 惊弦45集免费看 | 日本一二线不卡在线观看 |