+[CATransaction synchronize] called within transaction
If I close my iPad app while I'm lo开发者_开发知识库ading data from services, the app closes but then immediately opens again without my doing anything. At this point, I am not able to do anything; I can't close the app and I can't interact with the app or the device. The only way to use the device again is to restart it. The app does not crash, it simply disables the device.
When this happens, the following line appears in the console three times right after applicationWillResignActive and applicationDidEnterBackground:
+[CATransaction synchronize] called within transaction
It'd be almost okay if the app crashes, but the fact that the device is rendered completely useless is a huge problem. If I could intercept this bug or somehow detect when CATransaction raises this issue, then that'd be fine.
Any ideas?
This happens when more than one animations are taking place on main thread. I faced the same problem. In my case application freezes while animating the CALayer and rotating the device simultaneously. So I stopped the animation while rotating the device.
Look for the code
[CATransaction begin]
//foo
[CATransaction commit]
Make sure that animation inside this code does not overlap with your other animations on main thread.
This can show up in the logs if you use UIWindow.rootViewController
to skip storyboards altogether.
To ditch the log message you can remove the storyboard, remove the key associating the Storyboard with your app in info.plist, set LaunchScreen.storyboard
as the Main Interface
in the target and use
window = UIApplication.shared.keyWindow!
inside AppDelegate
to get the main window
and assign your UIViewController
on it.
精彩评论