亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識庫 > Erlang并發編程介紹

Erlang并發編程介紹

熱門標簽:實體店地圖標注怎么標 萬利達綜合醫院地圖標注點 南京電銷外呼系統哪家好 地圖標注如何弄全套標 外呼系統會封嗎 在電子版地圖標注要收費嗎 武漢AI電銷機器人 電銷機器人 深圳 股票配資電銷機器人

Erlang中的process——進程是輕量級的,并且進程間無共享。查了很多資料,似乎沒人說清楚輕量級進程算是什么概念,繼續查找中。。。閑話不提,進入并發編程的世界。本文算是學習筆記,也可以說是《Concurrent Programming in ERLANG》第五張的簡略翻譯。

1.進程的創建

    進程是一種自包含的、分隔的計算單元,并與其他進程并發運行在系統中,在進程間并沒有一個繼承體系,當然,應用開發者可以設計這樣一個繼承體系。
    進程的創建使用如下語法:

復制代碼 代碼如下:

Pid = spawn(Module, FunctionName, ArgumentList)

spawn接受三個參數:模塊名,函數名以及參數列表,并返回一個代表創建的進程的標識符(Pid)。
如果在一個已知進程Pid1中執行:
復制代碼 代碼如下:

Pid2 = spawn(Mod, Func, Args)

那么,Pid2僅僅能被Pid1可見,Erlang系統的安全性就構建在限制進程擴展的基礎上。

2.進程間通信

    Erlang進程間的通信只能通過發送消息來實現,消息的發送使用!符號:

復制代碼 代碼如下:

Pid ! Message

    其中Pid是接受消息的進程標記符,Message就是消息。接受方和消息可以是任何的有效的Erlang結構,只要他們的結果返回的是進程標記符和消息。
    消息的接受是使用receive關鍵字,語法如下:
 
復制代碼 代碼如下:

receive
      Message1 [when Guard1] ->
          Actions1 ;
      Message2 [when Guard2] ->
          Actions2 ;

end

    每一個Erlang進程都有一個“郵箱”,所有發送到進程的消息都按照到達的順序存儲在“郵箱”里,上面所示的消息Message1,Message2,當它們與“郵箱”里的消息匹配,并且約束(Guard)通過,那么相應的ActionN將執行,并且receive返回的是ActionN的最后一條執行語句的結果。Erlang對“郵箱”里的消息匹配是有選擇性的,只有匹配的消息將被觸發相應的Action,而沒有匹配的消息將仍然保留在“郵箱”里。這一機制保證了沒有消息會阻塞其他消息的到達。
    消息到達的順序并不決定消息的優先級,進程將輪流檢查“郵箱”里的消息進行嘗試匹配。消息的優先級別下文再講。

    如何接受特定進程的消息呢?答案很簡單,將發送方(sender)也附送在消息當中,接收方通過模式匹配決定是否接受,比如:
 

復制代碼 代碼如下:

Pid ! {self(),abc}

給進程Pid發送消息{self(),abc},利用self過程得到發送方作為消息發送。然后接收方:
復制代碼 代碼如下:

receive
  {Pid1,Msg} ->

end


通過模式匹配決定只有Pid1進程發送的消息才接受。

3.一些例子
    僅說明下書中計數的進程例子,我添加了簡單注釋:

復制代碼 代碼如下:

-module(counter).
-compile(export_all).
% start(),返回一個新進程,進程執行函數loop
start()->spawn(counter, loop,[0]).
% 調用此操作遞增計數
increment(Counter)->
    Counter!increament.
% 返回當前計數值
value(Counter)->
    Counter!{self(),value},
    receive
        {Counter,Value}->
            %返回給調用方
            Value
        end.
  %停止計數     
 stop(Counter)->
     Counter!{self(),stop}.
 loop(Val)->
     receive
         %接受不同的消息,決定返回結果
         increament->
             loop(Val+1);
         {From,value}->
             From!{self(),Val},
             loop(Val);
         stop->
             true;
         %不是以上3種消息,就繼續等待
         Other->
             loop(Val)
      end.  


調用方式:

復制代碼 代碼如下:

1> Counter1=counter:start().
0.30.0>
2> counter:value(Counter1).
0
3> counter:increment(Counter1).
increament
4> counter:value(Counter1).
1

基于進程的消息傳遞機制可以很容易地實現有限狀態機(FSM),狀態使用函數表示,而事件就是消息。具體不再展開

4.超時設置

    Erlang中的receive語法可以添加一個額外選項:timeout,類似:

復制代碼 代碼如下:

receive
   Message1 [when Guard1] ->
     Actions1 ;
   Message2 [when Guard2] ->
     Actions2 ;
  
   after
      TimeOutExpr ->
         ActionsT
end

after之后的TimeOutExpr表達式返回一個整數time(毫秒級別),時間的精確程度依賴于Erlang在操作系統或者硬件的實現。如果在time毫秒內,沒有一個消息被選中,超時設置將生效,也就是ActionT將執行。time有兩個特殊值:

1)infinity(無窮大),infinity是一個atom,指定了超時設置將永遠不會被執行。
2) 0,超時如果設定為0意味著超時設置將立刻執行,但是系統將首先嘗試當前“郵箱”里的消息。

超時的常見幾個應用,比如掛起當前進程多少毫秒:

復制代碼 代碼如下:

sleep(Time) ->
  receive
    after Time ->
    true
end.

  比如清空進程的“郵箱”,丟棄“郵箱”里的所有消息:
 

復制代碼 代碼如下:
 
flush_buffer() ->
  receive
    AnyMessage ->
      flush_buffer()
  after 0 ->
    true
end.

    將當前進程永遠掛起:
復制代碼 代碼如下:

  suspend() ->
    receive
    after
        infinity ->
            true
    end.

    超時也可以應用于實現定時器,比如下面這個例子,創建一個進程,這個進程將在設定時間后向自己發送消息:
復制代碼 代碼如下:

-module(timer).
-export([timeout/2,cancel/1,timer/3]).
timeout(Time, Alarm) ->
   spawn(timer, timer, [self(),Time,Alarm]).
cancel(Timer) ->
   Timer ! {self(),cancel}.
timer(Pid, Time, Alarm) ->
   receive
    {Pid,cancel} ->
       true
   after Time ->
       Pid ! Alarm
end.

5、注冊進程
    為了給進程發送消息,我們需要知道進程的Pid,但是在某些情況下:在一個很大系統里面有很多的全局servers,或者為了安全考慮需要隱藏進程Pid。為了達到可以發送消息給一個不知道Pid的進程的目的,我們提供了注冊進程的辦法,給進程們注冊名字,這些名字必須是atom。
    基本的調用形式:

復制代碼 代碼如下:

register(Name, Pid)

將Name與進程Pid聯系起來
復制代碼 代碼如下:

unregister(Name)

取消Name與相應進程的對應關系。
復制代碼 代碼如下:

whereis(Name)

返回Name所關聯的進程的Pid,如果沒有進程與之關聯,就返回atom:undefined
復制代碼 代碼如下:

registered()

返回當前注冊的進程的名字列表

6.進程的優先級

設定進程的優先級可以使用BIFs:

復制代碼 代碼如下:

process_flag(priority, Pri)

Pri可以是normal、low,默認都是normal
優先級高的進程將相對低的執行多一點。

7.進程組(process group)
    所有的ERLANG進程都有一個Pid與一個他們共有的稱為Group Leader相關聯,當一個新的進程被創建的時候將被加入同一個進程組。最初的系統進程的Group Leader就是它自身,因此它也是所有被創建進程及子進程的Group Leader。這就意味著Erlang的進程被組織為一棵Tree,其中的根節點就是第一個被創建的進程。下面的BIFs被用于操縱進程組:

group_leader()
返回執行進程的Group Leader的Pid

group_leader(Leader, Pid)
設置進程Pid的Group Leader為進程的Leader

8.Erlang的進程模型很容易去構建Client-Server的模型,書中有一節專門討論了這一點,著重強調了接口的設計以及抽象層次的隔離問題,不翻譯了。

標簽:濟源 汕頭 濟寧 武威 臺州 廣東 安徽 泰安

巨人網絡通訊聲明:本文標題《Erlang并發編程介紹》,本文關鍵詞  Erlang,并發,編程,介紹,Erlang,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Erlang并發編程介紹》相關的同類信息!
  • 本頁收集關于Erlang并發編程介紹的相關信息資訊供網民參考!
  • 推薦文章
    成人av在线播放| 日韩在线观看网站| 麻豆系列 在线视频| 日韩在线观看网站| 亚洲天堂在线播放| 日日夜夜婷婷| a级毛片免费观看网站| 中文字幕一区二区三区精彩视频| | 黄色福利| 韩国三级香港三级日本三级| 一级毛片视频播放| 日本特黄特黄aaaaa大片| 九九干| 午夜激情视频在线播放| a级毛片免费观看网站| 成人免费一级纶理片| 国产一区二区精品久久91| 国产精品自拍一区| 亚洲 激情| 黄视频网站免费看| 国产a视频精品免费观看| 国产亚洲免费观看| 精品国产亚洲一区二区三区| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 欧美激情一区二区三区视频 | 一本高清在线| 国产麻豆精品hdvideoss| 国产91丝袜高跟系列| 日韩女人做爰大片| 国产精品自拍在线| 国产视频一区在线| 午夜在线亚洲男人午在线| 久久精品成人一区二区三区| 国产麻豆精品hdvideoss| 天天做日日爱| 日本特黄一级| 二级特黄绝大片免费视频大片| 欧美国产日韩在线| 久久久成人影院| 精品视频在线观看视频免费视频| 成人免费网站视频ww| 国产成a人片在线观看视频| 国产伦久视频免费观看视频| 深夜做爰性大片中文| 欧美爱色| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 可以在线看黄的网站| 国产国产人免费视频成69堂| 美女免费黄网站| 日韩综合| 精品视频在线观看视频免费视频| 中文字幕97| 九九久久99| 精品久久久久久免费影院| 国产网站免费观看| 麻豆网站在线看| 国产伦精品一区二区三区无广告 | 91麻豆精品国产自产在线| 91麻豆tv| 国产麻豆精品hdvideoss| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 四虎久久影院| 中文字幕97| 免费毛片播放| 亚洲 男人 天堂| 欧美激情一区二区三区视频| 深夜做爰性大片中文| 久久成人综合网| 亚洲精品影院一区二区| 精品国产香蕉在线播出| 国产高清视频免费观看| 四虎影视久久久| 青青青草影院| 亚洲第一页色| 国产麻豆精品hdvideoss| 一本高清在线| 99久久精品费精品国产一区二区| 国产成a人片在线观看视频| 久久精品成人一区二区三区| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 四虎久久影院| 亚洲第一色在线| 国产原创中文字幕| 九九免费精品视频| 国产视频在线免费观看| 一级女性全黄生活片免费| 精品久久久久久中文字幕一区| 国产视频久久久| 日本免费看视频| 国产伦精品一区二区三区无广告 | 麻豆网站在线看| 成人影院一区二区三区| 国产伦精品一区二区三区无广告 | 精品国产一区二区三区国产馆 | 日韩在线观看视频网站| 免费一级片在线观看| 国产高清视频免费观看| 四虎影视久久久| 你懂的国产精品| 尤物视频网站在线观看| 日日夜夜婷婷| 99久久精品费精品国产一区二区| 欧美大片毛片aaa免费看| 高清一级片| 国产91素人搭讪系列天堂| 91麻豆tv| 可以免费看污视频的网站| 久久国产一区二区| 国产成人精品综合| 尤物视频网站在线观看| 欧美激情一区二区三区视频| 99久久精品费精品国产一区二区| 欧美激情一区二区三区在线播放| 日本伦理网站| 日韩免费在线视频| 日韩在线观看免费| 欧美大片毛片aaa免费看| 欧美日本免费| 日韩中文字幕在线观看视频| 一级片片| 香蕉视频久久| 91麻豆高清国产在线播放| 久久精品人人做人人爽97| 四虎久久影院| 99久久网站| 日韩综合| 一级女性大黄生活片免费| 久草免费在线色站| 日韩女人做爰大片| 欧美日本免费| 尤物视频网站在线观看| 亚欧乱色一区二区三区| 九九九国产| 欧美激情一区二区三区视频| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 一级毛片看真人在线视频| 成人免费观看视频| 欧美激情一区二区三区在线播放| 一 级 黄 中国色 片| 日韩中文字幕在线观看视频| 韩国三级香港三级日本三级| 精品毛片视频| 国产91丝袜高跟系列| 欧美激情中文字幕一区二区| 国产一区二区精品| 国产综合91天堂亚洲国产| 91麻豆国产| 精品在线免费播放| 国产视频一区在线| 日韩一级黄色| 国产91精品一区二区| 欧美一级视频免费| 欧美激情一区二区三区在线播放 | 欧美激情一区二区三区在线播放| 国产亚洲免费观看| 国产伦精品一区二区三区无广告 | 久久国产一区二区| 精品国产亚洲一区二区三区| 人人干人人插| 欧美激情伊人| 国产成人欧美一区二区三区的| 日本免费乱理伦片在线观看2018| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 日韩专区亚洲综合久久| 国产一区二区精品久久91| 国产不卡在线观看| 成人免费观看视频| 黄视频网站免费观看| 欧美1区2区3区| 成人影院一区二区三区| 欧美日本国产| 黄色福利片| 日韩av片免费播放| 久久国产精品只做精品| 亚洲 国产精品 日韩| 99久久精品国产国产毛片| 日韩在线观看视频免费| 91麻豆tv| 尤物视频网站在线观看| 91麻豆精品国产自产在线| 久久99欧美| 在线观看成人网 | 精品国产一区二区三区国产馆 | 国产极品白嫩美女在线观看看| 99热视热频这里只有精品| 日本特黄一级| 精品在线免费播放| 精品国产亚洲人成在线| 香蕉视频亚洲一级| 国产伦久视频免费观看视频| 在线观看成人网| 九九干| 欧美国产日韩久久久| 欧美激情一区二区三区中文字幕| 二级片在线观看| 青青久热| 久久99中文字幕久久| 亚洲女人国产香蕉久久精品| 国产精品免费久久|