系統技術非業餘研究 » iolist跟list有什麼區別?
看到erlang-china.org上有個帖子在問這個問題
一直不太明白iolist,跟list到底有什麼區別?請各位大俠指教。。
我翻看了半天erlang的文件也沒寫的太明白,所以就看看原始碼:
erts/emulator/beam/utils.c
3015int io_list_len(Eterm obj) 3016{ 3017 Eterm* objp; 3018 Sint len = 0; 3019 DECLARE_ESTACK(s); 3020 goto L_again; 3021 3022 while (!ESTACK_ISEMPTY(s)) { 3023 obj = ESTACK_POP(s); 3024 L_again: 3025 if (is_list(obj)) { 3026 L_iter_list: 3027 objp = list_val(obj); 3028 /* Head */ 3029 obj = CAR(objp); 3030 if (is_byte(obj)) { 3031 len++; 3032 } else if (is_binary(obj) && binary_bitsize(obj) == 0) { 3033 len += binary_size(obj); 3034 } else if (is_list(obj)) { 3035 ESTACK_PUSH(s, CDR(objp)); 3036 goto L_iter_list; /* on head */ 3037 } else if (is_not_nil(obj)) { 3038 goto L_type_error; 3039 } 3040 /* Tail */ 3041 obj = CDR(objp); 3042 if (is_list(obj)) 3043 goto L_iter_list; /* on tail */ 3044 else if (is_binary(obj) && binary_bitsize(obj) == 0) { 3045 len += binary_size(obj); 3046 } else if (is_not_nil(obj)) { 3047 goto L_type_error; 3048 } 3049 } else if (is_binary(obj) && binary_bitsize(obj) == 0) { /* Tail was binary */ 3050 len += binary_size(obj); 3051 } else if (is_not_nil(obj)) { 3052 goto L_type_error; 3053 } 3054 } 3055 3056 DESTROY_ESTACK(s); 3057 return len; 3058 3059 L_type_error: 3060 DESTROY_ESTACK(s); 3061 return -1; 3062}
從原始碼可以看出來iolist是這樣的定義的:
1. []
2. binary
3. 列表, 每個元素是int(0-255)或者binary或者iolist.
其中binary是指 bitsize % 8 == 0 .
int 是0-255
[email protected]:/usr/src/otp# erl Erlang R13B04 (erts-5.7.5) [smp:2:2] [rq:2] [async-threads:0] [hipe] [kernel-poll:false] Eshell V5.7.5 (abort with ^G) 2> iolist_size(<<>>). 0 3> iolist_size(<<1:1>>). ** exception error: bad argument in function iolist_size/1 called as iolist_size(<<1:1>>) 4> iolist_size(<<1:8>>). 1 5> iolist_size([]). 0 6> iolist_size(<<1,2>>). 2 7> iolist_size([1,2]). 2 8> iolist_size([1,2, <<1,2>>]). 4 9> iolist_size([1,2, <<1,2>>, [2]]). 5 10> iolist_size([1,2, <<1,2>>, [2]]). 5 11> iolist_size([<<1:1>>]). ** exception error: bad argument in function iolist_size/1 called as iolist_size([<<1:1>>]) 12> iolist_size([257]). ** exception error: bad argument in function iolist_size/1 called as iolist_size([257])
Iolist的作用是用於往port送資料的時候.由於底層的系統呼叫如writev支援向量寫, 就避免了無謂的iolist_to_binary這樣的扁平話操作, 避免了記憶體拷貝,極大的提高了效率.
建議多用.
Post Footer automatically generated by wp-posturl plugin for wordpress.
相關推薦
系統技術非業餘研究 » iolist跟list有什麼區別?
看到erlang-china.org上有個帖子在問這個問題 一直不太明白iolist,跟list到底有什麼區別?請各位大俠指教。。 我翻看了半天erlang的文件也沒寫的太明白,所以就看看原始碼: erts/emulator/beam/utils.c 3015int io_list_len(Ete
系統技術非業餘研究 » List comprehensions 另類用法
List Comprehensions List comprehensions are a feature of many modern functional programming languages. Subject to certain rules, they provide a succi
系統技術非業餘研究
ItPub寫的文章“2017 年度 DB-Engines 資料庫冠軍得主:PostgreSQL 封王!”, 點選 這裡 進一步閱讀 升的最快的幾個資料庫,我簡單的無責任點評: PG資料庫是很老的資料庫,不過這幾年冉冉升起,因為是學院派的,有很好的學術和智力的支援,一直以來在資料庫的體系結構,程式碼
系統技術非業餘研究 » MySQL資料庫架構的演化觀察
MySQL資料庫架構的演化觀察 December 14th, 2017 Categories: 資料庫 Tags: mysql
系統技術非業餘研究 » inet_dist_connect_options
Erlang 17.5版本引入了inet_dist_{listen,connect}_options,對於結點間的互聯socket可以有更精細的控制,RPC的時候效能可以微調: raimo/inet_tcp_dist-priority-option/OTP-12476: Document ke
系統技術非業餘研究 » 推薦工作機會
最後更新時間:2014/11/28 請賜簡歷至:[email protected], 感謝您對加入我們公司有興趣,我們希望能早日和您共事。 以下幾個職位1年內有效,歡迎內部轉崗: 資深資料工程師 公司:阿里(核心系統資料庫組) 工作地點:杭州(西溪園區) 崗位描述: 分析雲服務產生的海
系統技術非業餘研究 » 新的工作和研究方向
和大家更新下: 做了將近8年資料庫後,我的工作和研究方向將會延伸到虛擬化和計算相關的雲服務,希望能夠和大家一起進步,Happy New Year! 預祝大家玩得開心! Post Footer automatically generated by wp-posturl plugin for w
系統技術非業餘研究 » 叢集引入inet_dist_{listen,connect}_options更精細引數微調
Erlang 17.5版本引入了inet_dist_{listen,connect}_options,對於結點間的互聯socket可以有更精細的控制,RPC的時候效能可以微調: raimo/inet_tcp_dist-priority-option/OTP-12476: Document ke
系統技術非業餘研究 » 2017升的最快的幾個資料庫無責任點評
ItPub寫的文章“2017 年度 DB-Engines 資料庫冠軍得主:PostgreSQL 封王!”, 點選 這裡 進一步閱讀 升的最快的幾個資料庫,我簡單的無責任點評: PG資料庫是很老的資料庫,不過這幾年冉冉升起,因為是學院派的,有很好的學術和智力的支援,一直以來在資料庫的體系結構,程式碼
系統技術非業餘研究 » Erlang 17.5引入+hpds命令列控制程序預設字典大小
Erlang 17.5釋出引入控制程序預設字典大小的命令列引數: Erlang/OTP 17.5 has been released Written by Henrik, 01 Apr 2015 Some highlights of the release are: ERTS: Added co
系統技術非業餘研究 » inet_dist_listen_options
Erlang 17.5版本引入了inet_dist_{listen,connect}_options,對於結點間的互聯socket可以有更精細的控制,RPC的時候效能可以微調: raimo/inet_tcp_dist-priority-option/OTP-12476: Document ke
系統技術非業餘研究 » 老生常談: ulimit問題及其影響
ulimit最初設計是用來限制程序對資源的使用情況的,因為早期的系統系統資源包括記憶體,CPU都是非常有限的,系統要保持公平,就要限制大家的使用,以達到一個相對公平的環境。以下是典型的機器預設的限制情況: $ ulimit -a core file size (blocks,
系統技術非業餘研究 » 求賢帖
原創文章,轉載請註明: 轉載自系統技術非業餘研究 本文連結地址: 求賢帖 作為一個優秀的工程師,你其實不缺少才華,你缺少的是神一樣的隊友、充滿挑戰的世界級技術難題,和一個可以施展自己才華的大舞臺。加入阿里核心系統資料庫開發團隊吧,你缺的這裡都有。來吧,戳這裡,給我們見識你的機會:http://b
系統技術非業餘研究 » Erlang R16B03釋出,R17已發力
Erlang R16B03釋出了,通常03版本是bug fix版本,進入生產版本,官方的說明如下: OTP R16B03 is a service release with mostly a number of small corrections and user contributions. B
系統技術非業餘研究 » Erlang R13B04 Installation
R13B04後erlang的原始碼編譯為了考慮移植性,就改變了編譯方式,以下是官方wiki上的安裝文件: 1. Cloning Here are the basic steps to build Erlang/OTP in the Git repository. Start by cloning:
系統技術非業餘研究 » Understanding Linux CPU Load 資料彙總
最近關注線上CPU load的人挺多,很多人覺得load太高系統就有問題,就想各種辦法來折騰。其實在我看來load只是系統CPU執行佇列的在執行程序數的近似值, 如下圖: 對於Unix發展的初期,機器的效能比較差,CPU核數也少,參考意義比較大。現在的機器都是非常強悍的,CPU,記憶體,IO各個
系統技術非業餘研究 » Erlang R15的記憶體delayed dealloc特性對訊息密集型程式的影響
在新的NUMA體系結構下,每個CPU都有自己的本地記憶體,如果要訪問其他CPU的記憶體,那算remote了,要走CPU之間的QPI通道,通常這樣速度會有40%的下降。 那麼對於多執行緒的程式來講,這個硬體的變化對軟體也有很大的影響。在多執行緒程式裡面,通常一個執行緒會為一個物件分配記憶體,然後把這
系統技術非業餘研究 » Erlang R17新特性淺評
Erlang R17RC2 原始碼已經就緒, 參見 這裡 後續版本的釋出時間,官方的時間安排參見 這裡,摘抄如下: Preliminary dates for the upcoming release: Release: erts, emu,comp |Code stop
系統技術非業餘研究 » Erlang R16支援帶顏色的控制檯
Erlang通過fix tty驅動的過濾,在R16版本支援帶顏色的控制檯,這個特性在我們做各種監控工具高亮非常有幫助,參見R16的Readme: Support ANSI in console Unix platforms will no longer filter control sequenc
系統技術非業餘研究 » Linux下新系統呼叫sync_file_range
我們在做資料庫程式或者IO密集型的程式的時候,通常在更新的時候,比如說資料庫程式,希望更新有一定的安全性,我們會在更新操作結束的時候呼叫fsync或者fdatasync來flush資料到持久裝置去。而且通常是以頁面為單位,16K一次或者4K一次。 安全性保證了,但是效能就有很大的損害。而且我們更新