icer 发表于 2009-1-21 19:39:56

name()函数的问题导致宕机原因探索

今天测试时试了一下call /feature/name->replace_color("adsfa"),结果立马宕机
debug.log中显示Error '*Undefined function: query_temp
经过jason调试core发现,/feature/name包含name()函数,而name()函数比较特殊,mudos认为其是一个master_ob的函数,
如果一个object含有name(),则不管调用此object的什么函数,都会先调用一下name()。
不幸的是/feature/name的name()写得不太严格,在里面query_temp("apply/name"),
这在一个object()->name()时并没有问题,因为object也继承了dbase里的query和query_temp,
但在直接call或者其他没有继承dbase的时候,如果调用name(),则会引起master出错,直接宕机。

解决办法是在/feature/name.c的name()中先用function_exists判断一下要调用的
函数,比如query和query_temp是否存在,如果存在再调用它们。

以后应该注意:
如果不是必须,则不要在程序中加入name()函数,如果必须加入,则一定要仔细判断,
一定不能出现调用不存在函数的可能性。

jason 发表于 2009-1-21 20:26:58

lpc支持多重继承,并且可以在父类中调用另一个父类的函数,这是严重违反封装原则的。
不知道当初设计者的出发点是什么。
页: [1]
查看完整版本: name()函数的问题导致宕机原因探索