OC学习之@property和点语法

OC中类的成员变量默认是@protect,外界无法访问类的成员变量,所以通常我们在类文件中声明变量时会同时声明setter跟getter两个方法方便我们获取变量和修改(下面所有代码均在ARC模式下实现)
Person.h文件

[objc] view plain copy
  1. #import <Foundation/Foundation.h>  
  2.   
  3. @interface Person : NSObject  
  4. {  
  5.     int _age;  
  6.     NSString * _name;  
  7. }  
  8.   
  9. - (void)setAge: (int)age;   //setter方法  
  10. - (int)age;                 //getter方法  
  11. - (void)setName: (NSString *)name;  
  12.   
  13. @end  
Person.m文件
[objc] view plain copy
  1. #import "Person.h"  
  2.   
  3. @implementation Person  
  4.   
  5. - (void)setAge: (int)age  
  6. {  
  7.     _age = age;  
  8. }  
  9.   
  10. - (int)age  
  11. {  
  12.     return _age;  
  13. }  
  14.   
  15. - (void)setName: (NSString *)name  
  16. {  
  17.     _name = name;  
  18. }  
  19.   
  20. @end  
Main.m文件

在创建了setter方法跟getter方法之后,我们可以在main函数中访问到Person中的_age变量,也可以对age进行修改。而name变量我们只给它创建了setter方法,然后在访问变量时报错了。

为了进一步证明▪语法确实调用了这些方法,我在age的两个方法里加上断点,然后运行测试

说明了点语法实际上在我们使用时并不是直接访问变量,而是使用getter跟setter的方法来进行成员变量的访问和修改。那么为了说明属性@property的特性,我们将Person.m文件中的setter和getter方法全部清除掉,重写Person.h

[objc] view plain copy
  1. #import <Foundation/Foundation.h>  
  2.   
  3. @interface Person : NSObject  
  4.   
  5. @property (assign, nonatomicint age;  
  6. @property (copynonatomicNSString * name;  
  7.   
  8. @end  
Person.m
[objc] view plain copy
  1. #import "Person.h"  
  2.   
  3. @end  

修改完后我们直接运行main.m的原先代码,输出

要知道我们在新的Person文件里没有创建任何getter跟setter方法,但是我们可以直接使用这两个成员变量了,这是因为我们使用@property的时候编译器会自动帮我们生成getter和setter方法。当然了,我们可以在.m文件中使用关键字@dynamic加上变量名告诉编译器不要为这些变量自动生成这些方法

这次访问失败,程序运行crash了
关于@property括号中的属性表达的意思如下:
assign简单赋值,引用计数不增加
readwrite读写操作,默认
readonly只读属性
copy深复制
retain保留对象
strong保留对象
weak不保留对象,对象为空时自动变为nil
nonatomic非原子性,不对线程加锁,高性能
atomic多线程加锁,性能低

猜你喜欢

转载自blog.csdn.net/zxtech_lxy/article/details/80108755