昨天与同事讨论问题的时候,发现如果在graphedit中render一个mpg文件的话,有时候,有些filter会被多次创建,而且是先创建多个instance,然后再删掉其余,只留下一个;而不是创建一个,然后删掉,之后在创建一个。这样问题就出现了。
如果我们在filter的构造函数中create一个文件的句柄,在filter运行的时候对这个文件进行操作,然后在析构函数中close这个handle。那么当这个filter被render,并且多次创建、删除之后,对文件的操作就可能失败,原因很简单,因为当一个文件被打开之后,后继的打开请求未必会成功——这真是我同事遇到的问题。
至于为何在render的时候filter会被多次创建,可能是枚举的需要,但是还不清楚为何是这样的顺序。除了graphedit,mediaplay也是使用render来工作的,相信还有其他的一些软件使用render方式的智能链接来工作。而如果是确定的链接,比如在graphedit中使用grf文件而不是render一个媒体文件来创建graph,则不会出现filter被多次创建的情况,当然,可能只是我还没有遇到。