您好,登錄后才能下訂單哦!
Java、C#都提供了面向對象的線程模型。它們都抽象出了線程對象,而開發人員在某個類的成員方法中實現線程應用邏輯。通過分離線程對象和線程方法,簡化了線程應用邏輯的開發。
在Java中開發線程有兩種方法。第一種方法是由Thread派生一個線程類,實現run方法,并調用Thread.start方法啟動線程,如:
class MyThread extends Thread { //創建線程類XML:namespace prefix = o ns = "urn:schemas-microsoft-com:Office:office" />
public void run() {…} //線程方法
}
MyThread aThread = new MyThread(); //創建一個線程對象
aThread.start() ; //啟動線程
第二種方法是通過實現Runable接口創建一個可執行類,并利用一個Thread對象來啟動線程,如:
class MyRunable implements Runnable{
public void run() {…} //線程方法
}
MyRunable aRunable = new MyRunable(); //創建一個可執行對象
Thread aThread = new Thread(aRunable); //創建一個線程對象,并與可執行對象關聯
aThread.start() ; //啟動線程
C#的線程模型將線程對象和線程方法分離得更徹底,它可將任何一個原型為void( )的公有類成員方法(靜態或非靜態)用作線程方法;另外線程啟動時還指定一個提供線程方法的對象(該對象提供線程應用邏輯所需的各種信息)。下面是一個簡單的例子:
using System;
using System.Threading;
public class ThreadWork { //ThreadWork不顯式繼承任何類,DoWork可作為線程方法
public void DoWork() { for(int i = 0; i<10 ;i++) Console.WriteLine("Working thread..."); } //End of DoWork
} //End of ThreadWork
class ThreadTest{
public static void Main() { //將對象aThread 的DoWork方法作為線程方法執行
ThreadWork aThread = new ThreadWork();
ThreadStart myThreadDelegate = new ThreadStart(aThread.DoWork); //指定線程方法
Thread myThread = new Thread(myThreadDelegate); //創建線程對象
myThread.Start(); //啟動線程
} //End of
} //End of ThreadTest
開發人員最關心的是如何實現線程方法。Java線程模型提供兩種方法來實現線程方法,重載Runable.run方法或者重載Thread.run方法。開發人員可根據具體的應用場合選擇合適的基類(Runable或者Thread),這是Java線程模型的一個優點。另外可以看到,Java線程模型中只能在Runable或Thread的子類中實現線程方法(即子類的run方法),而且每個子類只能實現一個線程方法。C#線程模型由于允許將任何一個原型為void( )的公有類成員方法(靜態或非靜態)用作線程方法,因此它實際上允許在任何一個類(不要求這個類是某個類的子類)中實現線程方法,而且同一個類中可以實現多個線程方法。面向對象的線程模型有兩個要素:線程對象和線程方法。線程對象封裝線程本身相關的邏輯,如線程的創建、銷毀等等。而線程方法就是線程對象實際執行的任務。利用面向對象線程模型進行多線程開發時,這樣來思考問題會更自然:現在我有一項工作(即設計了一個線程方法),找一個工人(線程對象)來完成這個工作吧。所以我們認為C#的線程模型更靈活,而這種靈活性使得開發人員能夠將程序結構組織的更加清晰、合理。免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。