举例讲解Objective-C中@property属性的用法讲述.doc

举例讲解Objective-C中@property属性的用法讲述.doc

  1. 1、本文档共13页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
举例讲解Objective-C中@property属性的用法讲述

举例讲解Objective-C中@property属性的用法 这篇文章主要介绍了Objective-C中@property属性的用法,包括@property的属性关键字的整理,需要的朋友可以参考下 学过c/c++的朋友都知道,我们定义struct/class的时候,如果把访问限定符(public,protected,private)设置为public的话,那么我们是可以直接用.号来访问它内部的数据成员的。比如 1 2 3 4 5 6 7//in Test.h class Test { public: int i; float f; };  我在main函数里面是可以通过下面的方式来使用这个类的:(注意,如果在main函数里面使用此类,除了要包含头文件以外,最重要的是记得把main.m改成main.mm,否则会报一些奇怪的错误。所以,任何时候我们使用c++,如果报奇怪的错误,那就要提醒自己是不是把相应的源文件改成.mm后缀了。其它引用此类的文件有时候也要改成.mm文件) 1 2 3 4 5 6//in main.mm Test test; test.i =1; test.f =2.4f; NSLog(@Test.i = %d, Test.f = %f,test.i, test.f);  但是,在objc里面,我们能不能这样做呢?请看下面的代码:(新建一个objc类,命名为BaseClass) 复制代码 代码如下: //in BaseClass.h @interface BaseClass : NSObject{ @public NSString *_name; }  接下来,我们在main.mm里面: 复制代码 代码如下: BaseClass *base= [[BaseClass alloc] init]; =@set base name; NSLog(@base classs name = %@, );   不用等你编译,xcode马上提示错误,请看截图: 请大家注意看出错提示“Property nam not found on object of type BaseClass*,意思是,BaseClass这类没有一个名为name的属性。即使我们在头文件中声明了@public,我们仍然无法在使用BaseClass的时候用.号来直接访问其数据成员。而@public,@protected和@private只会影响继承它的类的访问权限,如果你使用@private声明数据成员,那么在子类中是无法直接使用父类的私有成员的,这和c++,java是一样的。   既然有错误,那么我们就来想法解决啦,编译器说没有@property,那好,我们就定义property,请看代码: 复制代码 代码如下: //in BaseClass.h @interface BaseClass : NSObject{ @public NSString *_name; } @property(nonatomic,copy) NSString *name; //in BaseClass.m @synthesize name = _name;   现在,编译并运行,ok,很好。那你可能会问了@prperty是不是就是让”.号合法了呀?只要定义了@property就可以使用.号来访问类的数据成员了?先让我们来看下面的例子: 复制代码 代码如下: @interface BaseClass : NSObject{ @public NSString *_name; } //@property(nonatomic,copy) NSString *name; -(NSString*) name; -(void) setName:(NSString*)newName;   我把@property的定义注释掉了,另外定义了两个函数,name和setName,下面请看实现文件: 复制代码 代码如下: //@synthesize name = _name; -(NSString*) name{ return _name; } -(void) setName:(NSString *)name{ if (_name != name) { [_name release]; _name = [name copy]; } }   现在,你再编译运行,一样工作的很好。why?因为我刚刚做的工作和先前声明@property所做的工作完全一样。@prperty只不过是给编译器看的一种指令,它可以编译之后为你生成相应的getter和setter方法。而且,注意看到面property(nonatomic,copy)括号里面这copy参数了吗?它所做的事就是 复制代码 代码如下:

文档评论(0)

jiayou10 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

版权声明书
用户编号:8133070117000003

1亿VIP精品文档

相关文档