如果NSArray有可能是空的,如果它被赋值时为空,那么检查它并将其设置为nil是更好的做法,还是在使用时进行检查更好?
例如:
NSArray *myArray;
if ([anotherArray count] > 0) <-- Check when assigned
myArray = [anotherArray copy];
else
myArray = nil;
something = [myArray objectAtIndex:x];
或
NSArray *myArray;
myArray = [anotherArray copy];
if ([myArray count] > 0) <-- Check when used
something = [myArray objectAtIndex:x];
哪种更好些呢?
发布于 2010-05-07 07:30:09
您应该在必要时检查数组是否为空。
不要将其设置为nil
,这可能会导致其他问题。例如,如果您尝试将nil
数组添加到NSArray
、NSDictionary
或其他集合类中,运行时将引发异常。
发布于 2010-05-06 18:56:57
我认为这是一个编程风格的问题。
我猜您担心的是,如果传入的数组为空,则会不必要地分配内存
https://stackoverflow.com/questions/2780411
复制相似问题