Erlang OTP

OTP是開放電信平臺的縮寫。它是一個應(yīng)用程序操作系統(tǒng),以及一組用于構(gòu)建大規(guī)模、容錯和分布式應(yīng)用程序的庫和過程。如果你想使用 OTP 編寫你自己的程序,那么你會發(fā)現(xiàn) OTP 行為是非常有用的核心概念。行為封裝了常見的行為模式ーー可以把它看作是一個由回調(diào)模塊參數(shù)化的應(yīng)用程序框架。

OTP 的強(qiáng)大功能來自于它的容錯性、可伸縮性、動態(tài)代碼升級等特性,這些特性可以通過行為本身來提供。因此,第一個基本概念是創(chuàng)建一個模仿 OTP 環(huán)境基礎(chǔ)的服務(wù)器組件,讓我們看看下面這個相同的示例。

在線示例

-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.

關(guān)于上述程序,需要注意以下幾點(diǎn):

  • 使用register函數(shù)向系統(tǒng)注冊的進(jìn)程。

  • 該進(jìn)程生成一個處理該進(jìn)程的循環(huán)函數(shù)。

現(xiàn)在,讓我們編寫一個將利用服務(wù)器程序的客戶端程序。

在線示例

-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}.

這段代碼實(shí)際上執(zhí)行兩個任務(wù)。它充當(dāng)從服務(wù)器框架代碼調(diào)用的回調(diào)模塊,同時(shí),它包含將由客戶機(jī)調(diào)用的接口例程。OTP 通常的慣例是將兩個函數(shù)組合在同一個模塊中。

所以這是上面的程序需要運(yùn)行的方式-

erl中,首先通過運(yùn)行以下命令來運(yùn)行服務(wù)器程序。

server(name_server,name_server)

您將獲得以下輸出-

輸出結(jié)果

true

然后,運(yùn)行以下命令

name_server.add(erlang,”nhooo”).

您將獲得以下輸出-

輸出結(jié)果

Ok

然后,運(yùn)行以下命令-

name_server.whereis(erlang).

您將獲得以下輸出-

輸出結(jié)果

{ok,"nhooo"}
丰满人妻一级特黄a大片,午夜无码免费福利一级,欧美亚洲精品在线,国产婷婷成人久久Av免费高清