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

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

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

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

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

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

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

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

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

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

2.   線程的生命周期

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

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

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

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

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

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

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

創(chuàng)建線程推介實現(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對象的執(zhí)行。Executor對象創(chuàng)建并管理一組Runnable對象的線程,這組線程就做線程池(thread pool).優(yōu)點是Executor對象能復(fù)用了已經(jīng)有的線程,減少為每個任務(wù)創(chuàng)建新線程的開銷,提高性能。

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

       ExecutorService接口擴展了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)多個并發(fā)線程對共享數(shù)據(jù)的訪問。這種方式同步多個線程,就可以保證訪問共享對象的每個線程都能同步地將其他所有線程排除在外,這被稱為“互斥”。
另一個方法,使用JAVA內(nèi)置的監(jiān)控器(monitor)。每個對象都有一個監(jiān)控器和監(jiān)控鎖(或內(nèi)置鎖)。監(jiān)控器保證任何時候監(jiān)控鎖由具有最大可能的唯一一個線程持有。

(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>

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

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

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 好男人在线观看hd中字 | a级亚洲片精品久久久久久久 | 亚洲精品αv一区二区三区 亚洲精品91大神在线观看 | gayrb免费漫画入口 | 色热综合 | 国产成人激情 | 亚洲免费视频一区二区三区 | 精品国产免费第一区二区 | 精品国产一区二区三区在线观看 | 99久热只有精品视频免费看 | 猛男深夜狂cao小男生 | 肠交女王magnet | 久久不卡免费视频 | 精品久久99麻豆蜜桃666 | 9自拍视频在线观看 | 青青视频国产依人在线 | 四虎影院观看 | 美女视频91 | 明星梦淫| 亚洲AV国产精品无码精 | 久久精品无码一区二区日韩av | 亚洲区视频在线观看 | 欧美三级小说 | 国产精品麻豆久久99 | 日本嫩小xxxxhd | 2020最新韩国理论三级0k | 九九在线精品视频 | 特级毛片免费观看视频 | 色老板在线免费观看 | 草莓视频网站18勿进 | 无人区在线观看免费视频国语 | 视频一区国产精戏刘婷30 | 亚洲国产货青视觉盛宴 | 成人久久18免费网站 | 满溢游泳池免费土豪全集下拉版 | 国产99视频精品免费视频免里 | 高h全肉np触手 | 波多野结衣护士 | 久久婷婷五月综合色丁香花 | 娇妻被朋友征服中文字幕 | 国产资源中文字幕 |