自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

揭秘Perl線程歷史

開發(fā) 架構
你對Perl線程的概念是否熟悉,Perl線程是一個單一的執(zhí)行流程,它是所有程序執(zhí)行過程中最小的控制單位,即能被CPU所調度的最小任務單元。

本文和大家介紹一下Perl線程的概念,Perl線程是一個單一的執(zhí)行流程,簡單地說,一個Perl線程必然屬于某一個進程,而一個進程包含至少一個或者多個Perl線程。

Perl線程概述

Perl線程是一個單一的執(zhí)行流程,它是所有程序執(zhí)行過程中最小的控制單位,即能被CPU所調度的最小任務單元。Perl線程與進程之間既有聯系,又完全不同。簡單地說,一個Perl線程必然屬于某一個進程,而一個進程包含至少一個或者多個Perl線程。早期的計算機系統一次只能運行一個程序,因此,當有多個程序需要執(zhí)行的時候,***的辦法就是讓它們排成隊,按順序串行執(zhí)行。進程的出現打破了這種格局,CPU資源按時間片被分割開來,分配給不同的進程使用。

這樣一來,從微觀上看進程的執(zhí)行雖然仍是串行的,但是從宏觀上看,不同的程序已經是在并行執(zhí)行了。如果我們把同樣的思想運用到進程上,很自然地就會把進程再細分成更小的執(zhí)行單位,即Perl線程。由于一個進程又往往需要同時執(zhí)行多個類似的任務,因此這些被細分的Perl線程之間可以共享相同的代碼段,數據段和文件句柄等資源。有了進程,我們可以在一臺單CPU計算機系統上同時運行Firefox和MicrosoftOfficeWord等多個程序;有了Perl線程,我們可以使Firefox在不同的標簽里同時加載多個不同的頁面,在OfficeWord里編輯文檔的同時進行語法錯誤檢查。因此,Perl線程給我們帶來了更高的CPU利用率、更快速的程序響應、更經濟地資源使用方式和對多CPU的體系結構更良好的適應性。

--------------------------------------------------------------------------------

Perl線程的歷史

5005threadsPerl線程模型

Perl對Perl線程的支持最早可以追溯到1998年7月發(fā)布的Perlv5.005。其發(fā)布申明指出,Perlv5.005中加入了對操作系統級Perl線程的支持,這個新特性是一個實驗性的產品,這也就是我們現在所稱的5005threadsPerl線程模型。對于5005threadsPerl線程模型來說,默認情況下,所有數據結構都是共享的,所以用戶必須負責這些共享數據結構的同步訪問。如今5005threads已經不再被推薦實用,Perlv5.10以后的版本里,也將不會再支持5005threadsPerl線程模型。

ithreadsPerl線程模型

2000年5月發(fā)布的Perlv5.6.0中開始引入了一個全新的Perl線程模型,即interpreterthreads,或稱為ithreads,也正是在這個版本的發(fā)布申明中***次提出了5005threadsPerl線程模型將來可能會被禁用的問題。盡管如此,ithreads在那個時候還是一個新的實驗性的Perl線程模型,用戶并不能直接使用它,***的辦法是通過fork函數模擬。經過兩年時間的發(fā)展,到2002年7月,Perlv5.8.0正式發(fā)布,這時ithreads已經是一個相對成熟的Perl線程模型,發(fā)布申明中也鼓勵用戶從老的5005threadsPerl線程模型轉換到新的ithreadsPerl線程模型,并明確指出5005threadsPerl線程模型最終將被淘汰。本文后面所討論的所有內容也都是基于新的ithreadsPerl線程模型。在ithreadsPerl線程模型中,最與眾不同的特點就在于默認情況一下一切數據結構都不是共享的,這一點我們會在后面內容中有更深刻的體會。

現有環(huán)境支持哪種Perl線程模型

既然Perl中有可能存在兩種不同的Perl線程模型,我們很自然地就需要判斷現有Perl環(huán)境到底支持的是哪一種Perl線程實現方式。歸納起來,我們有兩種方法:

在shell里,我們可以通過執(zhí)行perl–V|grepusethreads命令來獲取當前Perl線程模型的相關信息,例如

清單1.shell中查詢Perl當前Perl線程模型
 

  1. >perl-V|grepuse.*threads  
  2. config_args='-des-Doptimize=-O2-g-pipe-m32-march=i386-mtune=pentium4-Dversion=5.8.5  
  3. -Dmyhostname=localhost-Dperladmin=root@localhost-Dcc=gcc-Dcf_by=RedHat,Inc.  
  4. -Dinstallprefix=/usr-Dprefix=/usr-Darchname=i386-linux-Dvendorprefix=/usr  
  5. -Dsiteprefix=/usr-Duseshrplib-Dusethreads-Duseithreads-Duselargefiles-Dd_dosuid  
  6. -Dd_semctl_semun-Di_db-Ui_ndbm-Di_gdbm-Di_shadow-Di_syslog-Dman3ext=3pm-Duseperlio  
  7. -Dinstallusrbinperl-Ubincompat5005-Uversiononly-Dpager=/usr/bin/less-isr  
  8. -Dinc_version_list=5.8.45.8.35.8.25.8.15.8.0'  
  9. usethreads=defineuse5005threads=undefuseithreads=defineusemultiplicity=define  

 從結果中不難看出,在當前的Perl環(huán)境中提供了對ithreadsPerl線程模型的支持。

在Perl程序中,我們也可以通過使用Config模塊來動態(tài)獲取PerlPerl線程模型的相關信息,例如

清單2.Perl程序中動態(tài)獲取當前PerlPerl線程模型 

  1. #!/usr/bin/perl  
  2. #  
  3. useConfig;  
  4.  
  5. if($Config{useithreads}){  
  6. printf("Helloithreads\n")  
  7. }  
  8. elsif($Config{use5005threads}){  
  9. printf("Hello5005threads\n");  
  10. }  
  11. else{  
  12. printf("Cannotsupportthreadinyourperlenvironment\n");  
  13. exit(1);  
  14. }  
  15.  

 值得一提的是,對于5005threads和ithreadsPerl線程模型,Perl同時只能支持其中的一種。你不可能在某一個Perl環(huán)境中同時使用這兩種Perl線程模型。本文后面討論的所有內容都是基于ithreadsPerl線程模型的。

【編輯推薦】

 

  1. Perl線程的生命周期
  2. Perl文件句柄概念詳解
  3. 追溯Perl線程的歷史
  4. 專家推薦 幾款常用Perl開發(fā)工具
  5. 學習筆記 深入剖析Perl線程的生命周期
責任編輯:佚名 來源: csdn.net
相關推薦

2010-07-14 10:41:58

Perl線程

2010-07-13 09:34:24

Perl純變量

2010-07-20 08:58:28

Perl類

2010-07-23 15:37:22

Perl調試器用法

2010-07-23 14:04:43

Perl grep函數

2010-07-20 16:13:25

Perl線程

2010-07-15 15:39:51

Perl線程

2010-07-20 10:48:56

Perl文件操作

2010-07-26 13:27:19

Perl多線程

2010-07-19 09:28:37

Perl關聯數組

2010-07-20 14:27:46

Perl命令行

2010-07-15 15:21:07

Perl線程

2010-07-19 16:56:56

Perl線程

2010-07-14 10:48:37

Perl線程

2010-07-15 15:25:57

Perl線程

2010-07-14 10:59:15

Perl線程

2010-07-15 15:32:10

Perl線程

2010-07-14 10:30:26

Perl多線程

2014-04-10 10:24:00

編程語言排行榜

2010-07-21 14:18:27

Perl函數
點贊
收藏

51CTO技術棧公眾號