下午交测开发的新功能,给测试演示的时候发现我负责的发帖页面,在没有添加关联商品时发帖程序会闪退。会后我开始调试bug,查找缘由,一个全局断点很容易就定位到了引发程序闪退的代码,原来是一个把字典转转换成字符串的方法引发的。json
//字典转为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 writebash
而引发错误的缘由是在没有添加关联商品时调用convertDictionaryToJsonString
方法时参数传入的是一个空字符串,把字符串当成了一个字典使用,而字符串是没法转换成json格式的,因此代码执行到NSData *jsonData = [NSJSONSerialization dataWithJSONObject:dic options:NSJSONWritingPrettyPrinted error:&error];
语句时,引发了应用闪退。测试
而出现这个bug的缘由是后台接口返回数据发生了变化,同事在没有告知个人状况下帮我修改了代码,好吧,啥都不想不说了。。。 来记录一下第一次遇到的这个bug.ui