本文介绍: 平均时间 此函数当前实现的复杂度为 O(1),最坏情况下的时间复杂度为O(N), 其中 N 是流程中的项数 字典。也就是说,is_process_alive/1 对于正在退出的进程返回 false,但其进程标识符是 part 从进程返回的结果/0。返回一个元组,该元组是参数 Tuple1 的副本,其中由整数参数 Index 指定的元素(第一个元素是索引为 1 的元素)替换为 argument 值。返回元组中的元素数或 二进制或位串中的字节,对于位字符串,将返回整字节数。返回调用进程的进程标识符。

 map_size

1> map_size(#{a=>1, b=>2, c=>3}).
3

 返回一个整数,即键值对的数量

max 

2> max(1, 2).
2
3> max(1.0, 1).
1.0
4> max(1, 1.0).
1
5> max("abc", "b").
"b"

 返回 Term1 和 Term2 中最大的值。如果这些项与 == 运算符,Term1 是 返回。

min 

6> min(1, 2).
1
7> min(1.0, 1).
1.0
8> min(1, 1.0).
1
9> min("abc", "b").
"abc"

 返回 Term1 和 Term2 中的最小值。如果这些项与 == 运算符,Term1 是 返回。

pid_to_list 

10> erlang:pid_to_list(self()).
"<0.79.0>"

返回与文本对应的字符串 Pid 的表示。

processes 

11> processes().
[<0.0.0>,<0.1.0>,<0.2.0>,<0.3.0>,<0.4.0>,<0.5.0>,<0.6.0>,
 <0.7.0>,<0.10.0>,<0.42.0>,<0.44.0>,<0.46.0>,<0.47.0>,
 <0.49.0>,<0.50.0>,<0.51.0>,<0.52.0>,<0.53.0>,<0.54.0>,
 <0.55.0>,<0.56.0>,<0.57.0>,<0.58.0>,<0.59.0>,<0.60.0>,
 <0.61.0>,<0.62.0>,<0.63.0>,<0.64.0>|...]

 返回对应于 本地节点上当前存在的所有进程。请注意,退出进程存在,但不是活动进程。 也就是说,is_process_alive/1 对于正在退出的进程返回 false,但其进程标识符是 part 从进程返回的结果/0。

 put

12> X = put(name, walrus), Y = put(name, carpenter),
12> Z = get(name),
12> {X, Y, Z}. 
{undefined,walrus,carpenter}

将新的 Key 添加到进程字典中, 与值 Val 关联,并返回 undefined。如果 Key 存在,则旧的 value 被删除并替换为 Val,并且 该函数返回旧值。平均时间 此函数当前实现的复杂度为 O(1),最坏情况下的时间复杂度为O(N), 其中 N 是流程中的项数 字典。

registered 

14> registered().
[kernel_safe_sup,kernel_sup,user,global_name_server,
 global_group,file_server_2,standard_error,kernel_refc,
 logger_sup,logger_std_h_default,erts_code_purger,
 code_server,erl_signal_server,erl_prim_loader,logger_proxy,
 application_controller,init,inet_db,socket_registry,logger,
 rex,logger_handler_watcher,standard_error_sup,user_drv]

返回已使用 register/2 注册的名称列表。

round 

15> round(42.1).             
42
16> round(5.5).
6
17> round(-5.5).
-6
18> round(36028797018963969.0).
36028797018963968

通过舍入 Number 返回一个整数,在最后一个示例中,round(36028797018963969.0) 的计算结果为 36028797018963968。这样做的原因是 数字 36028797018963969.0 无法表示 与浮点值完全相同。相反,float 文本是 表示为 36028797018963968.0,这是最接近的数字 这可以完全表示为浮点值。

self 

19> self().
<0.79.0>

返回调用进程的进程标识符。

setelement 

20> setelement(2, {10, green, bottles}, red).
{10,red,bottles}

返回一个元组,该元组是参数 Tuple1 的副本,其中由整数参数 Index 指定的元素(第一个元素是索引为 1 的元素)替换为 argument 值。

size 

21> size({morni, mulle, bwange}).
3
22> size(<<11, 22, 33>>).
3

返回元组中的元素数或 二进制或位串中的字节,对于位字符串,将返回整字节数。 也就是说,如果位数 在位串中不能被 8 整除,则得到 字节数向下舍入。

spawn 

24> spawn(speed, regulator, [high_speed, thin_cut]). 
<0.105.0>
25> =ERROR REPORT==== 1-Feb-2024::22:04:13.252000 ===
Error in process <0.105.0> with exit value:
{undef,[{speed,regulator,[high_speed,thin_cut],[]}]}

返回启动者 启动的新进程的进程标识符 Module:Function 在 Args 中的应用。error_handler:undefined_function(模块, 如果 Module:Function/Arity 不存在(其中 Arity 是 Args 的长度),则新进程将评估 Function, Args)。错误处理程序 可以重新定义。如果 error_handler 未定义,或者用户已定义 重新定义了默认error_handler,其替换为 undefined,则发生原因为 undef 的故障。

split_binary 

25> B = list_to_binary("0123456789").
<<"0123456789">>
26> byte_size(B).
10
27> {B1, B2} = split_binary(B,3).
{<<"012">>,<<"3456789">>}
28>  byte_size(B1).
3
29> byte_size(B2).
7

返回一个元组,其中包含作为结果的二进制文件 将 Bin 拆分为两部分 位置位置 这不是破坏性操作。手术后, 总共有三个二进制文件。

statistics 

30> statistics(garbage_collection).
{538,586822,0}

 返回有关垃圾回收的信息,对于某些实现,此信息可能无效。

31> erlang:statistics(microstate_accounting).
[#{counters =>
       #{aux => 0,check_io => 0,emulator => 0,gc => 0,other => 0,
         port => 0,sleep => 0},
   id => 4,type => scheduler}, 
 #{counters => #{aux => 0,check_io => 0,...},
   id => 6,type => dirty_cpu_scheduler},
 #{counters => #{aux => 0,...},id => 5,...},
 #{counters => #{...},...},
 #{...}|...]

返回输入, 这是总字节数 通过端口接收,并输出, 这是输出到端口的总字节数。

32>  statistics(reductions).
{444785,444785}

返回有关减少的信息

33> statistics(runtime).
{3453,3453}

返回有关运行时的信息(以毫秒为单位)。这是所有线程的运行时总和 在 Erlang 运行时系统中,因此可以更大 比挂钟时间。

37> Ts1 = lists:sort(erlang:statistics(scheduler_wall_time)), ok.
ok
38> lists:map(fun({{I, A0, T0}, {I, A1, T1}}) ->                 
38> {I, (A1 - A0)/(T1 - T0)} end, lists:zip(Ts0,Ts1)).           
[{1,6.608032257562958e-4},
 {2,0.0},
 {3,0.0},
 {4,0.0},
 {5,0.0},
 {6,0.0},
 {7,0.0},
 {8,0.0},
 {9,0.0},
 {10,0.0},
 {11,0.0},
 {12,0.0},
 {13,0.0},
 {14,0.0},
 {15,0.0},
 {16,0.0},
 {17,0.0},
 {18,0.0},
 {19,0.0},
 {20,0.0},
 {21,0.0},
 {22,0.0},
 {23,0.0},
 {24,0.0}]

您可以使用scheduler_wall_time来计算 调度程序利用率。首先,对值进行采样 由 erlang:statistics(scheduler_wall_time) 返回。一段时间后,用户拍摄另一个快照并计算 每个调度程序的调度程序利用率。

term_to_binary

39> Bin = term_to_binary(hello).
<<131,100,0,5,104,101,108,108,111>>
40> hello = binary_to_term(Bin).
hello

 返回一个二进制数据对象,该对象是根据 Erlang 外部对 Term 进行编码的结果 术语格式。这可以用于各种目的,例如, 以有效的方式将术语写入文件,或发送 Erlang 术语对某种类型的通信渠道不是 由分布式 Erlang 支持。

原文地址:https://blog.csdn.net/m0_62961827/article/details/135982744

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。

如若转载,请注明出处:http://www.7code.cn/show_64837.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注