NSObject和反射

Person.h:

#import <Foundation/Foundation.h>  @interface Person : NSObject  @property(nonatomic,retain) NSString * name;  -(void) test; @end

Person.m:

#import "Person.h"  @implementation Person  +(id)personWithName:(NSString *)name{     Person *person=[[[Person alloc] init] autorelease];     person.name=name;     return person; }  -(void)test{     NSLog(@"调用了Person的test方法"); }  -(NSString *)description{     return self.name; }  -(id)alloc{     [_name release];     [super alloc]; } @end

Student.h:

#import "Person.h"  @interface Student : Person -(void) test; -(void) test2:(NSString *)a; //-(void) test3:(NSString *)a withPer:(NSString *)b; @end

Student.m:

#import "Student.h"  @implementation Student -(void)test{     NSLog(@"调用了test方法"); } -(void)test2:(NSString *)a{     NSLog(@"调用了test2方法,参数%@",a); } //-(void)test3:(NSString *)a withPar:(NSString *)b{ //    NSLog(@"带有两个参数的方法,参数1%@,参数2%@",a,b); //} @end

main:

#import <Foundation/Foundation.h> #import "Student.h" #import "Person.h" //由于Student继承自Person,所以这儿可以不需要导入Person.h,但import导入的时候,会先进行判断,然后在导入头文件,不会出现重复导入的状况  void NSObjectCreate(){     //判断是否是某一个类     id *stu=[[[Student alloc] init] autorelease];     if([stu isKindOfClass:[Person class]]){ //判断是否是Student类或者是否继承自Person类         NSLog(@"stu是Student类或者是继承自Person类");     }     else         NSLog(@"不是");      //如果用[stu isMemberOfClass:]这种方法只能判断是否是属于这个类,如果是子类则返回no,这个判断范围没有上面那种方法大     BOOL * result=[stu isMemberOfClass:[Person class]];     NSLog(@"是否是这个类:%i",result);       Student *student=[[[Student alloc] init] autorelease];     //直接调用方法     [student test];     //间接调用方法     [student performSelector:@selector(test)]; //调用无参方法     //如果调用有参方法要特别注意,调用的这个函数的参数类型不能是基本数据类型,就算我们将要传的参数封装成基本OC对象的NSNumber,但OC不支持自动解包,所以要确保调用的方法它的参数是OC对象     [student performSelector:@selector(test2:) withObject:@"3"];     //调用带有两个参数的方法,但是注意,没有调用两个参数及以上的方法     //[student performSelector:@selector(test2) withObject:@"1" withObject:@"2"];      //使用定时器,延迟两秒调用test2     [student performSelector:@selector(test2:) withObject:@"1" afterDelay:2];//延迟2秒钟带调用调用这个方法,注意:由于主函数都结束了,所以看不到延迟调用这个方法的执行 } #pragma mark - 反射 void reflect(){     //类名的反射(字符串变成类名)     NSString *str=@"Person";     Class class=NSClassFromString(str);     Person *person=[[[class alloc] init] autorelease];     person.name=@"dingxiaowei";     NSLog(@"%@",person);       //类名变成字符串     NSString * strClass= NSStringFromClass([Person class]);     NSLog(@"%@",strClass);      //方法的反射     NSString *method=@"test";     SEL selector=NSSelectorFromString(method);     [person performSelector:selector];     //selector变成字符串     str=NSStringFromSelector(selector);     NSLog(@"%@",str);      }  int main(int argc, const char * argv[]) {      @autoreleasepool {         //NSObjectCreate();         reflect();     }     return 0; }

结果:

2013-08-02 15:22:21.727 NSObject[1072:303] dingxiaowei

2013-08-02 15:22:21.728 NSObject[1072:303] Person

2013-08-02 15:22:21.729 NSObject[1072:303] 调用了Persontest方法

2013-08-02 15:22:21.729 NSObject[1072:303] test

























本文转自蓬莱仙羽51CTO博客,原文链接:http://blog.51cto.com/dingxiaowei/1366574,如需转载请自行联系原作者

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值