- 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 - Web 编程
- Erlang 有用资源
- Erlang - 快速指南
- Erlang - 有用资源
- Erlang - 讨论
Erlang - 端口
在 Erlang 中,端口用于不同程序之间的通信。套接字是一个通信端点,允许机器通过使用互联网协议 (IP) 在互联网上进行通信。
端口中使用的协议类型
有两种类型的协议可用于通信。一个是 UDP,另一个是 TCP。UDP 允许应用程序相互发送短消息(称为数据报),但无法保证这些消息的交付。它们也可能无序到达。另一方面,TCP 提供可靠的字节流,只要连接建立,这些字节流就会按顺序传递。
让我们看一个使用 UDP 打开端口的简单示例。
示例
-module(helloworld). -export([start/0]). start() -> {ok, Socket} = gen_udp:open(8789), io:fwrite("~p",[Socket]).
关于上述程序需要注意以下几点
gen_udp 包含 Erlang 中用于 UDP 通信的模块。
这里 8789 是在 Erlang 中打开的端口号。您需要确保此端口号可用且可以使用。
上述程序的输出为 -
#Port<0.376>
在端口上发送消息
打开端口后,可以在端口上发送消息。这是通过 send 方法完成的。让我们看看语法和以下示例。
语法
send(Socket, Address, Port, Packet)
参数
Socket - 这是使用 gen_udp:open 命令创建的套接字。
Address - 这是要将消息发送到的机器地址。
port - 这是需要发送消息的端口号。
Packet - 这是需要发送的数据包或消息详细信息。
返回值
如果消息发送成功,则返回 ok 消息。
例如
-module(helloworld). -export([start/0]). start() -> {ok, Socket} = gen_udp:open(8789), io:fwrite("~p",[Socket]), io:fwrite("~p",[gen_udp:send (Socket,"localhost",8789,"Hello")]).
输出
上述程序的输出如下。
#Port<0.376>ok
在端口上接收消息
打开端口后,也可以在端口上接收消息。这是通过recv 方法完成的。让我们看看语法和以下示例。
语法
recv(Socket, length)
参数
Socket - 这是使用 gen_udp:open 命令创建的套接字。
Length - 这是需要接收的消息的长度。
返回值
如果消息发送成功,则返回 ok 消息。
例如
-module(helloworld). -export([start/0]). start() -> {ok, Socket} = gen_udp:open(8789), io:fwrite("~p",[Socket]), io:fwrite("~p",[gen_udp:send(Socket,"localhost",8789,"Hello")]), io:fwrite("~p",[gen_udp:recv(Socket, 20)]).
完整程序
现在显然我们不能在同一个程序中拥有相同的发送和接收消息。您需要在不同的程序中定义它们。因此,让我们创建以下代码,该代码创建一个侦听消息的服务器组件和一个发送消息的客户端组件。
示例
-module(helloworld). -export([start/0,client/1]). start() -> spawn(fun() -> server(4000) end). server(Port) -> {ok, Socket} = gen_udp:open(Port, [binary, {active, false}]), io:format("server opened socket:~p~n",[Socket]), loop(Socket). loop(Socket) -> inet:setopts(Socket, [{active, once}]), receive {udp, Socket, Host, Port, Bin} -> io:format("server received:~p~n",[Bin]), gen_udp:send(Socket, Host, Port, Bin), loop(Socket) end. client(N) -> {ok, Socket} = gen_udp:open(0, [binary]), io:format("client opened socket=~p~n",[Socket]), ok = gen_udp:send(Socket, "localhost", 4000, N), Value = receive {udp, Socket, _, _, Bin} -> io:format("client received:~p~n",[Bin]) after 2000 -> 0 end, gen_udp:close(Socket), Value.
关于上述程序需要注意以下几点。
我们定义了两个函数,第一个是 server。这将用于侦听端口 4000。第二个是 client,它将用于向服务器组件发送消息“Hello”。
receive 循环用于在定义的循环中读取发送的消息。
输出
现在您需要从两个窗口运行程序。第一个窗口将用于通过在erl 命令行窗口中运行以下代码来运行服务器组件。
helloworld:start().
这将在命令行窗口中显示以下输出。
server opened socket:#Port<0.2314>
现在在第二个 erl 命令行窗口中,运行以下命令。
Helloworld:client(“<<Hello>>”).
当您发出此命令时,第一个命令行窗口将显示以下输出。
server received:<<"Hello">>