在iPhone App中分配NSInteger属性

时间:2012-09-05 06:10:22

标签: iphone objective-c ios xcode sqlite

我在SQLite中有一个表我想在该表中插入数据。该表有respond_id,participant_id,answer_text,answer_option_update_date_time。 responses_id和participant_id是整数。当我将任何事物分配给participant_id时,它会给出错误,对象无法设置为属性。

@interface Coffee : NSObject {

NSInteger coffeeID;
NSInteger participant_Id;

NSString*question_Id;
NSString*answer_option;
NSString*answer_text;
NSString*update_date_time;




//Intrnal variables to keep track of the state of the object.
}

@property (nonatomic, readonly) NSInteger coffeeID;
@property (nonatomic, retain) NSInteger participant_Id;

@property (nonatomic, copy) NSString *question_Id;
@property (nonatomic, copy) NSString *answer_option;
@property (nonatomic, copy) NSString *answer_text;
@property (nonatomic, copy) NSString *update_date_time;


- (void)save_Local {
    CereniaAppDelegate *appDelegate = (CereniaAppDelegate *)[[UIApplication sharedApplication] delegate];

    Coffee *coffeeObj = [[Coffee alloc] initWithPrimaryKey:0];

    coffeeObj.participant_Id=mynumber;

    NSString*question="1";
    coffeeObj.question_Id=question;
    coffeeObj.answer_option=selectionAnswerOption;
    coffeeObj.answer_text=professionTextField.text;




    NSDate* date = [NSDate date];
    NSDateFormatter* formatter = [[NSDateFormatter alloc] init];
    [formatter setDateFormat:@"yyyy-MM-dd HH:MM:SS"];
    NSString* str = [formatter stringFromDate:date];

    UPDATE_DATE_TIME=str;


    coffeeObj.update_date_time=UPDATE_DATE_TIME;

    //Add the object
    [appDelegate addCoffee:coffeeObj];  
}

当我为participant_id分配值时,会出错。

1 个答案:

答案 0 :(得分:35)

NSInteger不是一个类,它是一个基本类型,如intlong。在iOS NSIntegertypedefint,在OS X上typedeflong。因此,您不应该尝试retain NSInteger。您应该将您的财产声明更改为:

@property (nonatomic, assign) NSInteger participant_Id;

您的coffeeID财产也是如此。