图像处理应用程序在模拟器上运行速度很快,但在真实设备(iPhone 4GS)上运行速度非常慢.
在“instruments”下运行应用程序时,我看到以下调用树:
请注意,报告红色圆圈内的调用几乎占用了该方法的所有cpu时间.
@implementation Line2F + (CGFloat)signTested:(Point2F *)tested p1:(Point2F *)p1 p2:(Point2F *)p2 { return [Line2F signTestedX:tested.x testedY:tested.y p1x:p1.x p1y:p1.y p2x:p2.x p2y:p2.y]; } + (CGFloat)signTestedX:(CGFloat)testedX testedY:(CGFloat)testedY p1x:(CGFloat)p1x p1y:(CGFloat)p1y p2x:(CGFloat)p2x p2y:(CGFloat)p2y { return (testedX - p2x) * (p1y - p2y) - (p1x - p2x) * (testedY - p2y); } @end
任何人都可以解释为什么大部分cpu时间花在[NSObject发布]和[NSObject保留]上?
解决方法
如果它不知道任何更好的ARC将保留方法的所有参数并在方法退出时释放它们(见
this objc-language mailing list email).
您应该能够通过注释signTested的参数来避免这种情况:p1:p2:根据您的需要使用__weak或__unsafe_unretained.