青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

教父的告白
一切都是紙老虎
posts - 82,  comments - 7,  trackbacks - 0
以下是在erlang項目開發中的一些記錄,即包含很多通俗易懂的原則,也包含一些似是而非的建議,比較混亂,還沒有積累到一個可以分門別類的地步,各位就將就看吧..
:)

* 確保沒有任何編譯警告

* Erlang中String采用list實現,32位系統中,其1個字符用8個字節的空間(4個保存value, 4個保存指針)。因此string速度較慢,空間占用較大

* 在Server中,總是盡力書寫尾遞歸(tail-recursive)的函數

* 使用'++'時,left list會被拷貝,然后添加到right list的頭部,因此最好把length較短的list放在左側

* 避免使用regexp,如果需要正則表達式,請使用re

* timer模塊的大部分函數實現,依賴于一個process,如果過多使用timer,會導致這個process負載過大,影響效率。
  推薦使用erlang:send_after/3及erlang:start_timer/3

* 避免使用list_to_atom/1,因為erlang中atom數量最大為1048576, 且不進行GC控制。因此如果持續性的調用list_to_atom/1
  可能很容易達到系統上限,從而導致emulator terminate。請使用list_to_existing_atom/1。

* list內部實現為一個列表,因此length(List), 需要遍歷整個list比較耗時

* 對于不同的數據類型,使用不同的size函數:tuple_size/1, byte_size/1, bit_size/1

* 使用binary match來進行binary的分割,而不使用split_binary/2

* 如果兩個list都擁有很多數據,那么請不要使用'--',而是將數據轉化到ordsets,然后調用ordsets:substract/2.

* 對于binary相關操作可以進行binary優化(bin_opt_info編譯選項)代碼框架:

*   f(<<Pattern1,...,Rest/bits>>,...) -> 
       ... % Rest is not used here 
       f(Rest,...); 
    f(<<Pattern2,...,Rest/bits>>,...) -> 
      ... % Rest is not used here 
      f(Rest,...); 
    ... 
    f(<<>>, ...) -> 
      ReturnValue.

* 調用lists:flatten/1可以將list扁平化,這個操作代價很大,比'++'還要昂貴。下面這些時候我們可以避免:
    將數據發送給port時
    調用list_bo_binary/1和iolist_to_binary前

* 小的函數可以讓您方便的找出錯誤的函數和代碼

* 不要在同一行出現相同的符號
20    some_fun() ->
21       L = [{key1, v1}, {key2, [some_record#v21, v22]}],
22      ...
編譯時,會提示line 21 '[' 語法錯誤, 因為21行有多個 '[' ,所以這個bug不能準確定位,你需要花時間去排查代碼。
好的做法是:
20 some_fun() ->
21      L = [{key1, v1},
22            {key2, [some_record#v21, v22]}
23            ],
      ...
這樣,編譯其會提示你 line 22 '[' 語法錯誤,你很開就知道是那個地方錯了。

* 使用 CTRL + \ 或 init:stop(), 可以退出Erlang, 使用CTRL + G 及 CTRL + C 彈出菜單選項,可以選擇是否退出Erlang
其中CTRL + G可以用來連接其他的shell, CTRL + C可以查看其他一些系統信息
Ctrl + C abort 是野蠻的退出方式

* use "open_port({fd,0,2}, [out])" make erlang program write standard error to unix system

* If you don't run experiments before you start designing a new system, your entire system will be an experiment!

* standard data structure desc:

Module Description
sets sets, i.e. a collection of unique elements.
gb_sets sets, but based on a general balanced data structure
gb_tree a general balanced tree
dict maps, also called associative arrays
ets hash tables and ordered sets (trees)
dets on-disk hash tables

Suggestion:
elments count: 0 - 100 | 100 - 10000  |  10000 -
our select   :  list   |      ets     |  gb_tree

* 通過code:clash/0 檢測代碼中是否有module沖突現象(sticky)

* epmd -d -d 啟動 epmd 可以查看erlang node之間的通訊

* 將正常的邏輯代碼和錯誤處理代碼分離,發生錯誤時,盡管錯誤。由另一個錯誤處理模塊進行處理

* 類似于操作系統,我們的程序也可以分為kernel 和 user 兩層, 對于kernel絕對不能出現錯誤, 對于user可以出現錯誤,進行恢復

* process頂層loop涉及的代碼及函數,最好在一個module中實現

* process 的register name和module名稱一致, 便于尋找代碼

* 每個process具有一個單一的角色,比如:supervisor 用來進行錯誤恢復, work 工作者,可以出現錯誤, trusted worker 不會出現錯誤

* 通過函數調用可以實現的功能,就不要使用sever實現(如gen_server, 及類似的loop 實現)

* 給消息加一個tag,在發生錯誤的時候,可以定位到消息,同時也有利于程序的穩健

* 在消息循環中,對于unknown的消息,請調用lib:flush_receive/0 將其清除,減輕process msg queue的長度

* server中總是書寫尾遞歸的循環

* 盡量使用record, 而不是原始的tuple來表現數據結構, 在使用record時,使用select match:
#person{name = Name, age = Age} = Person

* 對于返回值,最好也添加一個tag,用來說明返回值類型,或者執行成功與否

* 盡可能少的使用catch和try,在erlang程序中,不推薦主動捕獲異常。只有當我們的邏輯特別復雜,我們可以使用throw來返回數據,使用catch來獲取返回值。

* 當然程序與外界交互,外界數據不可靠時,需要使用catch和try

* 慎重使用process dictory, 當你使用get/1, put/1時,你的應用會具有很大的slide effect。可以通過加入一個新的參數來保存原本需要存儲到process dictory中數據

* 如果不想使自己糊涂,請不要使用import

* 使用export時,將功能類似的接口組合在一起,并添加合理的注視,這樣你的接口更清晰,別人使用起來更方便

* 不要書寫嵌套太深的代碼

* 不要書寫太長的module

* 不要書寫太長的函數

* 每行代碼不能太長

* 避免使用 "_" 匿名變量,請為每個變量選擇有意義的名稱,如夠某個變量暫時不使用,請以下劃線 "_" 開始

* {error, enfile} enfile error in socket 是以為內linux系統中 ulimit 限制, 在root下修改:ulimit -n 25000

* {error, enotconn} 表示socket已經關閉

* 在erlang開發時,慎重使用macro,因為erlang的single assign的緣故,同時調用某個marco,而macro又定義了某個變量,可能導致badmatch錯誤。
比如:
-define(ADDLINEINFO1(F),
        (
        begin
        Str1 = lists:concat(["[Mod:", ?MODULE, " Line:", ?LINE, "]"]),
        Str1 ++ F
        end
        )).
-define(WARN(Log, F, D), log4erl:warn(Log, ?ADDLINEINFO(F), D)).
如果連續使用 WARN, 會出現此錯誤

* erlang中可以定義很多環境變量:
ERL_MAX_ETS_TABLES 設置最大的ets數目 默認1400
ERL_MAX_PORTS erlang最大的port數目 默認1024

* .app文件中的start_phases, 選項既可以用來作為include applications之間的同步啟動,也可以用來對單個application進行分布啟動。
順序如下
包含included app:

application:start(prim_app)
=> prim_app_cb:start(normal, [])
=> prim_app_cb:start_phase(init, normal, [])
=> prim_app_cb:start_phase(go, normal, [])
=> incl_app_cb:start_phase(go, normal, [])
ok

無included app:
application:start(prim_app)
=> prim_app_cb:start(normal, [])
=> prim_app_cb:start_phase(init, normal, [])
=> prim_app_cb:start_phase(go, normal, [])
ok

* 任何時候,都要重視函數的返回值,通過match確保您的預期,如果發生錯誤,那么就大膽的表達出來。
posted on 2009-09-24 01:00 暗夜教父 閱讀(627) 評論(0)  編輯 收藏 引用 所屬分類: erlang

<2009年12月>
293012345
6789101112
13141516171819
20212223242526
272829303112
3456789

常用鏈接

留言簿(2)

隨筆分類

隨筆檔案

文章分類

文章檔案

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲人线精品午夜| 亚洲靠逼com| 久久久伊人欧美| 久久久久88色偷偷免费| 欧美三级电影一区| 亚洲国产欧美在线| 精品不卡视频| 蜜桃av一区| 亚洲黄一区二区三区| 亚洲国产电影| 久久精品三级| 欧美激情精品久久久久久免费印度| 麻豆国产精品va在线观看不卡| 国产亚洲va综合人人澡精品| 性做久久久久久免费观看欧美| 午夜精品国产精品大乳美女| 国产精品免费观看视频| 久久精品伊人| 99亚洲一区二区| 久久精品免费看| 99精品欧美一区二区蜜桃免费| 国产精品亚洲精品| 久久婷婷国产综合尤物精品| 亚洲精品在线观看免费| 久久久久网站| 亚洲性感美女99在线| 国产亚洲福利一区| 欧美福利在线观看| 欧美一区二区三区免费视频| 免费91麻豆精品国产自产在线观看| 久久久夜精品| 亚洲欧洲在线视频| 欧美在线资源| 亚洲日本一区二区三区| 亚洲午夜免费福利视频| 久久久久久久一区二区| 亚洲理伦电影| 国产主播一区二区三区四区| 欧美不卡在线视频| 午夜精品久久| 亚洲人成网站精品片在线观看| 先锋亚洲精品| 野花国产精品入口| 尤物精品国产第一福利三区| 欧美欧美在线| 老司机午夜精品视频| 亚洲欧美日韩精品久久久久 | 欧美激情综合色| 中文精品视频| 欧美黑人在线播放| 久久久免费精品视频| 在线性视频日韩欧美| 亚洲免费激情| 亚洲精品国精品久久99热| 麻豆精品网站| 老司机午夜精品| 欧美 日韩 国产在线| 久久综合久久综合这里只有精品| 午夜久久美女| 久久国产精品亚洲77777| 亚洲国产女人aaa毛片在线| 欧美激情亚洲| 亚洲免费久久| 亚洲午夜一区二区| 亚洲欧美三级在线| 香港久久久电影| 久久精品视频在线观看| 久久中文精品| 欧美午夜精品理论片a级按摩 | 国产精品入口福利| 国产精品九色蝌蚪自拍| 欧美精品 国产精品| 欧美日韩综合视频| 国产午夜精品久久久久久久| 亚洲东热激情| 亚洲欧美日韩精品久久久| 久久精品国产一区二区三| 免费亚洲一区| 一区二区三区www| 久久成人综合视频| 欧美激情一区二区三区高清视频| 国产精品久久久久久久第一福利 | 国产一区二区三区无遮挡| 国产亚洲欧美日韩在线一区| 久久人人爽爽爽人久久久| 国产精品乱码一区二区三区| 亚洲福利视频免费观看| 亚洲电影观看| 欧美一区二区三区四区夜夜大片| 男男成人高潮片免费网站| 国产精品久久久久久模特| 亚洲国产精品va在线观看黑人| 亚洲开发第一视频在线播放| 久久九九99| 一区二区三区视频在线 | 欧美视频在线观看免费| 红杏aⅴ成人免费视频| 亚洲欧美国产va在线影院| 亚洲第一精品久久忘忧草社区| 亚欧美中日韩视频| 国产精品久久影院| 亚洲欧美日韩中文视频| av成人黄色| 老司机午夜精品| 亚洲国产专区校园欧美| 欧美+日本+国产+在线a∨观看| 久久国产精品久久久久久电车| 国产免费成人av| 久久国产加勒比精品无码| 亚洲欧美在线免费| 国产女主播一区二区三区| 欧美一级黄色录像| 亚洲一区免费网站| 国产乱码精品| 欧美wwwwww| 欧美日韩国产在线| 香港成人在线视频| 久久精品国产综合| 亚洲精品国精品久久99热一| 日韩一级裸体免费视频| 国产精品自拍视频| 欧美va天堂| 国产精品久久国产三级国电话系列| 欧美一区二区三区喷汁尤物| 久久免费视频在线观看| 日韩一区二区精品葵司在线| 香蕉亚洲视频| 亚洲手机视频| 久久一综合视频| 国产精品久久久久高潮| 亚洲欧美日韩另类| 欧美1区2区3区| 久久精品视频一| 欧美精品一区二区三区高清aⅴ| 亚洲欧美精品伊人久久| 欧美在线视频免费| 亚洲一区三区视频在线观看 | 翔田千里一区二区| 欧美久久九九| 欧美大片91| 亚洲一区二区三区乱码aⅴ| 亚洲激情在线视频| 久久久国产精彩视频美女艺术照福利| 亚洲精品乱码久久久久久按摩观| 欧美一区二区在线免费播放| 亚洲一区在线观看视频| 欧美日韩一区二区三| 91久久精品国产91性色tv| 在线电影院国产精品| 久久久91精品国产| 久久综合激情| 在线播放国产一区中文字幕剧情欧美| 日韩小视频在线观看| 一区二区久久久久| 欧美片第一页| 在线一区欧美| 亚洲乱码精品一二三四区日韩在线 | 亚洲精品国产精品国自产观看| 一区二区三区四区五区视频| 亚洲你懂的在线视频| 麻豆国产精品va在线观看不卡| 一区二区日韩精品| 国产一区二区久久精品| 欧美日韩国产色综合一二三四| 欧美一级免费视频| 91久久夜色精品国产九色| 久久av一区二区三区| 国产精品99久久久久久人| 狠狠入ady亚洲精品经典电影| 欧美成人在线影院| 久久精品国产清高在天天线 | 久久精品一区二区三区不卡| 亚洲欧洲日韩女同| 女同性一区二区三区人了人一| 亚洲影视九九影院在线观看| 亚洲国产精品久久精品怡红院| 国产欧亚日韩视频| 欧美午夜一区二区| 欧美91视频| 欧美日韩成人在线视频| 久久久久国产一区二区三区| 亚洲神马久久| 亚洲一区二区视频在线观看| 日韩亚洲欧美中文三级| 欧美国产国产综合| 欧美国产三级| 亚洲理论电影网| 亚洲先锋成人| 久久久精彩视频| 欧美成人蜜桃| 国产精品国内视频| 久久丁香综合五月国产三级网站| 午夜精品一区二区三区四区| 一本色道久久综合亚洲精品不 | 亚洲一区www| 欧美一级专区免费大片| 亚洲欧美另类综合偷拍| 久久久久国产成人精品亚洲午夜| 午夜精品视频一区| 欧美激情影院|