3

当我尝试使用 NSImage 的 imageFromRect 裁剪图像时,大约 50% 的时间会发生 EXEC_BAD_ACCESS 崩溃。这是在启动时运行的东西(在 awakeFromNib 中触发),所以环境不应该改变。我不确定为什么它会导致一次启动而不是另一次。当我在裁剪图像之前设置了断点时,我可以看到图像是从文件中正确加载的,并且看起来尺寸合适。有什么建议吗?

这是堆栈跟踪:

#0  0x97bb58c2 in ripc_RemoveEntry
#1  0x97b927b0 in ripc_AcquireImage
#2  0x97b903be in ripc_DrawImage
#3  0x930f9384 in CGContextDrawImage
#4  0x9463159f in __-[NSBitmapImageRep draw]_block_invoke_1
#5  0x9448e74b in __-[NSBitmapImageRep _performBlockUsingBackingCGImage:]_block_invoke_1
#6  0x94365232 in -[NSBitmapImageRep _performBlockUsingBacking:]
#7  0x9448e6b3 in -[NSBitmapImageRep _performBlockUsingBackingCGImage:]
#8  0x9462f87f in -[NSBitmapImageRep draw]
#9  0xb0006a03 in -[NSImage(Crop) imageFromRect:] at ThemeManager.m:325
#10 0xb000820a in -[FrameImages setImage:] at ThemeManager.m:270
#11 0xb0005f21 in -[ThemeManager setImage:forTheme:] at ThemeManager.m:63
#12 0xb0006397 in +[ThemeManager defaultThemeManager] at ThemeManager.m:39
#13 0xb0005b33 in -[SCThemedView layoutContentView] at SCThemedView.m:92
#14 0x9435ebaf in -[NSNibOutletConnector establishConnection]
#15 0x9435d33b in -[NSIBObjectData nibInstantiateWithOwner:topLevelObjects:]
#16 0x9435b450 in loadNib
#17 0x9435a848 in +[NSBundle(NSNibLoading) _loadNibFile:nameTable:withZone:ownerBundle:]
#18 0x9435a759 in +[NSBundle(NSNibLoading) loadNibFile:externalNameTable:withZone:]
#19 0x9435a6a4 in +[NSBundle(NSNibLoading) loadNibNamed:owner:]
#20 0x943574a9 in NSApplicationMain
#21 0x0000256a in start
4

2 回答 2

0

堆栈跟踪中没有awakeFromNib;相反,看起来崩溃发生在 nib 加载器仍在建立连接的过程中([NSNibOutletConnector establishConnection] ) 的过程中,这意味着绘图环境可能尚未正确设置。

尝试将 ThemeManager 设置代码(无论调用什么[ThemeManager defaultThemeManager])从 SCThemedView 的layoutContentView方法移动到 SCThemedView 的awakeFromNib.

如果这不起作用,请尝试将所有 ThemeManager 布局/绘图延迟到applicationDidFinishLaunching:调用 NSApplication 的方法之后。

于 2010-02-13T12:39:32.050 回答
0

向我们展示您如何加载图像。崩溃通常是由于对象在您完成之前被释放的结果。

于 2010-02-13T00:10:17.793 回答