// 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()不同的类型语法?有没有更好的方法来完成这种类型的决定?我必须在这里遗漏一些东西……
谢谢!
如果你有一个原始类型,那么第一个char将是你得到的所有,对于int,它将是’i’,对于char’c’,对于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.
总结以上是内存溢出为你收集整理的iphone – 如何使用ivar_getTypeEncoding和@encode动态确定和比较对象ivars的类型?全部内容,希望文章能够帮你解决iphone – 如何使用ivar_getTypeEncoding和@encode动态确定和比较对象ivars的类型?所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)