美文网首页
MudOS的物件(objects)

MudOS的物件(objects)

作者: 1angxi | 来源:发表于2015-07-31 18:25 被阅读280次

    MudOS里面以物件(objects)来称呼一个.c文件。其实跟其他语言中class的概念很像,不过与之相比会有一些特殊的地方。

    MudOS中的物件,统一继承一个"object"物件,代表了这是一个具体的实体。这个具体的实体可以是:房子(room)、怪物(monster)、用户(user)等东西。

    下面先来看看物件的通用函数(每个物件都可以定义的函数)。

    通用函数

    create

    void create( void ); 
    

    用法:

    每一个物件中, 都应定义一个 create() 函数. 在 create() 函数中, 要完成一个物件的初始条件设定. 所有的物件都会调用 create() 函数.

    clean_up

    int clean_up( int inherited );
    

    用法:

    驱动程序 (driver) 为在一段时间之内没有活动 (inactive) 的物件调用 clean_up() 函数. 此段时间的长短, 定义在执行时段组态档 (rumtime configuration file) 中。clean_up() 会收到一个标志 (flag) , 指出此物件是否有别的物件继承 (inherit) 它. 如果clean_up() 返回 0, 则此物件将永远不再调用 clean_up().  如果返回 1, 则在指定的 clean_up() 延迟时间之后物件仍没有活动的话, 再调用一次 clean_up().

    通常一个物件在 clean_up() 中所作的事, 是摧毁自己以节省内存.

    reset

    void reset( void ); 
    

    用法:

    在每次重新设定 (reset)  之后 (实际的重新设定周期取决于该 mud 的设定, 平均大约是每两个小时一次) , 所有游戏中现存的物件都会调用 reset() 函数. 如果编译驱动程序时, 于 options.h  中定义了 LAZY_RESET,  只有玩家接触到的物件才会调用 reset(). 如此一来, 没用到的物件就不会从交换档 (swap file)  中载入并进行重新设定. reset() 常用于检查宝物或怪物是否还在某个房间, 以判断要不要重新产生一份.

    上面讲的比较模糊。reset其实用于房间重新生成怪物,也是是游戏里面的刷怪。

    move_or_destruct

    int move_or_destruct( object dest ); 
    

    用法:

    如果一个物件的环境 (environment)  物件被摧毁了, 就调用此函数, 并用于它的内容物件. dest  是正要被摧毁的物件. 如果 dest 不存在, 则 dest 为 0. 如果 dest 中的物件没有把自己移出被摧毁的物件, 则也会被一起摧毁.

    每个object都有属于自己的environment。最直观的概念,就是玩家打副本地图。如果玩家通关一个临时副本,副本地图的销毁会导致所有处于这个环境下的object调用自身的move_or_destruct。副本内的怪物destruct,玩家move到其他地图。

    init

    void init( void ); 
    

    用法:

    当 mudlib 把物件 A放入(move)物件 B时, 驱动程序 (即 move_object() 函数)  会做以下的动作:

    1.  如果 A 是活的 (living),  让 A  在 B里面调用 A 的 init() 函数.

    2.  不管 A是否为活的物件, 让 B的内容物 (inventory) 里面, 所有活的物件调用 A 的 init().

    3.  如果 A是活的, 让 A调用位于 B  的内容物里面所有物件的 init().

    请注意: 一个物件必须曾调用过 enable_command(3) 才视为活的物件.

    一般来说, 一个物件的 init(4) 函数用来调用 add_command(3), 添加此物件提供的动词命令 (command).

    举个例子,当来到一个新的地图时,玩家和地图各自的init被调用,玩家可能会得到某种buf或message,地图要做一些初始化的工作,比如通知其他玩家有人来了。这体现了一种互相影响的关系。(太哲学了)

    id

    int id( string an_id ); 
    

    用法:

    present(3)外部函数调用 id() 以判断一个指定的物件是否以字符串 an_id为识别名称 (id) . 如果 an_id  是此物件的识别名称之一, 就返回 1, 不是则返回 0.

    其实就是询问一个object:你是那谁谁谁吗?

    互动物件(interactive)

    互动物件一般是指玩家物件。

    logon

    object logon( void ); 
    

    主控物件 (master) 中的 connect() 函数返回的物件会调用 logon(). 此函数将新的使用者设定好.

    也就是初始化使用者。一般来说会在这里弹个消息欢迎用户。

    net_dead

    void net_dead( void ); 
    

    如果一个可互动的物件 (即玩家物件) 突然断线 (即成了「网路死亡」(net dead)  状态) , 则驱动程序对此物件调用 net_dead() , 让此物件稍后有机会被清理掉 (clean up)、将断线状态告知环境物件等等. 请小心, 在物件处于可互动状态时才有作用的函数, 将不会如您预料般地工作.

    一般要在这里停止心跳,并告知environment,这个player掉线了。

    process_input

    string process_input( string ); 
    

    用法:

    如果玩家物件中有 process_input(), 则 MudOS  驱动程序则会将玩家所输入的每行数据传递给 process_input(). process_input() 使得像命令回溯 (command history)  和防止 wizcuffs.  process_input() 可以在分析 (parse) 命令前, 修改玩家输入的数据. 如果 process_input() 返回一个非零字符串, 则此字符串就代替玩家输入的内容.

    很容易理解,用户所有的命令都要经过这个函数的处理,处理过后的返回值就会代替用户输入的命令进入下一个流程。

    receive_message

    void receive_message( string class, string message ); 
    

    用法:

    message() 这一类的外部函数调用在玩家物件中的 receive_message(). 参数 parameter通常用于指示消息的种类 (说话 say, 倾诉 tell,  表情 emote, 战斗 combat, 房间语句 room description).  receive_message()  和 message() 的外部函数结合在一起, 可以提供一个「聪明的」消息处理程序介面.

    就是反馈信息用的。

    还有一个receive_snoop函数:

    void receive_snoop( string message) ;
    

    用法:

    如果驱动程序编译时, 在 options.h  中定义 RECEIVE_SNOOP, 则一个使用者窥视另一个使用者时, 所有窥视的文字会传递给玩家物件中的 receive_snoop()  函数. 在此函数中, 您可以处理这些文字. receive_snoop() 程序的内容, 通常把这些文字再传递给 receive() 函数.

    主控物件(master)

    主控物件只有一个,负责整个程序的调度。举个例子,每当新用户连接到服务器的时候,driver会调用master的connect方法。一般来说,connect方法负责生成一个login对象并返回,login负责处理与新用户的所有交互。

    相关文章

      网友评论

          本文标题:MudOS的物件(objects)

          本文链接:https://www.haomeiwen.com/subject/zufvqttx.html