У меня есть собственный класс для отображения, как показано ниже.
class UserSaved {
var Id : String
var UserName : String
var profileURL : String
var fullNameUser : String
func encode(with aCoder: NSCoder) {
aCoder.encode(self.Id, forKey: "Id")
aCoder.encode(self.UserName, forKey: "UserName")
aCoder.encode(self.profileURL, forKey: "profileURL")
aCoder.encode(self.fullNameUser, forKey: "fullNameUser")
}
required init?(coder aDecoder: NSCoder) {
self.Id = aDecoder.decodeObject(forKey: "Id") as! String
self.UserName = aDecoder.decodeObject(forKey: "UserName") as! String
self.profileURL = aDecoder.decodeObject(forKey: "profileURL") as! String
self.fullNameUser = aDecoder.decodeObject(forKey: "fullNameUser") as! String
// self.init(my_id: self.Id, my_username: self.UserName, profile_url: self.profileURL, full_name: self.fullNameUser)
}
init(my_id: String, my_username: String, profile_url: String, full_name : String) {
self.Id = my_id
self.UserName = my_username
self.profileURL = profile_url
self.fullNameUser = full_name
}
}
Теперь я добавляю объект другой модели в два разных массива, как показано ниже, ниже в обоих массивах могут быть общие записи
//////array 1
let arrayTemp = dic.value(forKey: "data") as! NSArray
for i in 0..<arrayTemp.count {
let dic = arrayTemp.object(at: i) as! NSDictionary
let strId = String(dic.value(forKey: "pk") as! Int)
let instaName = dic.value(forKey: "username") as! String
let profileURL = dic.value(forKey: "profile_pic_url") as! String
let fullName = dic.value(forKey: "full_name") as! String
let person1 = UserSaved(insta_id: strId, insta_username: instaName,profile_url: profileURL,full_name: fullName)
self.arr1.append(person1)
}
//////array 2
let arrayTemp = dic.value(forKey: "data") as! NSArray
for i in 0..<arrayTemp.count {
let dic = arrayTemp.object(at: i) as! NSDictionary
let strId = String(dic.value(forKey: "pk") as! Int)
let instaName = dic.value(forKey: "username") as! String
let profileURL = dic.value(forKey: "profile_pic_url") as! String
let fullName = dic.value(forKey: "full_name") as! String
let person2 = UserSaved(insta_id: strId, insta_username: instaName,profile_url: profileURL,full_name: fullName)
self.arr2.append(person2)
}
Теперь я манипулирую над массивами, используя приведенный ниже код, который прекрасно работает
let setA = Set(self.arr1)
let setB = Set(self.arr2)
let inBothAAndB = setA.intersection(setB)
let inAButNotB = setA.subtracting(setB)
let inBButNotA = setB.subtracting(setA)
Теперь, когда я пытался сохранить массив в пользовательских ошибках, используя NSKeyedArchiver.archivedData
.Это дает мне ошибку, как показано ниже
2018-10-09 12:27:46.375587+0530 Insta_Analytics[12764:181604] *** NSForwarding: warning: object 0x6100000f0500 of class
'Insta_Analytics.UserSaved' does not implement methodSignatureForSelector: -- trouble ahead
Unrecognized selector -[Insta_Analytics.UserSaved replacementObjectForKeyedArchiver:]
2018-10-09 12:27:46.376141+0530 Insta_Analytics[12764:181604]
Unrecognized selector -[Insta_Analytics.UserSaved replacementObjectForKeyedArchiver:]
Вот мой код сохранения массива в userdefaults
let encodedData = NSKeyedArchiver.archivedData(withRootObject: self.arr1)
UserDefaults.standard.set(encodedData, forKey: "arr_store")
Теперь, если я изменю свою пользовательскую модель сопоставления, UserSaved
наследует от NSCoding
и NSObject
.Это работает, но в это время манипулирование данными не работает
ТАК в одно время, работает только одна вещь.Я хочу сохранить свои массивы, используя NSCoding
, в то же время intersection
и subtracting
должны работать