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,如需转载请自行联系原作者

相关文章
|
8月前
|
Java
【反射】Java反射机制 -- 常用构造器与方法
【反射】Java反射机制 -- 常用构造器与方法
72 0
|
程序员 C#
C# 类实现接口(Interface) 多态 多继承
C# 类实现接口(Interface) 多态 多继承
|
Java API
Java反射(通过反射获取构造函数、方法、属性)
1.通过反射获取构造函数,2.通过反射获取方法,3.通过反射调用成员属性
125 0
|
编译器 定位技术
在父类的构造函数中调用虚函数为什么不能实现多态
在父类的构造函数中调用虚函数为什么不能实现多态
114 0
子类到底能不能继承父类的私有属性?
继承就像是我们现实生活中的父子关系,儿子可以遗传父亲的一些特性,在面向对象语言中,就是一个类可以继承另一个类的一些特性,从而可以代码重用,其实继承体现的是is-a关系,父类同子类在本质上还是一类实体;子类通过继承父类的属性的行为,我们称之为继承。Java只支持单继承,不支持多继承。因为多继承容易带来安全隐患:当多个父类定义相同的功能,当功能内容不同的时候,子类对象不确定要运行哪一个,在Java中用另一种形式体现出来,就是接口的多实现。
如何通过反射创建对象?
方法1:通过类对象调用newInstance()方法,例如:String.class.newInstance() 方法2:通过类对象的getConstructor()或getDeclaredConstructor()方法获得构造器(Constructor)对象并调用其newInstance()方法创建对象,例如:String.
1302 0
|
iOS开发
NSObject类了解
今天看一本书,偶然间看到关于继承的那一章。上面有一句话是这么说的:在OC中,允许定义自己的根类,但通常不这么做,而是希望利用现有的类。因此,我们所定义的类都是属于NSObject根类的派生类。
977 0