我最近开始在 iOS 中编程。我正在浏览一个声明以下变量的代码片段:
int rc = 0X00;
sqlite3_stmt *pStmt = 0X00;
FMStatement *stat = 0X00;
BOOL abc = 0X00;
这是什么意思??我在某处读到在引用变量中设置 0X00 意味着将其设置为 NULL(在 C 中)。但是将 BOOL 类型变量和 int 类型变量设置为 0X00 是什么意思?
我最近开始在 iOS 中编程。我正在浏览一个声明以下变量的代码片段:
int rc = 0X00;
sqlite3_stmt *pStmt = 0X00;
FMStatement *stat = 0X00;
BOOL abc = 0X00;
这是什么意思??我在某处读到在引用变量中设置 0X00 意味着将其设置为 NULL(在 C 中)。但是将 BOOL 类型变量和 int 类型变量设置为 0X00 是什么意思?
我建议您阅读有关编程语言的基础知识,特别是使用指针进行 C 编程。Objective-C 是 C 的超集,并遵循许多类似的规则。
但是对于您的问题:代码(0x00)中文字值前面的 0x 指定该值被解释为十六进制而不是十进制。但是 0x00(十六进制)与 0(十进制)相同。
int rc = 0x00; //same as int rc = 0;
int 是 Obj-C 和 C 中的原始类型,它指定一个整数,实际上是在初始化变量。在 C 语言中,您必须初始化变量,否则它们可能指向随机的内存块。因此,检查此代码:
int a;
int b = 0;
//a is NOT equal to b!
在 C 中,变量“a”尚未初始化,因此假设它将被初始化为 0 通常是不安全的。始终初始化您的变量。如果您执行了 printf 或变量 'a' 的 NSLog,您会看到它打印了一些巨大的数字并且没有意义(有时这取决于编译器)
BOOL 也可以这样说。尽管将 BOOL 设置为 0 与将其设置为 false 相同;
BOOL flag = 0; //The same as saying BOOL flag = false;
现在是代码的最后一部分:
FMStatement *stat = 0X00;
通常在 Objective-C 中,如果您正在处理指针和对象,则需要初始化指针以指向某个内存地址。实际内存地址通常由堆栈/堆确定,您无需担心。但是您确实需要确保指针没有指向错误的位置(称为垃圾指针)。为此,我们只需将指针设置为 nil。例如:
FMStatement *stat = nil; //This pointer is now safe. Although memory still hasnt been allocated for it yet
当您立即为对象分配内存时,这通常会为您处理好,因此在这种情况下,您无需担心将指针初始化为 nil:
FMStatement *stat = [[FMStatement alloc]init];
就像我说的,我建议你阅读基本的 C 编程、分配、指针、数据类型、初始化等,一旦你掌握了这些,然后转到 Objective-C,然后在它之上构建面向对象的东西。
祝你好运。
0X00
只是0
以十六进制表示。所以,
int rc = 0X00;
是相同的
int rc = 0;
与 BOOL 变量相同,其中0
与 相同NO
。使用很奇怪——在适当的情况下使用或使用指针0X00
会更有意义。0
NO
nil