iOS開發知識之:NS_ASSUME_NONNULL_BEGIN,NS_ASSUME_NONNULL_END
阿新 • • 發佈:2018-11-10
Nonnull區域設定(Audited Regions)
如果需要每個屬性或每個方法都去指定nonnull和nullable,是一件非常繁瑣的事。蘋果為了減輕我們的工作量,專門提供了兩個巨集:NS_ASSUME_NONNULL_BEGIN和NS_ASSUME_NONNULL_END。在這兩個巨集之間的程式碼,所有簡單指標物件都被假定為nonnull,因此我們只需要去指定那些nullable的指標。如下程式碼所示:
NS_ASSUME_NONNULL_BEGIN @interface TestNullabilityClass () @property (nonatomic, copy) NSArray * items; - (id)itemWithName:(nullable NSString *)name; @end NS_ASSUME_NONNULL_END
在上面的程式碼中,items屬性預設是nonnull的,itemWithName:方法的返回值也是nonnull,而引數是指定為nullable的。
不過,為了安全起見,蘋果還制定了幾條規則:
- typedef定義的型別的nullability特性通常依賴於上下文,即使是在Audited Regions中,也不能假定它為nonnull。
- 複雜的指標型別(如id *)必須顯示去指定是nonnull還是nullable。例如,指定一個指向nullable物件的nonnull指標,可以使用”__nullable id * __nonnull”。
- 我們經常使用的NSError **通常是被假定為一個指向nullable NSError物件的nullable指標。
參考: