CGContextSaveGState:无效上下文 0x0 仅在设备上出错

CGContextSaveGState: invalid context 0x0 Error only on device

更新:我正在使用 XCode 7 Beta 和 Swift 2.0

当我尝试在 iPhone 上 运行 我的应用程序时,我遇到了这 3 个错误:

<Error>: CGContextSaveGState: invalid context 0x0. If you want to see the backtrace, please set CG_CONTEXT_SHOW_BACKTRACE environmental variable.
<Error>: CGContextTranslateCTM: invalid context 0x0. If you want to see the backtrace, please set CG_CONTEXT_SHOW_BACKTRACE environmental variable.
<Error>: CGContextRestoreGState: invalid context 0x0. If you want to see the backtrace, please set CG_CONTEXT_SHOW_BACKTRACE environmental variable.

当我启用 CG_CONTEXT_SHOW_BACKTRACE 变量时,我得到这个:

Backtrace:
      <<redacted>+40>
       <<redacted>+432>
        <<redacted>+144>
         <<redacted>+172>
          <<redacted>+332>
           <<redacted>+112>
            <<redacted>+820>
             <<redacted>+688>
              <<redacted>+356>
               <<redacted>+80>
                <<redacted>+808>
                 <<redacted>+344>
                  <<redacted>+420>
                   <<redacted>+104>
                    <<redacted>+284>
                     <<redacted>+556>
                      <<redacted>+504>
                       <<redacted>+1792>
                        <<redacted>+220>
                         <<redacted>+284>
                          <<redacted>+920>
                           <<redacted>+168>
                            <<redacted>+184>
                             <<redacted>+56>
                              <<redacted>+24>
                               <<redacted>+540>
                                <<redacted>+724>
                                 <CFRunLoopRunSpecific+384>
                                  <<redacted>+460>
                                   <UIApplicationMain+204>
                                    <main+164>

我不确定如何解释这一点,我没有在我的代码中使用任何 CoreGraphics 内容,而其他类似问题的答案对我不起作用。我知道没有代码很难帮助调试,但我无法弄清楚与此相关的代码,所以如果有人有想法,我可以 post 更多代码。

我在 iOS9 beta5 上编译我的项目时也遇到了这个问题(包括编辑部分)。在 iOS8.

上编译时没问题

它发生在我的 App Delegate 中,在执行来自

的任何命令之前
  • (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {

所以它似乎比我们的问题更有可能是 iOS 测试版问题。

根据我的实验,这似乎是由于在 Info.plist 中定义了 UIViewControllerBasedStatusBarAppearance

它发生在 iOS 9(测试版和 GM)上,但不会发生在 8.4 上。

我在 xcode 7 GM 版本上得到了同样的东西,我想我会简单地忽略它们,因为一切正常,但它很烦人,即使他们已经承认它是一个错误但还没有修复它。 Dev Forum Posting

根据@JimRota 的建议,将其移至答案中,因为它被认为有帮助:

如果这个还在 XCode 7 GM,iOS9 GM。但是,检查一下:将 UIViewControllerBasedStatusBarAppearance 设置为 YES(即使状态栏被隐藏,这就是我一开始将其设置为 NO 的原因),警告就会消失。疯了!

然后我不得不将其添加到我的视图控制器以隐藏状态栏:

- (BOOL) prefersStatusBarHidden
{
    return YES;
}

对我来说,我所有的 VC 实际上都继承自 ProjectNameViewController,因此稍微简化了它。

根据上面给出的评论,这是真正的修复方法:

UIViewControllerBasedStatusBarAppearance to YES in Info.plist

我有这个错误。这是因为我创建了一个函数而忘记添加一个 return 值。

-(void)doSomething

对比

-doSomething

我在使用非整数值作为可调整大小图像的插图时遇到了相同类型的错误,如下所示:

UIImage * image = [[UIImage imageNamed:@"pill"]
             resizableImageWithCapInsets:UIEdgeInsetsMake(17.5, 17.5, 17.5, 17.5)];

这导致了这种日志。使用整数值解决了问题。