2008-06-28
[笔记]Erlang R12B中的sub binary优化
在Erlang的 DOC erl5.6.3/doc/efficiency_guide/binaryhandling.html#4 中,第四章提到了Binary的优化。由于虚拟机经过了改良,一些在R11B使用的Binary优化技巧,在R12B就不推荐使用了。
特别注意的是sub binary的使用。举个例子,从一个大的Binary中取出以某个字节结束的一句:
上面的代码由于将sub binary T 传递给 extract_str_end_with_tag3/2,在使用 erlc +bin_opt_info 编译的时候会提示:
我的做法是加入一个是否匹配的字段:
这样在编译时就可以进行优化
特别注意的是sub binary的使用。举个例子,从一个大的Binary中取出以某个字节结束的一句:
extract_str_end_with_tag(Data, Tag) ->
extract_str_end_with_tag2(Data, <<>>, Tag).
extract_str_end_with_tag2(<<Tag, T/binary>>, Buffer, Tag) ->
extract_str_end_with_tag3(Buffer, T); %% 留意这里
extract_str_end_with_tag2(<<B, T/binary>>, Buffer, Tag) ->
extract_str_end_with_tag2(T, <<Buffer/binary, B>>, Tag);
extract_str_end_with_tag2(<<>>, Buffer, Tag) ->
{not_found, Buffer}.
extract_str_end_with_tag3(Str, NextStr) ->
{found, Str, size(Str), NextStr}.
上面的代码由于将sub binary T 传递给 extract_str_end_with_tag3/2,在使用 erlc +bin_opt_info 编译的时候会提示:
引用
Warning: NOT OPTIMIZED: called function extract_str_end_with_tag3/
2 does not begin with a suitable binary matching instruction
2 does not begin with a suitable binary matching instruction
我的做法是加入一个是否匹配的字段:
extract_str_end_with_tag(Data, Tag) ->
extract_str_end_with_tag2(Data, <<>>, Tag, not_found).
extract_str_end_with_tag2(RestBinary, Buffer, _, found) ->
extract_str_end_with_tag3(Buffer, RestBinary); %在found的时候再将RestBinary进行传递
extract_str_end_with_tag2(<<Tag, T/binary>>, Buffer, Tag, _) ->
extract_str_end_with_tag2(T, Buffer, Tag, found); %这里不使用T
extract_str_end_with_tag2(<<B, T/binary>>, Buffer, Tag, not_found) ->
extract_str_end_with_tag2(T, <<Buffer/binary, B>>, Tag, not_found);
extract_str_end_with_tag2(<<>>, Buffer, _, _) ->
{not_found, Buffer}.
extract_str_end_with_tag3(Str, NextStr) ->
{found, Str, size(Str), NextStr}.
这样在编译时就可以进行优化
引用
Warning: OPTIMIZED: creation of sub binary delayed
发表评论
- 浏览: 26111 次

- 详细资料
搜索本博客
最近加入圈子
最新评论
-
New Erlang book
13, Silverlight and Erlang 嗯,什么关系呢,呵呵。
-- by boost -
对Socket的{active, true} ...
不会溢出。 inet:setopts {read_packets, N} 这个参 ...
-- by mryufeng -
[笔记]用ets实现了把一 ...
ets肯定会比gb_tree快 毕竟是c实现的 推荐大量使。事实上erlang的 ...
-- by mryufeng -
erlang module pg2
好像不能下载代码了。能不能也发一份给我。dotwoo@gmail.com 谢谢了 ...
-- by dotwoo -
Java 和 Erlang 的列表元 ...
这个层面效率应该差不太多
-- by mryufeng






评论排行榜