今天调试程序的时候发现cpu不断在刷,后来找到是自定义NSMatrix子类的 inLiveResize 和 DrawRect 一直在被调用。后来追查到真凶,就是在自定义的NSCell子类的drawWithFrame方法中调用了setAttributedStringValue方法。
估计该方法会促发重绘消息,因此一直循环重绘。
以后在处理绘图函数drawXXX时一定要小心,避免调用到会触发该重绘函数响应的函数,这样的函数应该在重绘函数外调用。
本文记录了在调试过程中遇到的CPU占用率异常问题。通过详细的跟踪和分析,发现是由于自定义NSMatrix子类中的inLiveResize和DrawRect方法被频繁调用导致。进一步定位到自定义NSCell子类的drawWithFrame方法中调用了setAttributedStringValue方法,该方法可能触发了重绘消息,从而导致循环重绘。本文提醒开发者在处理绘图函数时要格外小心。
今天调试程序的时候发现cpu不断在刷,后来找到是自定义NSMatrix子类的 inLiveResize 和 DrawRect 一直在被调用。后来追查到真凶,就是在自定义的NSCell子类的drawWithFrame方法中调用了setAttributedStringValue方法。
估计该方法会促发重绘消息,因此一直循环重绘。
以后在处理绘图函数drawXXX时一定要小心,避免调用到会触发该重绘函数响应的函数,这样的函数应该在重绘函数外调用。

被折叠的 条评论
为什么被折叠?