この説明を何度か見たことがあります。self が実際に必要なインスタンスを呼び出しているかどうかがわからないため、初期化メソッドまたは dealloc では属性を使用しないのが最善です。これはなぜでしょうか。
どこで見ましたか?それらはすべて過去のもので、ARC には制限はなく、好きなように使用できます。
昔の手動メモリ管理では、プロパティの呼び出しには参照カウンターの追加と減算が含まれ、self = [super ...] 初始化的对象不一定是当前类的对象,可能是“变体”或私有类(objc里的class有 class 和 metaclass 的区别),所以在你不知道属性 setter 方法里到底是怎么加减引用计数器的情况下,你就只针对 ivar単に保持して解放するだけでした。
self = [super ...]
class
metaclass
ivar
retain(copy,new)とreleaseはペアで表示されます
デリゲートなどの循環参照が生成され、その後決して解放されないためです
注意が必要なカテゴリ (Category)、セッター、ゲッター、KVO などがあるためです 最も重要なことは、分類のため、文法は分類の属性とメソッドを呼び出すことができますが、_ は呼び出すことができません。仕事、注意が必要です
どこで見ましたか?それらはすべて過去のもので、ARC には制限はなく、好きなように使用できます。
昔の手動メモリ管理では、プロパティの呼び出しには参照カウンターの追加と減算が含まれ、
リーリーself = [super ...]
初始化的对象不一定是当前类的对象,可能是“变体”或私有类(objc里的class有class
和metaclass
的区别),所以在你不知道属性 setter 方法里到底是怎么加减引用计数器的情况下,你就只针对ivar
単に保持して解放するだけでした。retain(copy,new)とreleaseはペアで表示されます
デリゲートなどの循環参照が生成され、その後決して解放されないためです
注意が必要なカテゴリ (Category)、セッター、ゲッター、KVO などがあるためです
最も重要なことは、分類のため、文法は分類の属性とメソッドを呼び出すことができますが、_ は呼び出すことができません。仕事、注意が必要です