• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

iphone - iOS5 BAD_EXCESS 仅在设备上

[复制链接]
菜鸟教程小白 发表于 2022-12-11 22:42:39 | 显示全部楼层 |阅读模式 打印 上一主题 下一主题

我正在运行一个后台线程来从 Web 服务获取数据。

要获得创建 URL 所需的设置,我使用此方法:

+(Settings *)getSettings
{
    Settings *settings = [[Settings alloc] init];
    NSString *path = [NSString stringWithFormat"Documents/Settings"];
    NSString *settingsPath = [NSHomeDirectory() stringByAppendingPathComponent:path];
    NSFileManager *fileMgr = [NSFileManager defaultManager];
    if ([fileMgr fileExistsAtPath:settingsPath]) {
        NSDictionary *settingsDictionary = [NSDictionary dictionaryWithContentsOfFile:settingsPath];
        settings.username = [settingsDictionary objectForKey"username"];
        settings.module = [settingsDictionary objectForKey"module"];
        settings.websiteUrl = [settingsDictionary objectForKey"websiteUrl"];

    }else
    {
        settings.username =  @"";
        settings.module =  @"";
        settings.websiteUrl =  @"";
    }
    NSLog(@"Settings = u:%@ m:%@ w:%@",settings.username,settings.module,settings.websiteUrl);
    return settings;
}

这在调试器中运行良好,但是当我在设备上运行它时,我在 NSLog 或任何尝试使用带有警告的数据的类上得到 BAD_EXCESS:

警告:尝试使用不在框架中的 block 创建 USE_BLOCK_IN_FRAME 变量。

如果我单步执行代码,这就是代码在设备上可以正常工作。

有什么想法吗?

编辑: 回溯 -

#0  0x37a97eda in objc_retain ()
#1  0x37aa4be4 in objc_retainAutoreleasedReturnValue ()
#2  0x0000f84a in +[SettingData getSettings] (self=0x175e4, _cmd=0x11af9) at /Users/Jono/Dropbox/Uni/iOS5/Feedback At Tees/Feedback At Tees/SettingData.m:49
#3  0x0000fa86 in -[DataManager init] (self=0x3509e0, _cmd=0x30fd9f96) at /Users/Jono/Dropbox/Uni/iOS5/Feedback At Tees/Feedback At Tees/DataManager.m:19
#4  0x00003b46 in __35-[MasterViewController viewDidLoad]_block_invoke_0 (.block_descriptor=0x185f40) at /Users/Jono/Dropbox/Uni/iOS5/Feedback At Tees/Feedback At Tees/MasterViewController.m:70
#5  0x30b08d54 in _dispatch_call_block_and_release ()
#6  0x30b0b896 in _dispatch_worker_thread2 ()
#7  0x37a0e1ce in _pthread_wqthread ()
#8  0x37a0e0a4 in start_wqthread ()

我尝试将以下内容添加到设置的 init 方法中,如果我单步执行它是可以的

-(id)init
{
    if ((self=[super init]))
    {
        NSString *path = [NSString stringWithFormat"Documents/Settings"];
        NSString *settingsPath = [NSHomeDirectory() stringByAppendingPathComponent:path];
        NSFileManager *fileMgr = [NSFileManager defaultManager];
        if ([fileMgr fileExistsAtPath:settingsPath]) 
        {
            NSDictionary *settingsDictionary = [NSDictionary dictionaryWithContentsOfFile:settingsPath];
            self.username = [settingsDictionary objectForKey"username"];
            self.module = [settingsDictionary objectForKey"module"];
            self.websiteUrl = [settingsDictionary objectForKey"websiteUrl"];
            NSLog(@"Settings = u:%@ m:%@ w:%@",self.username,self.module,self.websiteUrl);
        }
        else
        {
            self.username =  @"";
            self.module =  @"";
            self.websiteUrl =  @"";
        }
    }
    NSLog(@"Settings = u:%@ m:%@ w:%@",self.username,self.module,self.websiteUrl);
    return self;
}

截图: http://postimage.org/image/4vw6uq7pp/



Best Answer-推荐答案


首先,方法应该是 retrieveSettingsdownloadSettings 或者只是 settings,而不是 getSettings get 作为前缀对于方法的论证(通过引用传递)具有非常特殊的含义。

其次,该代码并没有明显的问题(除了settings的泄漏,但这不会导致这种崩溃)。 (我看到 ARC 已启用)。

最后,如果您发生了崩溃,那么发布回溯。您看到的错误消息(“USE_BLOCK_IN_FRAME”)表明您发布的代码与崩溃无关。


奇怪的崩溃,那个。好的——警告来自调试器,与实际错误没有任何关系。

范围边界通常是编译器发出 release 和/或耗尽自动释放池的位置。

这会引出下一个问题;怎么样

This is the code works fine on the device if I step through the code.

好的——所以,当你全速运行时它不起作用,而在逐步运行时它起作用。闻起来像并发崩溃。你能发布实际崩溃的截图吗? IE。您确定特定的回溯是崩溃的回溯,而不是崩溃时调试器发生的位置吗?

(是的,稍微抓紧了救命稻草——根据所显示的证据,这次崩溃没有意义。我喜欢谜题。)


好的——现在我们已经到了某个地方。有点。在成功记录相同的东西inside if 的范围后,它会在 if 的范围之外 outside 崩溃。

usernamemodulewebsiteURL 是如何定义的?它们是 strong 还是最恰当的 copy @property 声明?

关于iphone - iOS5 BAD_EXCESS 仅在设备上,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10194923/

回复

使用道具 举报

懒得打字嘛,点击右侧快捷回复 【右侧内容,后台自定义】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关注0

粉丝2

帖子830918

发布主题
阅读排行 更多
广告位

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap