所以我试图用我的 sqlite 数据库中的行填充一个对象,如下所示:
- (id) initWithSQLite:(sqlite3_stmt *)row andDatabase:(Database*)db
{
self.valueX = sqlite3_column_int(row, 0);
self.valueY = sqlite3_column_int(row, 1);
self.valueZ = sqlite3_column_int(row, 2);
//etc
return self;
}
由于属性比较多,而且数据库迁移后会添加更多的属性,所以我自作聪明,把代码改成了:
- (id) initWithSQLite:(sqlite3_stmt *)row andDatabase:(Database*)db
{
int i = 0;
self.valueX = sqlite3_column_int(row, i);
self.valueY = sqlite3_column_int(row, i++);
self.valueZ = sqlite3_column_int(row, i++);
//etc
return self;
}
但这不起作用,但如果我将其更改为 sqlite3_column_int(row, i+=1);
它似乎确实有效。
所以我的问题是:i++
Và i += 1
Sự khác biệt là gì?
i++
是后缀表示法,这里的Tôi
只有在语句执行完后才会递增。
虽然 i+=1
扩展为 i = i+1
,但此处 Tôi
在同一语句中递增。您也可以使用 ++i
的前缀符号来实现这一点。
Tôi là một lập trình viên xuất sắc, rất giỏi!