iOS和Objective-C:大部分CPU时间花在[NSObject release]和[NSObject retain]上但是类方法没有做任何内存操作

Guy*_*Guy 8 profiling memory-management objective-c instruments ios

图像处理应用程序在模拟器上快速运行,但在真实设备(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
Run Code Online (Sandbox Code Playgroud)

任何人都可以解释为什么大部分的CPU时间花在[NSObject release][NSObject retain]

小智 3

如果它不知道更好的方法,ARC 将保留方法的所有参数,并在方法退出时释放它们(请参阅此 objc 语言邮件列表电子邮件)。

您应该能够根据您的需要通过+signTested:p1:p2:使用__weak或注释参数来避免这种情况__unsafe_unretained

  • 问题不在于采用 CGFloat 参数的 `+signTestedX:testedY:p1x:p1y:p2x:p2y:` ;正如您所注意到的,浮点数不是对象,并且那里的语义没有意义。问题出在“+signTested:p1:p2:”中,它调用“+signTestedX:testedY:p1x:p1y:p2x:p2y:”并采用“Point2F”参数,这些参数(看起来)是可以保留的对象/释放。 (3认同)