iOS实现一个强大的本地状态记录容器

我们开发中经常会遇到这样的场景,就是我们客户端用户进行了某个操作,这个操作影响了数据的状态,但是我们又不方便重新请求一次数据,

这个时候,就需要我们记录一下本地状态在内存中,随着业务越来越复杂,要记录的状态也越来越多,如果状态都是对应同一个ID还比较好处理,如果不同的状态对应的ID都不是同一个,则管理起来比较麻烦,比如,有些情况下,我们不能根据某条数据的内容ID,而要记录到实例队形的颗粒度,这个时候,就需要我们支持不同的ID来记录本地状态了,

一下是我的处理思路,

我们可以创建一个单例,单例中有一个数组,数组中

有字典,字典中包含三个键: type:对应 id的类型,

ID,对应ID的值,data,对应我们要记录的数据,通常情况下是一个字典,对应我们要记录的状态字段和值,我们获取记录的状态的时候,传入一个ID数组,就会遍历整个容器,获取到对应的ID下的所有数据,如下所示

{ "type":"contentId", "id": "xxxx" "data": { "hasComment":"0" } }, { "type":"userId", "id": "xxxx" "data": { "hasComment":"1" } }, { "type":"xxxid", "id": "xxxx" "data": { "hasSee":"1" } },

具体代码如下

保存本地数据的实现,单例中

复制代码
- (void)updateData:(NSArray *)newData {
    NSMutableArray *keysToUpdate = [[NSMutableArray alloc] init];
    
    for (NSDictionary *data in newData) {
        NSString *IDString = [data stringForKey:@"id"];
        NSString *type = [data stringForKey:@"type"];
        NSDictionary *templateData = [data dictionaryForKey:@"data"];
        
        if (IDString.length <= 0 || type.length <= 0 || templateData.count <= 0) continue;
        
        NSUInteger synchronizedTemplateDataToUpdateIndex = 0;
        NSDictionary *synchronizedTemplateDataToUpdate = nil;
        
        for (NSUInteger i = 0; i < self.synchronizedDataList.count; i++) {
            NSDictionary *synchronizedData = [self.synchronizedDataList objectAtIndex:i];
            NSString *synchronizedIDString = [synchronizedData stringForKey:@"id"];
            NSString *synchronizedType = [synchronizedData stringForKey:@"type" ];
            NSMutableDictionary *synchronizedTemplateData = [[synchronizedData dictionaryForKey:@"data"] mutableCopy];
            
            if (![synchronizedIDString isEqualToString:IDString] || ![synchronizedType isEqualToString:type]) continue;
            
            for (NSString *key in templateData.allKeys) {
                NSString *value = [templateData stringForKey:key];
                
                [synchronizedTemplateData setObject:value forKey:key];
            }
            
            synchronizedTemplateDataToUpdateIndex = i;
            synchronizedTemplateDataToUpdate = @{
                @"id": IDString,
                @"type": type,
                @"data": synchronizedTemplateData
            };
            
            break;
        }
        
        if (synchronizedTemplateDataToUpdate == nil) {
            [self.synchronizedDataList addObject:data];
        } else {
            [self.synchronizedDataList removeObjectAtIndex:synchronizedTemplateDataToUpdateIndex];
            [self.synchronizedDataList addObject:synchronizedTemplateDataToUpdate];
        }
        
        [keysToUpdate addObject:@{
            @"id": IDString ?: @"",
            @"type": type ?: @""
        }];
    }

更新本地数据

复制代码
   NSMutableDictionary *data = [NSMutableDictionary dictionary];
        data[@"hasCancelRecommend"] = @(NO);
        NSString *addressId = [NSString stringWithFormat:@"%p", model];
        NSDictionary *updateData = @{
            @"id": addressId ?: @"",
            @"type": @"modelAddress",
            @"data": data
        };
            [[LBDataSyncDataManager sharedManager] updateData:@[updateData]];

根据所有ID获取本地数据, 单例的实例方法

复制代码
- (NSDictionary *)getMemoryDataWithKeys:(NSArray *)keys {
    NSMutableDictionary *getSynchronizedData = [[NSMutableDictionary alloc] init];
    
    for (NSString *key in keys) {
        for (NSDictionary *synchronizedData in self.synchDataList) {
            NSString *synchronizedIDString = [synchronizedData stringForKey:@"id"];
            
            if (![key isEqualToString:synchronizedIDString]) continue;
            
            [getSynchronizedData addEntriesFromDictionary:[synchronizedData dictionaryForKey:@"data"]];
            
            break;
        }
    }
    
    return getSynchronizedData;
}

调用,获取到所有的本地状态

复制代码
    NSString *cardInstanceAddress = [NSString stringWithFormat:@"%p", instance];
    
    NSDictionary *mergedData = [[LBDataSyncDataManager sharedManager] getMergedDataWithKeys:@[contentID ?: @"", publicID ?: @"", Address ?: @""]];
相关推荐
咕噜签名分发冰淇淋1 小时前
苹果ios的系统app应用WebClip免签应用开源及方式原理
ios·开源·cocoa
2501_915106325 小时前
App Store 软件上架全流程详解,iOS 应用发布步骤、uni-app 打包上传与审核要点完整指南
android·ios·小程序·https·uni-app·iphone·webview
开开心心loky5 小时前
[iOS] ViewController 的生命周期
macos·ui·ios·objective-c·cocoa
2501_9160137410 小时前
App 上架全流程指南,iOS App 上架步骤、App Store 应用发布流程、uni-app 打包上传与审核要点详解
android·ios·小程序·https·uni-app·iphone·webview
牛蛙点点申请出战10 小时前
仿微信语音 WaveView 实现
android·前端·ios
TheLittleBoy12 小时前
iOS 26支持的设备列表
ios·ios 26
Magnetic_h12 小时前
【iOS】block复习
笔记·macos·ios·objective-c·cocoa
2501_9159184120 小时前
Web 前端可视化开发工具对比 低代码平台、可视化搭建工具、前端可视化编辑器与在线可视化开发环境的实战分析
前端·低代码·ios·小程序·uni-app·编辑器·iphone
2501_9151063220 小时前
iOS 使用记录和能耗监控实战,如何查看电池电量消耗、App 使用时长与性能数据(uni-app 开发调试必备指南)
android·ios·小程序·uni-app·cocoa·iphone·webview
凉白开<--21 小时前
mardown-it 有序列表ios序号溢出解决办法
ios·vue