以下是我想要做的比较操作:
// foobar is the name of an ivar on some class
// i.e. NSDate *foobar;
const char *ivarType = [self getTypeForInstanceVariableWithName:@"foobar"];
const char *objType = @encode(NSDate);
if (strcmp(ivarType, objType) == 0) {
//set value
}
NSLog(@"comparing %s with %s", ivarType, objType);
帮助方法:
- (const char*)getTypeForInstanceVariableWithName:(NSString *)name {
return ivar_getTypeEncoding(class_getInstanceVariable([self class], [name cStringUsingEncoding:NSUTF8StringEncoding]));
}
NSLog结果:
comparing @"NSDate" with {NSDate=#}
为什么@encode会返回与ivar_getTypeEncoding()不同的类型语法?有没有更好的方法来完成这种类型的决定?我必须在这里遗漏一些东西...... 谢谢!
答案 0 :(得分:5)
使用ivar_getTypeEncoding()时,您必须注意第一个字符。我们来看一个例子:
如果您有原始类型,则第一个字符将是您获得的所有内容,对于 int ,对于字符'c',它将是'i',对于 unsigned long long 'Q'等......
对于对象和类,您可能会得到更多,例如您的示例,但第一个字符是您想要的,例如@ for objects,#for classes,:for selectors。
您可以阅读这些类型here。您还可以在比较时使用常量,例如_C_ID,_C_CLASS等。在runtime.h处有一个战利品。
C阵列似乎更棘手,但我相信你可以解决这个问题。
您的代码中的一个问题是您正在获取NSDate类的类型编码,而不是NSDate对象。因此,不要与@encode(NSDate)进行比较,而是与@encode(NSDate *)进行比较。
要查看此类代码,请查看Adium's code。