ios序列化

你于写数据需要本地存储时,即将你的数据写到硬盘上的时候,你就必须对他进行序列化,转换成二进制文件,从而便于在磁盘上的读写,同理在取出的时候必须将其在反序列化,这样才能将数据读出来,就好比加密和解密的过程。


NSUserDefaults只支持: NSString, NSNumber, NSDate, NSArray, NSDictionary.
如果把一个自定义的类存到一个NSArray里,然后再存到NSUserDefaults里也是不能成功的。
那怎么办呢?
让这个自定义类实现<NSCoding>协议中的- (id) initWithCoder: (NSCoder *)coder方法和- (void) encodeWithCoder: (NSCoder *)coder方法(obj-c的协议protocol就是java的接口interface,就是C++的纯虚函数),然后把该自定义的类对象编码到NSData中,再从NSUserDefaults中进行读取。

假设有这样一个简单的类对象

view plaincopy to clipboardprint?
@interface BusinessCard : NSObject <NSCoding>{  
    NSString *_firstName;  
    NSString *_lastName;  
}  
@property (nonatomic, retain) NSString *_firstName;  
@property (nonatomic, retain) NSString *_lastName;  
@end;  

@implementation BusinessCard  
@synthesize _firstName, _lastName;  
- (void)dealloc{  
    [_firstName release];  
    [_lastName release];  
    [super dealloc];  
}  
- (id) initWithCoder: (NSCoder *)coder  
{  
if (self = [super init])  
    {  
        self._firstName = [coder decodeObjectForKey:@"_firstName"];  
        self._lastName = [coder decodeObjectForKey:@"_lastName"];  
    }  
return self;  
}  
- (void) encodeWithCoder: (NSCoder *)coder  
{  
    [coder encodeObject:_firstName forKey:@"_firstName"];  
    [coder encodeObject:_lastName forKey:@"_lastName"];  

}  

@end
然后再存取时通过NSData做载体:
BusinessCard *bc = [[BusinessCard alloc] init];  
NSUserDefaults *ud = [NSUserDefaults standardUserDefaults];  
NSData *udObject = [NSKeyedArchiver archivedDataWithRootObject:bc];  
[ud setObject:udObject forKey:@"myBusinessCard"];  
[bc release];  
udObject = nil;  
udObject = [ud objectForKey:@"myBusinessCard"];  
bc = [NSKeyedUnarchiver unarchiveObjectWithData:udObject] ;  
C++ 序列化是将对象转换为字节流的过程,这样可以将对象存储到磁盘或网络中,并在需要时重新读取。以下是一个简单的示例: ```c++ #include <iostream> #include <fstream> #include <string> class Person { public: Person() = default; Person(std::string name, int age) : m_name(name), m_age(age) {} std::string getName() const { return m_name; } int getAge() const { return m_age; } friend std::ostream& operator<<(std::ostream& os, const Person& p) { os << "Name: " << p.m_name << ", Age: " << p.m_age << std::endl; return os; } friend std::istream& operator>>(std::istream& is, Person& p) { is >> p.m_name >> p.m_age; return is; } private: std::string m_name; int m_age; }; int main() { // 创建 Person 对象 Person p1("Tom", 30); // 将对象序列化写入文件 std::ofstream ofs("person.dat", std::ios::binary); ofs.write(reinterpret_cast<const char*>(&p1), sizeof(p1)); ofs.close(); // 从文件中读取序列化的对象 std::ifstream ifs("person.dat", std::ios::binary); Person p2; ifs.read(reinterpret_cast<char*>(&p2), sizeof(p2)); ifs.close(); std::cout << p2; return 0; } ``` 在这个示例中,我们定义了一个名为 `Person` 的类,它有两个成员变量:姓名和年龄。我们还重载了输入输出运算符,以便我们可以将对象输出到控制台或从控制台读取对象。 在 `main` 函数中,我们首先创建一个 `Person` 对象 `p1`,然后将其序列化写入名为 `person.dat` 的二进制文件中。接下来,我们从文件中读取序列化的对象并将其存储在 `p2` 中。最后,我们将 `p2` 输出到控制台。 请注意,在将对象写入文件时,我们使用了 `reinterpret_cast` 将指向 `Person` 对象的指针转换为 `char` 指针。同样,在从文件读取对象时,我们也使用了 `reinterpret_cast` 将 `char` 指针转换为 `Person` 对象指针。这是因为我们正在处理字节流,而不是对象本身。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值