谁有专业知识来解释什么时候使用NSUInteger,什么时候使用NSInteger?
我曾经见过Cocoa方法返回NSInteger,即使在返回值总是无符号的情况下也是如此。
根本原因是什么?如果我们想表示负值,NSInteger或int是否被严格限制?
来自NSObjCRuntime.h:
#if __LP64__ || (TARGET_OS_EMBEDDED && !TARGET_OS_IPHONE) || TARGET_OS_WIN32 || NS_BUILD_32_LIKE_64
typedef long NSInteger;
typedef unsigned long NSUInteger;
#else
typedef int NSInteger;
typedef unsigned int NSUInteger;
#endif
发布于 2010-07-22 13:14:42
在处理NSUInteger与NSInteger时,您还应该了解整数转换规则:
例如,下面的代码片段返回0 (false),尽管您期望它打印1 (true):
NSInteger si = -1;
NSUInteger ui = 1;
printf("%d\n", si < ui);
原因是si变量被隐式地转换为一个无符号整数!
有关这些“问题”以及如何解决这些“问题”的深入讨论,请参阅CERT's Secure Coding site。
发布于 2014-09-02 21:37:10
默认情况下,假定整数是有符号的。换句话说,编译器假定将调用一个整数变量来存储负数或正数。这限制了范围在两个方向上都能达到的范围。例如,32位int的范围为4,294,967,295。实际上,由于该值可以是正数也可以是负数,因此其范围实际上是−2,147,483,648到+2,147,483,647。如果我们知道一个变量永远不会被调用来存储负值,我们可以将它声明为无符号,从而将(正)范围扩展到0到+4,294,967,295。所以我想说,当你知道你有一个有限的输出范围时,使用NSInteger是可以的。如果我需要返回非常大的仅为正的数字,我个人会使用NSUInteger
发布于 2010-03-31 23:36:09
如果您的方法的输出范围受到适当的限制,那么您最好使用NSInteger
,因为它更容易输入。正如您所说,如果需要返回负数,NSInteger
是唯一的选择;只有在出于某种原因需要返回非常大的数字时,我才会使用NSUInteger
。
https://stackoverflow.com/questions/2557209
复制