- Erlang教程
- Erlang - 主页
- Erlang - 概述
- Erlang - 环境
- Erlang - 基本语法
- Erlang-Shell
- Erlang - 数据类型
- Erlang - 变量
- Erlang - 运算符
- Erlang - 循环
- Erlang - 决策
- Erlang - 函数
- Erlang - 模块
- Erlang - 递归
- Erlang - 数字
- Erlang - 字符串
- Erlang - 列表
- Erlang - 文件 I/O
- Erlang - 原子
- Erlang - 地图
- Erlang - 元组
- Erlang - 记录
- Erlang - 异常
- Erlang - 宏
- Erlang - 头文件
- Erlang - 预处理器
- Erlang - 模式匹配
- Erlang - 守卫
- Erlang-BIFS
- Erlang - 二进制文件
- Erlang - 乐趣
- Erlang - 进程
- Erlang - 电子邮件
- Erlang - 数据库
- Erlang - 端口
- Erlang - 分布式编程
- Erlang-OTP
- Erlang - 并发
- Erlang - 性能
- Erlang - 驱动程序
- Erlang - 网络编程
- Erlang 有用资源
- Erlang - 快速指南
- Erlang - 有用的资源
- Erlang - 讨论
Erlang-OTP
OTP 代表开放电信平台。它是一个应用程序操作系统以及一组用于构建大规模、容错、分布式应用程序的库和过程。如果您想使用 OTP 编写自己的应用程序,那么您会发现非常有用的核心概念是 OTP Behave。Behave封装了常见的Behave模式 - 将其视为由回调模块参数化的应用程序框架。
OTP 的力量来自于Behave本身可以提供的容错、可扩展性、动态代码升级等属性。因此,第一个基本概念是创建一个模仿 OTP 环境基础知识的服务器组件,让我们看一下下面的示例。
例子
-module(server). -export([start/2, rpc/2]). start(Name, Mod) -> register(Name, spawn(fun() -> loop(Name, Mod, Mod:init()) end)). rpc(Name, Request) -> Name ! {self(), Request}, receive {Name, Response} -> Response end. loop(Name, Mod, State) -> receive {From, Request} -> {Response, State1} = Mod:handle(Request, State), From ! {Name, Response}, loop(Name, Mod, State1) end.
关于上述程序需要注意以下事项 -
该进程使用注册功能向系统注册。
该过程产生一个处理处理的循环函数。
现在让我们编写一个将利用服务器程序的客户端程序。
例子
-module(name_server). -export([init/0, add/2, whereis/1, handle/2]). -import(server1, [rpc/2]). add(Name, Place) -> rpc(name_server, {add, Name, Place}). whereis(Name) -> rpc(name_server, {whereis, Name}). init() -> dict:new(). handle({add, Name, Place}, Dict) -> {ok, dict:store(Name, Place, Dict)}; handle({whereis, Name}, Dict) -> {dict:find(Name, Dict), Dict}.
这段代码实际上执行两个任务。它充当从服务器框架代码调用的回调模块,同时,它包含将由客户端调用的接口例程。通常的 OTP 约定是将这两个功能组合在同一模块中。
所以上面的程序需要如何运行 -
在erl中,首先通过运行以下命令来运行服务器程序。
server(name_server,name_server)
您将得到以下输出 -
输出
true
然后,运行以下命令
name_server.add(erlang,”Tutorialspoint”).
您将得到以下输出 -
输出
Ok
然后,运行以下命令 -
name_server.whereis(erlang).
您将得到以下输出 -
输出
{ok,"Tutorialspoint"}