property可以被声明的位置
property可以在类的interface section和class extension以及protocol中被声明
property的可见性
Objective-C中的property实际上就是getter和setter方法。一个类的property能够在外部被访问,主要看该类的property声明在外部能否可见。比如有一个类X,其.h和.m文件如下:
//X.h #import <Foundation/Foundation.h> @interface X : NSObject @end
//X.m #import "X.h" @interface X () @property (assign, nonatomic) int i; @end @implementation X @end
如果在main函数中访问声明于X.m中的property,则会报错:
//main.m #import <Foundation/Foundation.h> #import "X.h" int main(int argc, const char * argv[]) { @autoreleasepool { X *x = [X new]; x.i = 2; //报错,property i不可见 } return 0; }
但是,如果我们把class extension移动到X.h中,此时main函数就可以看到property i的声明,就不会报错。或者,你可以在X.h中的interface section部分声明property i的setter方法,由于main函数访问的实际就是property i的setter方法,经过声明之后,setter方法对于main函数可见,因此也不会报错。
property合成实例变量的名字
property合成实例变量有3中情况:
1) 不使用@synthesize指令,此时合成的实例变量名字为下划线加上property,即_property
2) 只使用@synthesize property名,那么此时合成的实例变量名字和property名一样
3) 使用@synthesize property名=实例名,那么此时合成的实例名字就是指定的名字
什么时候不会为property合成实例变量
如果你为一个readwriteproperty自定义了getter,setter方法或者为一个readonly property自定义了getter方法,那么编译器不会自动合成对应的实例变量,除非显示使用@synthesize property名或者@synthesize property名=实例名
合成的实例变量的可访问性
合成的实例变量都是private的。
property的默认attribute
property的默认attribute是assign,atomic,readwrite的
参考链接: