婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Erlang初學:Erlang的一些特點和個人理解總結

Erlang初學:Erlang的一些特點和個人理解總結

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

我對 Erlang 編程理念的理解:以分布式架構師的角度寫代碼。

函數式編程

Erlang 里面的函數是數學里面的函數:必須有返回值。 只要是函數必然有返回值,函數是一個過程,以英文的句號為函數結束符。 函數結束之前的表達式就是該函數的返回值。 所以這也是在 Erlang 里面的函數不會看到任何 return 語句的原因。 C++ 等其他語言的函數和函數之前可以通過共享變量來實現消息傳遞。 Erlang 里面的函數不可以,消息的傳遞通過函數的傳入和傳出。 也只是為什么 Erlang 號稱天生之處并行處理的原因, 因為他們不共享變量,也就不需要加鎖。

很多人聽到函數式編程都會覺得高大上或者晦澀難懂。 因為函數是編程沒有 for 循環語句, 但是在我看來,關鍵在于會使用【列表推倒】和【尾遞歸】來進行循環遍歷。 說到函數式編程就會拿快速排序說事,下面這個示例是 Erlang 版本的快速排序:

復制代碼 代碼如下:

-module(sort).

-export([qsort/1]).

qsort([]) -> [];
qsort([Pivot | T]) ->
    qsort([X || X - T, X Pivot]
         ++ [Pivot] ++
         qsort([X || X - T, X >= Pivot]).


非常簡潔,[Pivot | T] 就是拿列表的第一個元素當快排中的 Pivot 。
復制代碼 代碼如下:

[X || X - T, X Pivot]

上式就是【列表推導】, 含義就是找出列表 T 中所有元素小于 Pivot 中的元素組成一個新的列表。 不過,這個例子顯然性能不高,只是一個示例。

很多人一直在鼓吹函數式語言馬上就要迎來朝陽, 但是在我看來,函數式編程永遠只能是小眾語言, 這就像當年的 lisp machine ,被鼓吹的天花亂墜還是夭折了。 現在主流的計算機架構都是馮諾依曼體系的,并不是最適合函數式語言的生存土壤。

一切都是常量

沒有變量,也就沒有通過變量共享狀態導致的資源競爭,也就不需要加鎖。 任何狀態的變化都是通過函數的輸入輸出來進行改變, 輕量級進程的狀態變化也是靠消息傳遞(函數的輸入輸出)來實現。 這也是為什么有人說函數式編程適合高并發的原因,因為他們沒有變量, 一切都是常量。

輕量進程

Erlang 里面有 spawn 函數,可以快速的創建一個 process , 這里的 process 不是操作系統的進程,而是 Erlang 自己的輕量進程。 Erlang 輕量到超乎你想象, 構建 kv 數據庫的時候,甚至可以對不同的 key 分配給不同的進程。 而且進程的表示單位是 Pid ,只要知道進程的 Pid, 哪怕該進程是在別的機器上面,都可以很輕易的發送給它。 原因是 Erlang 的【天生自帶RPC通信】和【自帶端口映射】

天生自帶RPC通信

復制代碼 代碼如下:

ToPid ! Data

ToPid 是接受方進程的id , Data 可以是 Erlang 的任何類型,比如
復制代碼 代碼如下:

Pid ! {name, "jb51.net"}.

也就是可以直接把任何數據結構當成消息發送,天生自帶 RPC 通信。 (雖然本來 RPC 的含義是“遠程過程調用”,不過其實反正就是幫你序列化了數據結構,Erlang 的 ! 操作符也是如此。)

進程端口映射

節點之間發消息在代碼里面的表示也還是

復制代碼 代碼如下:

ToPid ! Data

也就是在寫代碼的時候,根本不用考慮該進程是在哪臺機器上面, 無論是本 Erlang 進程(這里的進程是操作系統級別的進程,不是 Erlang 的輕量進程) 內, 還是其他機器的進程,都不用管。 這是因為有 epmd 的存在。

Epmd是Erlang Port Mapper Daemon的縮寫,在Erlang集群中相當于dns的作用,供給節點名稱到端口的查詢辦事,epmd綁定在總所周知的4369端口上。

有了 epmd ,寫分布式程序就好像寫單機程序一樣簡單。

嚴密的模塊化管理

Erlang 的模塊類似 C++ 中的 namespace(命名空間),但是比命名空間更利于高效的軟件工程管理。

在 Erlang 項目源碼中處處可見如下代碼。

復制代碼 代碼如下:

-module(my_app).
-export([start/2, stop/1]).

-module 指明模塊名,-export 指明導出的函數。 未被導出的函數都無法被外界調用。 從軟件工程上看的話,這樣使得模塊功能和使用方法更加清晰。 使用者只需要關心如何 -export 里面的函數即可。 相比較之下 C++ 對這方面特別不規范,而 Java 通過對類聲明為 public class 指明可以被外界使用, Node.js 也是使用 export 來顯示聲明可以被外界使用的函數。

行為模式

復制代碼 代碼如下:

-module(ecomet_app).

-behaviour(application).

%% comment: Application callbacks
-export([start/2, stop/1]).
-behavior(application).

Erlang/otp 里面的【行為模式】概念等價于 OOP 里面的接口概念。 上面代碼示例的意思就是該模塊(ecomet_app)遵守的行為模式是(application)。 剛行為模式需要實現的兩個接口函數就是 -export([start/2, stop/1]). 。

另一個示例如下是遵守監督者(supervisor)行為模式, 實現的一個接口函數是 -export([init/1]). 。

復制代碼 代碼如下:

-module(ecomet_sup).

-behaviour(supervisor).

%% Supervisor callbacks
-export([init/1]).

監督者機制

Erlang/otp 的天生分布式特性在監督機制里面體現的很好, 每一個 otp 應用啟動的時候,都是啟動監督者(supervisor)和工作者(worker)。 他們的關系是樹形結構,每個工作者的上級都會有監督者, 每個監督者的上級也可能有監督者。 當工作者異常退出的時候,監督者會根據相應的參數決定是否對工作者進行重啟。 如果重啟失敗的話監督者也會退出,而更加上層的監督者收到信號后會對他們進行重啟等處理。 這個監督者機制非常好理解,其實就是 OOP 編程里面的 try ... catch 異常處理機制。 當出現異常的時候一層一層的往上拋出,直到有人重啟。

otp平臺

Erlang 最強大的地方也是最讓我感覺難學的地方,就是它的 otp 平臺。 各種行為模式, 讓我感覺就像多年以前學習 MFC 的時候, 感覺很強大,但是卻總是感覺自己被按死在一條特定的軌道上面奔跑, 有種不自由的疲憊感。

代碼熱切換

熱切換也叫熱升級,大部分情況下,如果需要對 C++/Java 程序進程版本升級, 則需要重啟進程。 Erlang 支持熱切換的意思就是可以在運行的時候進行代碼升級。 升級過程不影響進程的運行, 而且在過渡階段新舊版本還可以共存。 是不是碉堡了。這個功能對于那些需要 7x24 高可用的服務來說簡直就是爽爆了。

Erlang 進程本身可以通過一個類似“后門”的控制臺 erl 來實時的查看狀態, 甚至直接使用控制臺來修改配置等,非常方便,這對于大部分其他語言來說, 簡直就是黑魔法般神奇的存在。

典型缺點

1.文檔太少,出現問題搜索出來的答案也少。
2.Erlang 人才稀缺,招聘不易。
3.動態語言最典型的就是調試不易。
4.上手門檻較高。

最后,我只是 Erlang 的入門初學者, 因為工作中需要使用 ejabberd (Erlang 的開源項目), 從而學習了 Erlang , 欠缺實戰經驗,所以這篇文章標題起為 【Erlang初體驗】。

您可能感興趣的文章:
  • Go/Python/Erlang編程語言對比分析及示例代碼
  • python讀取excel表格生成erlang數據
  • Erlang實現的一個Web服務器代碼實例
  • Erlang中的Record詳解
  • CentOS 6.5源碼安裝Erlang教程
  • ERLANG和PYTHON互通實現過程詳解

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

巨人網絡通訊聲明:本文標題《Erlang初學:Erlang的一些特點和個人理解總結》,本文關鍵詞  Erlang,初學,的,一些,特點,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Erlang初學:Erlang的一些特點和個人理解總結》相關的同類信息!
  • 本頁收集關于Erlang初學:Erlang的一些特點和個人理解總結的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    亚洲高清不卡在线| 欧美在线看片a免费观看| 婷婷中文字幕综合| 国产精品免费视频观看| 国产精品69久久久久水密桃| 欧美日韩精品久久久| 国产精品国产三级国产aⅴ入口| 亚欧色一区w666天堂| 99r国产精品| 国产午夜精品福利| 日韩国产在线一| 在线观看不卡视频| 亚洲日本韩国一区| 不卡的电视剧免费网站有什么| 欧美videossexotv100| 午夜久久久久久| 欧美日韩一区二区不卡| 亚洲蜜臀av乱码久久精品| 成人一区二区视频| 欧美激情一区不卡| 成人一级黄色片| 国产欧美精品日韩区二区麻豆天美| 精品一区二区三区在线播放| 欧美另类变人与禽xxxxx| 亚洲精品五月天| 91麻豆国产香蕉久久精品| 国产欧美视频一区二区三区| 精品一区二区三区在线播放视频 | 国产精品久久久久7777按摩| 国产精品自拍网站| 国产日本欧洲亚洲| 99视频超级精品| 国产精品久久福利| 欧美性感一区二区三区| 亚洲国产cao| 7777精品久久久大香线蕉| 亚洲h动漫在线| 色琪琪一区二区三区亚洲区| 亚洲国产成人高清精品| 色8久久人人97超碰香蕉987| 亚洲国产成人tv| 久久久影院官网| 日本在线观看不卡视频| 久久九九影视网| 91亚洲精华国产精华精华液| 亚洲一区二区黄色| 精品欧美一区二区久久| 成人app下载| 亚洲第一狼人社区| 精品免费国产一区二区三区四区| 日韩电影一区二区三区四区| 国产亚洲欧洲997久久综合| 成人18视频在线播放| 亚洲一区二区不卡免费| 日韩一区二区电影网| 久久国产精品免费| 日韩精品资源二区在线| 美女在线观看视频一区二区| 国产成人精品综合在线观看| 日本亚洲一区二区| 欧美日韩一区二区三区在线| 国产一区二三区| 亚洲精品写真福利| 欧美激情一区二区三区蜜桃视频| 色婷婷av一区二区三区软件| 国产在线视频一区二区| 麻豆久久久久久| 亚洲精品国产精品乱码不99| 久久精品男人的天堂| 制服丝袜一区二区三区| 91免费国产视频网站| 精品一区二区三区在线视频| 亚洲成人一二三| 亚洲另类在线一区| 国产区在线观看成人精品 | 午夜精品免费在线观看| 久久精品欧美一区二区三区不卡| 337p亚洲精品色噜噜| 91黄色小视频| 国产精品99精品久久免费| 1024成人网| 国产精品三级av在线播放| 日韩一区二区在线观看| 欧美日韩精品综合在线| 成人av电影在线| 日韩国产欧美三级| 精品国产91乱码一区二区三区 | 69堂成人精品免费视频| 99久久伊人久久99| 亚洲伦理在线精品| 精一区二区三区| 国产精品无码永久免费888| 国产精品视频一二| 日本不卡在线视频| 亚洲一区二区三区小说| 一区二区三区在线视频免费 | 国产欧美日韩视频一区二区| 日韩欧美中文字幕制服| 日韩一区二区视频| 久久婷婷国产综合精品青草| 欧美三片在线视频观看| 欧美日韩精品是欧美日韩精品| 色天使久久综合网天天| 蜜臀av一区二区在线观看 | 午夜精品福利视频网站| 欧美国产一区视频在线观看| 久久久久久久免费视频了| 亚洲精品一区在线观看| 久久精品亚洲麻豆av一区二区| 日本一区二区三区高清不卡| 国产精品久线观看视频| 亚洲裸体xxx| 午夜精品久久久久久久99樱桃| 麻豆一区二区三| 成人18精品视频| 欧美日韩激情一区| 亚洲精品一区二区三区蜜桃下载| 日本一区二区视频在线观看| 亚洲三级在线观看| 日韩激情中文字幕| 中文字幕欧美区| 国产午夜精品久久久久久免费视| 久久久影院官网| 亚洲免费观看在线观看| 日韩高清电影一区| 天天综合网天天综合色| 蜜桃视频一区二区三区| 午夜婷婷国产麻豆精品| 国产一区欧美一区| 欧美做爰猛烈大尺度电影无法无天| 欧美一级片免费看| 国产精品女同一区二区三区| 婷婷久久综合九色综合伊人色| 国产精品123区| 欧美疯狂性受xxxxx喷水图片| 久久久综合精品| 午夜国产不卡在线观看视频| 国产不卡视频在线播放| aaa亚洲精品| 欧美色窝79yyyycom| 亚洲成人免费av| 欧美男男青年gay1069videost | 国产久卡久卡久卡久卡视频精品| 美女网站一区二区| 欧美系列日韩一区| 国产喂奶挤奶一区二区三区| 日韩一区精品视频| 色网站国产精品| 国产精品水嫩水嫩| 久久成人麻豆午夜电影| 欧美日韩一级片在线观看| 精品欧美一区二区三区精品久久| 一区二区三区高清| av成人免费在线观看| 久久综合九色综合欧美就去吻| 日韩精品一卡二卡三卡四卡无卡| 色诱亚洲精品久久久久久| 日韩精品资源二区在线| 中文字幕一区二区三区色视频| 日韩影视精彩在线| 欧美少妇bbb| 中文字幕精品三区| 国产成人免费视频网站 | 成人在线视频首页| 国产精品网曝门| www.激情成人| 亚洲三级免费观看| 91久久国产综合久久| 亚洲综合免费观看高清完整版| 在线免费观看日本一区| 亚洲综合清纯丝袜自拍| 欧美在线播放高清精品| 亚洲午夜羞羞片| 欧美日韩不卡在线| 青青草成人在线观看| 日韩欧美三级在线| 国内精品视频666| 国产午夜久久久久| 成人黄色电影在线| 一区二区三区久久| 欧美精品v国产精品v日韩精品| 亚洲最大色网站| 欧洲一区二区三区在线| 亚洲精品成a人| 在线观看亚洲一区| 色综合av在线| 国产成人在线网站| 一级女性全黄久久生活片免费| 欧美一级生活片| 国产精一区二区三区| 午夜精品福利一区二区三区av| 中文字幕精品一区二区三区精品| 这里只有精品视频在线观看| kk眼镜猥琐国模调教系列一区二区| 青娱乐精品在线视频| 亚洲一区影音先锋| 成人欧美一区二区三区黑人麻豆 | 亚洲三级电影网站| 国产精品狼人久久影院观看方式| 精品日本一线二线三线不卡|