对象数组序列化和反序列化

简介: 对象数组序列化和反序列化

对象数组序列化需要对象实现NSCoding协议:

PPKeyWordEntity.h

#import <Foundation/Foundation.h>


@interface PPKeyWordEntity : NSObject<NSCoding>

@property (nonatomic, strong) NSString *keyword;

- (instancetype)initWithKeyWord:(NSString *)keyWord;
- (void)fillDataWithKeyWord:(NSString *)keyWord;
@end

PPKeyWordEntity.m

#import "PPKeyWordEntity.h"

@implementation PPKeyWordEntity

- (instancetype)init
{
    self = [super init];
    if (self) {

    }
    return self;
}

- (instancetype)initWithKeyWord:(NSString *)keyWord
{
    if (self = [super init]) {
        [self fillDataWithKeyWord:keyWord];
    }
    return self;
}

- (void)fillDataWithKeyWord:(NSString *)keyWord
{
    self.keyword = keyWord;
    if(isCommonUnitEmptyString(keyWord))
    {
        return;
    }
    _keyword = keyWord;
}


-(void)encodeWithCoder:(NSCoder *)aCoder
{
    [aCoder encodeObject:getNotNilString(self.keyword) forKey:@"keyword"];
    [aCoder encodeObject:[NSString stringWithFormat:@"%.0f", self.keywordWidth] forKey:@"keywordWidth"];
}

-(id)initWithCoder:(NSCoder *)aDecoder
{
    if (self=[super init])
    {
        self.keyword = [aDecoder decodeObjectForKey:@"keyword"];
        self.keywordWidth = [[aDecoder decodeObjectForKey:@"keywordWidth"] floatValue];
    }
    return self;
}


@end

获取文件路径:

//  返回文件路径
- (NSString *)getPathWithFileName:(NSString *)fileName
{
    NSString *newFileName = fileName;
    if(isFileHandleEmptyString(fileName))
    {
        newFileName = @"";
    }
    NSString *documents = [NSSearchPathForDirectoriesInDomains(NSCachesDirectory, NSUserDomainMask, YES) lastObject];
    NSString *path = [documents stringByAppendingPathComponent:fileName];
    return path;
}

对象数组序列化:

-(void)storeSearchHistoryListWithIsClearAll:(BOOL)isClearAll
{
    if(isClearAll)
    {
        [self.searchListEntity.searchHistoryList removeAllObjects];
    }
    else if(isEmptyArray(self.searchListEntity.searchHistoryList))
    {
        return;
    }
    [NSKeyedArchiver archiveRootObject:self.searchListEntity.searchHistoryList toFile:[self getPathWithFileName:@"Abc.archiver"]];
}

对象数组反序列化:

- (void)loadSearchHistoryList
{
    [self.searchListEntity.searchHistoryList removeAllObjects];
    NSString *searchHistoryPath = [self getPathWithFileName:@"Abc.archiver"];
    if ([[NSFileManager defaultManager] fileExistsAtPath:searchHistoryPath]) {
        self.searchListEntity.searchHistoryList = [NSKeyedUnarchiver unarchiveObjectWithFile:searchHistoryPath];
    }
    [_searchListEntity updateKeywordLabelWidth];
}
目录
相关文章
|
7天前
|
网络协议 Java API
【Java】序列化和反序列化
【Java】序列化和反序列化
15 4
|
11天前
|
Java 数据安全/隐私保护 Android开发
Java基础21-读懂Java序列化和反序列化(二)
Java基础21-读懂Java序列化和反序列化(二)
16 1
|
11天前
|
XML 存储 Java
Java基础21-读懂Java序列化和反序列化(一)
Java基础21-读懂Java序列化和反序列化(一)
12 1
|
17天前
|
JSON 缓存 Java
【Java基础】 序列化和反序列化
Java中的序列化(Serialization)和反序列化(Deserialization)是将对象和字节流之间进 行相互转换的过程。这两个过程用于保存对象的状态并能够在需要时恢复这些状态。
12 1
|
4天前
|
存储 安全 网络协议
【JAVA反序列化】序列化与反序列化&Java反射&URLDNS链
【JAVA反序列化】序列化与反序列化&Java反射&URLDNS链
|
1月前
使用序列化和反序列化函数archivedDataWithRootObject和unarchivedObjectOfClasses的使用和遇到问题及解决方案
使用序列化和反序列化函数archivedDataWithRootObject和unarchivedObjectOfClasses的使用和遇到问题及解决方案
24 0
|
1月前
|
前端开发 数据库
省市区三级联动数据本地序列化和反序列化
省市区三级联动数据本地序列化和反序列化
22 0
|
1月前
|
存储 XML JSON
数据传输的艺术:深入探讨序列化与反序列化
数据传输的艺术:深入探讨序列化与反序列化
87 0
|
1月前
|
存储 安全 Java
Java一分钟之-Java序列化与反序列化
【5月更文挑战第14天】Java序列化用于将对象转换为字节流,便于存储和网络传输。实现`Serializable`接口使类可被序列化,但可能引发隐私泄露、版本兼容性和性能问题。要避免这些问题,可使用`transient`关键字、控制`serialVersionUID`及考虑使用安全的序列化库。示例代码展示了如何序列化和反序列化对象,强调了循环引用和未实现`Serializable`的错误。理解并妥善处理这些要点对优化代码至关重要。
28 1
|
1月前
|
JSON 安全 Java
Spring Boot 序列化、反序列化
本文介绍了Spring Boot中的序列化和反序列化。Java提供默认序列化机制,通过实现Serializable接口实现对象到字节流的转换。Spring Boot默认使用Jackson处理JSON,可通过注解和配置自定义规则。然而,序列化可能引发安全问题,建议使用白名单、数据校验和安全库。最佳实践包括使用标准机制、自定义规则及注意版本控制。文章还提醒关注性能并提供了相关参考资料。
101 2