最近在一个Symbian S60工程中,程序退出时总是提示KERN-EXEC 3错误,跟踪调试是在对象析构时发生的异常,
但定位不到任何具体的行上面,所以推测是系统自动析构某个成员时发生的异常。
注:KERN-EXEC 3 错误描述
This panic is raised when an unhandled exception occurs. Exceptions have many causes, but the most common are access violations caused, for example, by dereferencing NULL. Among other possible causes are: general protection faults, executing an invalid instruction, alignment checks, etc.
然后在析构函数中逐步的去掉一些对象的销毁操作,最后发现与一个指针对象(iMyObject)的delete有关,去掉这个iMyObject对象
的delete操作后,跟踪发现,iMyObject的析构函数仍然会被调到,奇怪,系统自动进行销毁?恍然大悟,CleanupStack!
马上查看iMyObject的构造:
iMyObject = CMyOjbect::NewLC();
原因找到了。不过还要对NewLC费点口舌,它是这样定义的:
但定位不到任何具体的行上面,所以推测是系统自动析构某个成员时发生的异常。
注:KERN-EXEC 3 错误描述
This panic is raised when an unhandled exception occurs. Exceptions have many causes, but the most common are access violations caused, for example, by dereferencing NULL. Among other possible causes are: general protection faults, executing an invalid instruction, alignment checks, etc.
然后在析构函数中逐步的去掉一些对象的销毁操作,最后发现与一个指针对象(iMyObject)的delete有关,去掉这个iMyObject对象
的delete操作后,跟踪发现,iMyObject的析构函数仍然会被调到,奇怪,系统自动进行销毁?恍然大悟,CleanupStack!
马上查看iMyObject的构造:
iMyObject = CMyOjbect::NewLC();
原因找到了。不过还要对NewLC费点口舌,它是这样定义的:
CMyOjbect
*
CMyOjbect::NewLC()