我有一个正在损坏的 const 字符串文字。
奇怪的是,根据安装的 XCode 版本,它的行为显然有所不同(我必须再做一些实验才能 100% 确认这一点),但即使它不是 Xcode,那么我想知道可能是什么原因。
如果完全相同的代码在完全相同的手机上运行,但其中一个运行它连接到运行 Xcode 3.3.3 的笔记本电脑,那么如果相同的代码和相同的手机在另一台装有 XCode 的笔记本电脑上运行,那么这个问题就会出现安装 4.3.2 或 4.4 则问题不明显。
问题是这样的:
HeaderFile.h
extern NSString* const kValue;
HeaderFile.m
NSString* const kValue = @"Some Value";
OtherFile.m
#import "HeaderFile.h"
...
NSLog(@"Value is: %@", kValue);
当使用 Xcode 4.3.3 连接到笔记本电脑时,在调试全局常量时记录或观察到的值已损坏。
知道这是怎么回事吗?
因为它是一个 const 文字,如果我的代码中存在错误,它应该不可能被涂写。
更新: 我在 didFinishLaunchingWithOptions: 被调用后立即检查了 kValue 的值,此时它已经损坏,所以我的代码没有机会在上面涂写,即使它是可涂写的。
最佳答案
作为一个 const 文字,如果我的代码中存在错误,它不应该被涂写。
这并不完全正确。
首先,const 甚至可以通过简单的转换删除。其次,如果您有一个严重的错误,您可能正在写入存储变量的内存,因为您正在访问另一个变量的内存之外(例如,如果您获取 short
的地址并将其转换为类型为 long*
然后访问它)。第三,您将指针本身声明为 const,但指向的数据不是 const(至少根据声明不是)。
另一方面,一般来说,您观察到的情况确实可能是不可能的。通常将声明为 const 的全局变量放在运行时只读的内存区域中。但并非所有硬件都允许这样做,而且编译器也没有真正要求这样做。此外,字符串文字通常也被视为 const,这意味着实际上您指向的内容也可能存储在 const 区域中(即使指针不是 const)。
我不知道你为什么会观察到这种行为,而且我不知道编译器和 iPhone 硬件的内部结构,所以我不能说是否真的因为错误而无法修改该数据。但我知道,根据语言规则,编译器(和硬件)将所有内容存储在可修改区域中是完全合法的。如果那是他们所做的,那么是的,错误可能就是问题所在。
关于objective-c - const 全局字符串文字已损坏,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12083765/