iOS属性列表序列化

可序列化的Objective-C类如下:

·     NSArray

·     NSMutableArray

·     NSDictionary

·     NSMutableDictionary

·     NSData

·     NSMutableData

·     NSString

·     NSMutableString

·     NSNumber

·     NSDate

上述类实例都可通过writeToFile:atomically:方法进行序列化。

 

属性列表非常方便,只要字典或数组仅包含特定可序列化的对象,就可以将NSDictionary和NSArray实例写入属性列表以及从属性列表创建它们。

 

但是对于自定义的类myClass,要使用属性列表序列化,有如下步骤:

      1.      将每个字段中的值复制到NSDictionary实例中;

      2.      将NSDictionary实例添加到另一个数组;

      3.      将该数组写入属性列表文件。

显然,如果不做大量转换工作就根本不能为自定义类使用属性列表序列化。

#pragma mark -
#pragma mark 将以myClass为元素的数组转成以词典为元素
-(NSArray *)transformDataObjectToDic:(NSArray *)itemAry
{
    
    if (itemAry == nil)
    {
        return nil;
    }
    
    NSMutableArray * dicMutAry = [NSMutableArray arrayWithCapacity:5];
    // 获取数组,数组成员对应myClass的属性。
    for (int i = 0 ; i<[itemAry count]; i++)
    {
        NSMutableDictionary * mutDic = [NSMutableDictionary dictionaryWithCapacity:5];

        id item = [itemAry objectAtIndex:i];
        NSArray * atrAry = [self traversalObjAtr:item];
        if (atrAry != nil)
        {
            for (int j =0 ; j<[atrAry count]; j++)
            {
                NSString * keyStringByClassAtr = [atrAry objectAtIndex:j];
                NSString * methodName = [NSString stringWithFormat:@"%@", keyStringByClassAtr];
                if ([item respondsToSelector:NSSelectorFromString(methodName)])
                {
                    NSString * artValue = [item performSelector:NSSelectorFromString(methodName) withObject:nil];
                    if (artValue != nil) {
                        [mutDic setObject:artValue forKey:keyStringByClassAtr];
                    }
                }
            }
            
        }
        
        [dicMutAry addObject:mutDic];
    }
    
    return dicMutAry;
}
#pragma mark -
#pragma mark 遍历并获取自定义类的各个字段
- (NSArray *)traversalObjAtr:(id)_class_object
{
    
    NSMutableArray *itemMutAry = [[[NSMutableArray alloc] initWithCapacity:6] autorelease];
    @synchronized(self) {         
        int i;
        unsigned int propertyCount = 0;
        
        objc_property_t *propertyList = class_copyPropertyList([_class_object class], &propertyCount);
        
        
        for ( i=0; i < propertyCount; i++ ) {
            
            objc_property_t *thisProperty = propertyList + i;
            const char* propertyName = property_getName(*thisProperty);
            
            NSString *propertyNameString = [NSString stringWithCString:propertyName encoding:NSUTF8StringEncoding];            
            
            [itemMutAry addObject:propertyNameString];
            thisProperty = nil;
        }
        free(propertyList);
    }
    return [[[NSArray alloc] initWithArray:itemMutAry] autorelease];
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C知道:在C++中,可以使用不同的方法实现序列化和反序列化。以下是两个常用的方法: 1. 使用流(Stream): 使用流是一种常见的序列化和反序列化方法。你可以使用`std::ofstream`将数据写入文件,然后使用`std::ifstream`从文件中读取数据。这种方法可以用于基本类型、自定义结构体和类对象的序列化和反序列化。 示例代码如下: ```cpp #include <iostream> #include <fstream> struct MyData { int value1; float value2; }; int main() { // 序列化 MyData data; data.value1 = 42; data.value2 = 3.14f; std::ofstream outfile("data.bin", std::ios::binary); outfile.write(reinterpret_cast<char*>(&data), sizeof(MyData)); outfile.close(); // 反序列化 MyData loadedData; std::ifstream infile("data.bin", std::ios::binary); infile.read(reinterpret_cast<char*>(&loadedData), sizeof(MyData)); infile.close(); std::cout << "Loaded data: " << loadedData.value1 << ", " << loadedData.value2 << std::endl; return 0; } ``` 2. 使用序列化库: 另一种常用的方法是使用现有的序列化库,如Google Protocol Buffers、JSONcpp、Boost.Serialization等。这些库提供了更高级的序列化和反序列化功能,并支持更复杂的数据结构和对象。 以Google Protocol Buffers为例,你需要首先定义一个Protocol Buffers的消息(Message),然后使用Protocol Buffers的编译器生成相应的C++代码。然后,你可以使用生成的代码进行序列化和反序列化操作。 示例代码如下: ```cpp // 定义 Protocol Buffers 消息 syntax = "proto3"; message MyData { int32 value1 = 1; float value2 = 2; } // 使用 Protocol Buffers 编译器生成 C++ 代码 protoc -I=./ --cpp_out=./ ./data.proto ``` ```cpp #include <iostream> #include "data.pb.h" int main() { // 序列化 MyData data; data.set_value1(42); data.set_value2(3.14f); std::string serializedData = data.SerializeAsString(); // 反序列化 MyData loadedData; loadedData.ParseFromString(serializedData); std::cout << "Loaded data: " << loadedData.value1() << ", " << loadedData.value2() << std::endl; return 0; } ``` 这是一个使用Google Protocol Buffers的简单示例,你可以根据具体的需求和选择使用适合的序列化库。 希望这些信息对你有帮助!如果你有任何进一步的问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值