erlang:gen-server和state

时间:2013-11-23 16:51:15

标签: erlang state gen-server

作为测试我对顺序Erlang的理解的练习,我写了一个简单的html标签编辑器。

它维持文本中的当前位置,例如编辑状态,在这样的记录中:

-record(ed_txt, {a=[], b=[], c=[]).

...其中a保存当前段落上方的文本,b保存当前段落,c保存当前段落下方的文本。

它被称为:

tag(App, FileName) ->
   {ok, File1} = get_file(App, FileName),
   {ok, File2} = file_to_paragraphs(File1),
   {ok, Record} = create_record(File2),
   ....

tag(Record) ->
   {ok, InputTuple} = get_input(Record), % gets edit command
   ...
   do(Command, Record)

函数do / 2是递归函数,如下所示:

   do("h", Record)    -> tag(help(Record));
   do("down", Record) -> tag(down(Record));
   do("up",Record)    -> tag(up(Record));
   do("h1", Record)   -> tag(wrap("H1", Record));
   ...
   do("quit", Record) -> {ok, quit(Record)};
   do(_, Record)      -> tag(Record).

现在我想把这个模块变成一个OTP gen-server,但是我意识到我并不真正理解如何维护状态。

我创建了一个州记录:

-record(state, {app, filename, a=[], b=[], c=[]}).

我的想法是使用一对一的主管,这样每个用户都在他/她自己的进程中工作,抛弃编辑循环,并使用handle_call(或handle_cast)来调用相应的 编辑功能。

但令我困惑的是:

只要进程正在运行,可能会在进程中维护用户状态,但handle_call和handle_cast都将State作为参数并返回State。

这是否意味着我还必须维护其各自进程的每个用户OUTSIDE的状态,或许?

还是有更好的方法来完成这项工作吗?

非常感谢,

LRP

0 个答案:

没有答案