標籤:
- 如果後期需要增加資料庫中的欄位怎麼實現,如果不使用CoreData呢?
編寫SQL語句來操作原來表中的欄位
1> 增加表欄位
ALTER TABLE 表名 ADD COLUMN 欄位名 欄位類型;
2> 刪除表欄位
ALTER TABLE 表名 DROP COLUMN 欄位名;
3> 修改表欄位
ALTER TABLE 表名 RENAME COLUMN 舊欄位名 TO 新欄位名;
- SQLite資料存放區是怎麼用?
1> 添加SQLite動態庫:
2> 匯入主標頭檔:#import <sqlite3.h>
3> 利用C語言函數建立\開啟資料庫,編寫SQL語句
- 簡單描述下用戶端的緩衝機制?
- 緩衝可以分為:記憶體資料緩衝、資料庫緩衝、檔案快取
- 每次想擷取資料的時候
1> 先檢測記憶體中有無緩衝
2> 再檢測本地有無緩衝(資料庫\檔案)
3> 最終發送網路請求
4> 將伺服器返回的網路資料進行緩衝(記憶體、資料庫、檔案), 以便下次讀取
- 你實現過多線程的Core Data嗎?NSPersistentStoreCoordinator,NSManagedObjectContext和NSManagedObject中的哪些需要線上程中建立或者傳遞?你是用什麼樣的策略來實現的?
1> CoreData是對SQLite資料庫的封裝
2> CoreData中的NSManagedObjectContext在多線程中不安全
3> 如果想要多線程訪問CoreData的話,最好的方法是一個線程一個NSManagedObjectContext
4> 每個NSManagedObjectContext對象執行個體都可以使用同一個NSPersistentStoreCoordinator執行個體,這是因為NSManagedObjectContext會在便用NSPersistentStoreCoordinator前上鎖
5 什麼是資料持久化?
plist,喜好設定,索引值歸檔,sqlite3,core data五種。前面4種,都只是存oc類型的對象資料,比如:NSNumber NSString NSData NSArray NSDictionary等,而資料庫呢,首先是查有沒有那個庫,沒有則建立一個庫,
然後在庫裡面建立表,在表裡面再進行具體的資料存放區,最後還要關閉資料庫,資料庫一般是用c寫,但蘋果他有自己的一個庫,就叫fmdb ,是oc 版本的,
用起來更加面相對象,也是c 封裝後的,前面4種都是普通物件類型,而core data不是,可以存的範圍很廣,但不太好操作,穩定性差,不是一個庫,只是一個檔案罷了
6資料傳值怎麼傳,又有哪些方式?
block,通知,代理,屬性,單例等。
iOS技術面試04:資料存放區