- 1、本文档共13页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 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{@publicNSString *_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{@publicNSString *_name;}@property(nonatomic,copy) NSString *name;//in BaseClass.m@synthesize name = _name;
现在,编译并运行,ok,很好。那你可能会问了@prperty是不是就是让”.号合法了呀?只要定义了@property就可以使用.号来访问类的数据成员了?先让我们来看下面的例子:
复制代码 代码如下:
@interface BaseClass : NSObject{@publicNSString *_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)