代码敲久了的朋友们可能都在控制台遇见过下面的这两行输出
_BSMachError: (os/kern) invalid capability (20)
_BSMachError: (os/kern) invalid name (15)
我很久之前遇见过,那时候随便翻了翻资料,印象中大概是说这是什么新系统bug,也可能是什么消息传递后未被实现,总之这个问题并不是100%必现,就算现出来也不一定影响程序运行,所以当时的帖子就建议不要管它
结果现在sdk版本都迭代了好几个版本了,我居然又遇到这个问题了。寻思着,这回怎么也得认真点查查为什么了吧。
这回遇见的场景是:(使用swift2.3)
1.从网络上拿到用户登录信息,存入了NSUserDefaults,再从NSUserDefaults中取出来时控制台80%几率输出此两行
stackoverflow上有两个评论我觉得比较有意思,原帖点这里。
第一个说法是,尽管这个问题看起来像是将来会被修复的一个bug,但它是自从iOS9之后App Transport Security发生了变化后遗留下来的问题,因此该评论的解决方案是,修改info.plist文件中的App Transport Security 设置:
<key>NSAppTransportSecurity</key>
<dict>
<key>NSExceptionDomains</key>
<dict>
<key>testdomain.com</key>
<dict>
<key>NSIncludesSubdomains</key>
<false/>
<key>NSExceptionAllowsInsecureHTTPLoads</key>
<false/>
<key>NSExceptionRequiresForwardSecrecy</key>
<true/>
<key>NSExceptionMinimumTLSVersion</key>
<string>TLSv1.2</string>
<key>NSThirdPartyExceptionAllowsInsecureHTTPLoads</key>
<false/>
<key>NSThirdPartyExceptionRequiresForwardSecrecy</key>
<true/>
<key>NSThirdPartyExceptionMinimumTLSVersion</key>
<string>TLSv1.2</string>
<key>NSRequiresCertificateTransparency</key>
<false/>
</dict>
</dict>
</dict>
不过虽然看起来似乎有点可能性,可是我是从本地数据读出来打印的时候,控制台出现的提示,所以应该跟网络下载没有关系,再看下一条。
2。http://cocoadocs.org/docsets/Keyboard/0.3.0/
这里提到可能是键盘的问题,需要Pod补丁
3。还有一点需要注意的评论:
Dismissing view controller prematurely might cause this.
[self dismissViewControllerAnimated:YES completion:NULL];
//<do something..>
This throws _BSMachErrors
vs
//<do something..>
[self dismissViewControllerAnimated:YES completion:NULL];
Now, the _BSMachError is gone.
然而,最终我并没有得出结论,因为在这以上两个方法都没有使用的情况下,我将会出_BSMachError输出附近的print方法都注销了,再运行,什么问题都没有了…我还能说什么?WTF?呵呵哒
后续报道:
苹果开发者论坛上找到两个连接:
https://forums.developer.apple.com/message/122381#122381
https://forums.developer.apple.com/thread/15683
结论:这个问题太复杂,如果没有上下文,苹果开发团队也说不清_BSMachError确切是由于什么引起的。不过人家最后留下了线索:
—
Quinn “The Eskimo!”
Apple Developer Relations, Developer Technical Support, Core OS/Hardware
let myEmail = “eskimo” + “1” + “@apple.com”
---------------
如果你觉得有必要的话,可以写信给这个邮箱,等等看有什么结果