阅读 393

iOS:“Invalid top-level type in JSON write”引起程序闪退

下午交测开发的新功能,给测试演示的时候发现我负责的发帖页面,在没有添加关联商品时发帖程序会闪退。会后我开始调试bug,查找原因,一个全局断点很容易就定位到了引起程序闪退的代码,原来是一个把字典转转换成字符串的方法引起的。

//字典转为Json字符串
+ (NSString *)convertDictionaryToJsonString:(NSDictionary *)dic
{
    NSError *error = nil;
    NSData *jsonData = [NSJSONSerialization dataWithJSONObject:dic options:NSJSONWritingPrettyPrinted error:&error];
    return [[NSString alloc] initWithData:jsonData encoding:NSUTF8StringEncoding];
}
复制代码

错误log如下: [NSJSONSerialization dataWithJSONObject:options:error:]: Invalid top-level type in JSON write

而引起错误的原因是在没有添加关联商品时调用convertDictionaryToJsonString方法时参数传入的是一个空字符串,把字符串当成了一个字典使用,而字符串是无法转换成json格式的,所以代码执行到NSData *jsonData = [NSJSONSerialization dataWithJSONObject:dic options:NSJSONWritingPrettyPrinted error:&error];语句时,引起了应用闪退。

而出现这个bug的原因是后台接口返回数据发生了变化,同事在没有告知我的情况下帮我修改了代码,好吧,啥都不想不说了。。。 来记录一下第一次遇到的这个bug.

关注下面的标签,发现更多相似文章
评论