erlang 使用callback自定义行为模式

erlang之前自定义行为模式,需要导出behaviour_info函数,比如:

?
1
2
3
4
5
6
7
-module(gen_foo).
- export ([behaviour_info/1]).
 
behaviour_info(callbacks) ->
     [{foo, 0}, {bar, 1}, {baz, 2}];
behavior_info(_) ->
     undefined.
在需要实现gen_foo行为模式的模块,添加-behaviour(gen_foo),实现相关的函数就行。

这种方式的缺点是,实现模块在实现函数时,没有类型规范的约束,约束只有函数名和元数。

已经存在的-spec关键字,不能使用在这种场景下,原因是spec用来规范约束函数定义和使用的。

erlang提出了新的关键字:callback,极大的简化了自定义行为模式的编码。代码如下:

?
1
2
3
-module(ranch_transport).
 
-callback messages() -> {OK::atom(), Closed::atom(), Error::atom()}.
编译期间使用 callback约束,自动生成behaviour_info导出函数,进一步检查实现行为模式的模块导出了所有的callback函数。



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值