Подтвердить что ты не робот

Как определить и реализовать свойства в протоколе

Я хочу определить один протокол с несколькими свойствами и использовать эти свойства в другом подклассе NSObject. Пожалуйста, дайте мне ссылку или пример кода. Мне нужно, чтобы работать с 10.5.

Спасибо   ПОЖАЛУЙСТА, ПРОВЕРЬТЕ СЛЕДУЮЩИЙ КОД ОБРАЗЦА

@protocol MyProtocol
@property (nonatomic, readonly) id someObject;
@property (nonatomic, getter=isAlive) BOOL alive;
@end

#import "MyProtocol.h"
@interface MyCustomClass : NSObject <MyProtocol>{

}
@end

#import "MyCustomClass.h"
@implementation MyCustomClass
@synthesize someObject,alive;

/*
- (id)someObject {
    return nil;
}

- (BOOL)isAlive {
    return YES;
}

- (void)setAlive:(BOOL)aBOOL {
}
*/
@end

** Добавлено: Код компиляции с архитектурой x86_64 отлично работает. Но ошибка, если я изменю архитектуру на i386, тогда я получаю следующие предупреждения:

MyCustomClass.m:13: error: synthesized property 'someObject' must either be named the same as a compatible ivar or must explicitly name an ivar

 error: synthesized property 'alive' must either be named the same as a compatible ivar or must explicitly name an ivar

Я просто хочу знать, почему он работает в x86_64 с @synthesize, а не в i386. **

4b9b3361

Ответ 1

@property просто сообщает компилятору, что класс должен определить методы, соответствующие этому свойству.

@protocol MyProtocol
@property (nonatomic, readonly) id someObject;
@property (nonatomic, getter=isAlive) BOOL alive;
@end

Теперь все, что реализует этот протокол, должно иметь

- (id)someObject;
- (BOOL)isAlive;
- (void)setAlive:(BOOL)aBOOL;

Ответ 2

Я думаю, что вещи, с которыми вы имеете дело, в первую очередь являются побочными эффектами введения Objective-C 2.0. Он позволяет вам делать такие вещи, как declare properties, не определяя также экземпляры vars. Но (как вы обнаружили), это только совместимость с x86_64 и пост-10.5.