Может кто - нибудь объяснить мне подробно , когда я должен использовать каждый атрибут: nonatomic, copy, strong, weak, и так далее, для заявленного имущества, и объяснить , что каждый делает? Какой-то пример тоже подойдет. Я использую ARC.
Может кто - нибудь объяснить мне подробно , когда я должен использовать каждый атрибут: nonatomic, copy, strong, weak, и так далее, для заявленного имущества, и объяснить , что каждый делает? Какой-то пример тоже подойдет. Я использую ARC.
Ответы:
Этот ответ имеет множество ошибок и также устарел. Пожалуйста, смотрите другие вопросы / ответы и комментарии.
неатомической
nonatomicиспользуется для многопоточности. Если мы установили неатомарный атрибут во время объявления, тогда любой другой поток, желающий получить доступ к этому объекту, может получить к нему доступ и дать результаты в отношении многопоточности.
копия
copyтребуется, когда объект изменчив. Используйте это, если вам нужно, чтобы значение объекта было таким, как оно есть в данный момент, и вы не хотите, чтобы это значение отражало какие-либо изменения, сделанные другими владельцами объекта. Вам нужно будет освободить объект, когда вы закончите с ним, потому что вы сохраняете копию.
Присвоить
Assignявляется несколько противоположностью copy. При вызове метода получения assignсвойства он возвращает ссылку на фактические данные. Обычно вы используете этот атрибут, когда у вас есть свойство примитивного типа (float, int, BOOL ...)
сохранить
retainтребуется, когда атрибут является указателем на объект. Сеттер, сгенерированный с помощью @synthesize, сохранит (или добавит счет сохранения) объект. Вам нужно будет отпустить объект, когда вы закончите с ним. Использование retain увеличивает количество сохраняемых данных и занимает память в пуле автоматического выпуска.
сильный
strongявляется заменой атрибута retain, как части автоматического подсчета ссылок Objective-C (ARC). В не-ARC-коде это просто синоним для сохранения.
Это хороший сайт для изучения strongи weakдля iOS 5.
http://www.raywenderlich.com/5677/beginning-arc-in-ios-5-part-1
слабый
weakаналогично тому, strongчто он не увеличивает счетчик ссылок на 1. Он не становится владельцем этого объекта, а просто хранит ссылку на него. Если счетчик ссылок объекта падает до 0, хотя вы все еще можете указывать на него здесь, он будет освобожден из памяти.
Приведенная выше ссылка содержит как полезную, так и слабую информацию .
nonatomicозначает, что к нему не должны обращаться одновременно несколько потоков. По умолчанию это atomicделает его потокобезопасным.
nonatomic Свойство утверждает, что объект не является потокобезопасным, что означает, что если другой поток пытается получить доступ к этому объекту, это может привести к плохим вещам, но это намного быстрее, чем атомарное свойство.
strongиспользуется с ARC, и это в основном помогает вам, не беспокоясь о сохранении счета объекта. ARC автоматически выпускает его для вас, когда вы закончите. Использование ключевого слова strongозначает, что вы являетесь владельцем объекта.
weakвладение означает, что вы не владеете им, и он просто отслеживает объект до тех пор, пока объект, которому он был назначен, не останется, как только будет выпущен второй объект, он теряет свою ценность. Например, obj.a=objectB;используется и имеет слабое свойство, тогда его значение будет действительным только до тех пор, пока objectB не останется в памяти.
copyсвойство очень хорошо объяснено здесь
strong,weak,retain,copy,assignявляются взаимоисключающими, поэтому вы не можете использовать их на одном объекте ... прочитайте раздел «Объявленные свойства»
надеясь, что это поможет вам немного ...
nonatomicтолько означает, что исключение не применяется. Это не означает, что доступ не является потокобезопасным. Это деталь реализации, которую atomicvs. nonatomicне фиксирует.
Эта ссылка сломана
http://clang.llvm.org/docs/AutomaticReferenceCounting.html#ownership.spelling.property
Назначение подразумевает __unsafe_unretained владение.
Копирование подразумевает __strong владение, а также обычное поведение семантики копирования в установщике.
сохранить подразумевает __сильное владение.
сильный подразумевает __сильное владение.
unsafe_unretained подразумевает __unsafe_unretained владение.
слабая подразумевает слабое владение.
Отличные ответы! Одна вещь, которую я хотел бы уточнить, это nonatomic/ atomic. Пользователь должен понимать, что это свойство - «атомарность» распространяется только на ссылку атрибута, а не на его содержимое. Т.е. atomicгарантируется атомарность пользователя для чтения / установки указателя и только указателя на атрибут. Например:
@interface MyClass: NSObject
@property (atomic, strong) NSDictionary *dict;
...
В этом случае гарантируется, что указатель на dictбудет читаться / устанавливаться атомарным способом различными потоками. НО dictсам по себе (словарь dictуказывает на) по-прежнему потокобезопасным , то есть все операции чтения / добавления в словарь по-прежнему поток небезопасно.
Если вам нужен потокобезопасный сбор, у вас либо плохая архитектура (чаще), либо реальное требование (более редко). Если это «реальное требование» - вы должны либо найти хороший и проверенный потокобезопасный компонент для сбора, либо быть готовым к испытаниям и невзгодам, написав свой собственный. В последнем случае рассмотрим парадигмы «без блокировки» и «без ожидания». На первый взгляд это похоже на ракетостроение, но может помочь вам добиться фантастических результатов по сравнению с «обычной блокировкой».