• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            Fork me on GitHub
            隨筆 - 215  文章 - 13  trackbacks - 0
            <2017年1月>
            25262728293031
            1234567
            891011121314
            15161718192021
            22232425262728
            2930311234


            專注即時通訊及網游服務端編程
            ------------------------------------
            Openresty 官方模塊
            Openresty 標準模塊(Opm)
            Openresty 三方模塊
            ------------------------------------
            本博收藏大部分文章為轉載,并在文章開頭給出了原文出處,如有再轉,敬請保留相關信息,這是大家對原創作者勞動成果的自覺尊重!!如為您帶來不便,請于本博下留言,謝謝配合。

            常用鏈接

            留言簿(1)

            隨筆分類

            隨筆檔案

            相冊

            Awesome

            Blog

            Book

            GitHub

            Link

            搜索

            •  

            積分與排名

            • 積分 - 219191
            • 排名 - 117

            最新評論

            閱讀排行榜

            節選自:https://www.sohu.com/a/244980510_473282


            Erlang 的世界和我們的真實世界很像。每個 Erlang 進程維護著自己獨有的內存,別的進程無法訪問其內部狀態,除非它們互發消息進行交流。所有的消息傳遞都是異步的,就像我們的現實世界。

            1>spawn(foo,hello,[]).

            <0.70.0>

            這樣就會創建一個新的進程,調用foo:hello()。進程一旦執行完這個函數就會死掉,將所有分配到的內存還給BEAM。

            如果你想創建兩個進程同時做事,只需spawn兩次:

            1>spawn(foo,hello,[]).

            <0.70.0>

            2>spawn(foo,hello,[]).

            <0.71.0>

            這將創建兩個進程并發調用foo:hello()。這就是 Erlang 的并發模型——也叫參與者模式 (Actor model)。

            如果你想整100個進程同時做事,調用spawn 100次即可。簡單粗暴。

            現在我們知道如何創建進程,接下來是給它發消息。

            1>Pid=spawn(foo,loop,[]).

            <0.80.0>

            2>Pid!hello.

            hello

            這里我們啟動一個進程調用 foo:loop()。我們假設這個loop函數會遞歸調用自己,這樣我們的進程不會一下就死掉。spawn 會返回一個進程ID <0.80.0>,我們將其綁定到 Pid 變量中,并向其發個消息 hello。 Erlang 里用驚嘆號 ! 發消息。好了,以上就是異步消息發送。這也是 Erlang 中兩個進程之間交流的唯一手段。

            當消息被發給某進程后,該進程如何收消息呢?

            1>Pid=spawn(fun()->

            1>receive

            1>hello->io:format("Got hello message~n")

            1>end

            1>end).<0.86.0>

            2>Pid!hello.

            Gothellomessage

            hello

            用 receive 來收消息。你可以在這里用模式匹配來匹配你想要接收的信息,忽略其他的消息。在這個例子中,我們只接收消息 hello。

            我們平時會記不住朋友的電話,所以我們用通訊錄給電話號碼加個名字。在 Erlang 中也沒有必要記住每個進程的 Pid,給其注冊個名字即可以后用名字來訪問之。

            1>Pid=spawn(fun()->receivehello->io:format("Got hello message~n")endend).

            <0.93.0>

            2>register(foo,Pid).

            true

            3>foo!hello.

            Gothellomessage

            hello

            只需調用 register(Name,Pid) 即可給任何進程注冊名字。之后我們可以用該名字給進程發消息。

            當我們給某進程注冊了名字后,我們也能通過查找通訊錄來找到其Pid。

            1>register(foo,spawn(fun()->receivehello->helloendend)).

            true

            2>whereis(foo).

            <0.102.0>

            最后,一個進程可以通過調用 self() 來找到自己的Pid。

            1>self().

            <0.90.0>

            以上6個函數就這么簡單,再多也沒有了。spawn, send, receive, register, whereis 和 self。就這6個函數,組成 Erlang 的世界觀。

            posted on 2018-12-13 10:22 思月行云 閱讀(676) 評論(0)  編輯 收藏 引用 所屬分類: Erlang
            伊人久久综合无码成人网| 久久九九久精品国产| 久久精品成人欧美大片| 久久无码AV中文出轨人妻| 国产精品一区二区久久国产| 久久久久国产视频电影| 性欧美丰满熟妇XXXX性久久久 | 久久精品国产亚洲Aⅴ香蕉| 中文国产成人精品久久亚洲精品AⅤ无码精品 | 久久久噜噜噜久久中文字幕色伊伊| 亚洲午夜久久久久久噜噜噜| 99热都是精品久久久久久| 影音先锋女人AV鲁色资源网久久| 国内精品久久久久久久久电影网| AV无码久久久久不卡蜜桃| 久久精品无码av| 国产日韩久久久精品影院首页 | 99久久婷婷国产一区二区| 久久午夜福利无码1000合集| 伊人色综合久久天天| av国内精品久久久久影院| 国内精品综合久久久40p| 久久丝袜精品中文字幕| 伊人久久大香线蕉精品| av国内精品久久久久影院| 日韩精品久久久久久免费| 97久久国产露脸精品国产| 久久只有这里有精品4| 久久久久一级精品亚洲国产成人综合AV区| 久久青青草原亚洲av无码app| 模特私拍国产精品久久| 一本久道久久综合狠狠躁AV| 国产亚州精品女人久久久久久| 99久久久精品免费观看国产| 人妻无码久久一区二区三区免费| 久久www免费人成看片| 久久中文字幕人妻丝袜| 亚洲熟妇无码另类久久久| 国内精品久久久久久久久电影网| 亚洲中文久久精品无码| 久久国产亚洲精品无码|