NSArray 倒序 输出

今天因为自己一些知识的不了解,导致了开发时间的浪费,现在一个需求记录用户曾使用的历史照片功能,单独在Documents建立了一个文件夹存放用户图片,后来想法是先遍历文件夹下的内容,获取一个数组来进行操作。但是输出的NSArray很纠结,不是倒序排列的,于是乎,想用Plist进行存储,然后再输出下,后来Plist获取的还是正常的先后顺序的数组,后来查询了下NSArray的倒序输出,发现这个,瞬间石化了,绕了非常大的一个弯,中间还遇到NSMutableDic添加替换的问题,才知道相同的key会直接替换掉。基础知识多么重要啊!


NSMutableArray *array = [NSMutableArray arrayWithObjects:@"1",@"2",@"3",nil];

NSArray* reversedArray = [[array reverseObjectEnumerator] allObjects];



解析这个m文件,并思考这个manager需要重点注意的地方 // // SDNDeviceDownloadImageManager.m // Omada // // Created by wanghao on 2025/2/12. // Copyright © 2025 TP-Link. All rights reserved. // #import "SDNDeviceDownloadImageManager.h" #import "TPDataStorage.h" #import "SDWebImageManager.h" #import "DMSDNDeviceImageInfo.h" NSString *const kDeviceDownloadFirstVersion = @"0"; static const NSInteger kSDNDeviceDownloadDefaultCacheMaxCacheAge = 365 * 24 * 60 * 60 * 50; // 50 years static const NSInteger kSDNDeviceDownloadDefaultCacheMinUpdateInterval = 3 * 24 * 60 * 60; // 3 days @interface SDNDeviceDownloadImageManager () @property (nonatomic, readwrite, strong) TPECFetchDeviceIconModule *deviceIconModule; @property (nonatomic, readwrite, strong) TPAbstractHandle *checkDeviceUpdateHandle; @property (nonatomic, readwrite, copy) NSArray<DMSDNDeviceImageInfo *> *updateDeviceImageList; @property (nonatomic, readwrite, strong) SDWebImageDownloader *imageDownloader; @property (nonatomic, readwrite, strong) SDImageCache *imageCache; @property (nonatomic, readwrite, assign) BOOL isDownloading; @end @implementation SDNDeviceDownloadImageManager + (instancetype)sharedInstance { static id instance = nil; static dispatch_once_t onceToken; dispatch_once(&onceToken, ^{ instance = [[self alloc] init]; }); return instance; } - (instancetype)init { self = [super init]; if (self) { self.imageCache = [[SDImageCache alloc]initWithNamespace:@"OmadaDeviceStore"]; self.imageCache.maxCacheAge = kSDNDeviceDownloadDefaultCacheMaxCacheAge; self.imageDownloader = [SDWebImageDownloader sharedDownloader]; self.deviceIconModule = [ALAccountContext sharedInstance].eapCloudClient.fetchDeviceIconModule; self.updateDeviceImageList = [NSArray new]; self.isDownloading = NO; } return self; } - (TPAbstractHandle *)checkDeviceUpgrade { if (self.checkDeviceUpdateHandle) { return self.checkDeviceUpdateHandle; } NSString *currentVersion = [[TSSUserDefaults standardUserDefaults] objectForKey:TPDeviceIconCurrentVersionKey]; if (IsEmptyString(currentVersion)) { currentVersion = kDeviceDownloadFirstVersion; } TPWeakSelf TPQueueHandleFactoryBlock blck1 = ^TPAbstractHandle* (TPQueueHandleBlockContext* context){ TPStrongSelfNoReturn return [_self.deviceIconModule checkNeedUpgradeWithCurrentVersion:currentVersion]; }; TPQueueHandleFactoryBlock blck2 = ^TPAbstractHandle* (TPQueueHandleBlockContext* context){ TPStrongSelfNoReturn if(context.lastResult.success) { BOOL needCheckUp = _self.deviceIconModule.needUpdate; if (needCheckUp) { return [_self.deviceIconModule getDeviceIconWithCurrentVersion:currentVersion]; } } context.stop = YES; context.stopResult = context.lastResult; return nil; }; TPGCDQueueHandle *queueHandle = [[TPGCDQueueHandle alloc] initWithQueue:dispatch_get_main_queue() factoryBlockArray:@[blck1, blck2] timeout:-1]; [queueHandle addCompletionOnMainThread:^(TPHandleResult * _Nonnull result) { TPStrongSelf _self.checkDeviceUpdateHandle = nil; if (result.success) { _self.updateDeviceImageList = _self.deviceIconModule.updateDeviceImageList; if (_self.updateDeviceImageList.count > 0 && _self.deviceIconModule.needUpdate) { [_self downLoadUpdatedDeviceImage]; } } }]; return queueHandle; } - (void)updateCacheInfo { NSTimeInterval lastTime = 0.0; NSNumber *lastShowTimestampObject = [[TSSUserDefaults standardUserDefaults] objectForKey:TPDeviceIconLastUpdateTimeKey]; if (lastShowTimestampObject) { lastTime = [lastShowTimestampObject doubleValue]; } //上次更新时间距离现在超过最小间隔,则重新拉取设备图标 if (lastTime + kSDNDeviceDownloadDefaultCacheMinUpdateInterval < [[NSDate date] timeIntervalSince1970] && !self.isDownloading) { self.isDownloading = YES; [self resetCacheInfo]; [self checkDeviceUpgrade]; } } - (void)resetCacheInfo { [[TSSUserDefaults standardUserDefaults] setObject:kDeviceDownloadFirstVersion forKey:TPDeviceIconCurrentVersionKey]; [[TSSUserDefaults standardUserDefaults] setObject:[NSArray new] forKey:TPDeviceIconMdelListKey]; } - (void)storeDeviceModelList:(NSString *)modelAndVersionKey { if (IsEmptyString(modelAndVersionKey)) { return; } NSArray<NSString *> *imageList = [self deviceIconModelList]; for (NSString *itemImage in imageList) { if ([modelAndVersionKey isEqualToString:itemImage]) { return; } } imageList = [imageList arrayByAddingObject:modelAndVersionKey]; [[TSSUserDefaults standardUserDefaults] setObject:imageList forKey:TPDeviceIconMdelListKey]; } - (void)downLoadUpdatedDeviceImage { self.isDownloading = YES; __block int handledCount = 0; for (DMSDNDeviceImageInfo *deviceImageInfo in self.updateDeviceImageList) { if ([self.imageCache diskImageExistsWithKey:deviceImageInfo.modelAndVersionKey] || deviceImageInfo.imageDownLoadURL == nil) { [self storeDeviceModelList:deviceImageInfo.modelAndVersionKey]; handledCount++; [self updateControllerVersionWithTotalCount:handledCount]; continue; } TPWeakSelf [self.imageDownloader downloadImageWithURL:deviceImageInfo.imageDownLoadURL options:0 progress:nil completed:^(UIImage *image, NSData *data, NSError *error, BOOL finished) { TPStrongSelf handledCount++; [_self.imageCache storeImage:image recalculateFromImage:NO imageData:data forKey:deviceImageInfo.modelAndVersionKey toDisk:YES]; [self storeDeviceModelList:deviceImageInfo.modelAndVersionKey]; [[TSSUserDefaults standardUserDefaults] setObject:@([[NSDate date] timeIntervalSince1970]) forKey:TPDeviceIconLastUpdateTimeKey]; [_self updateControllerVersionWithTotalCount:handledCount]; }]; } } - (void)updateControllerVersionWithTotalCount:(int)totalCount { if (totalCount == self.updateDeviceImageList.count) { NSString *curVersion = [ALAccountContext sharedInstance].eapCloudClient.fetchDeviceIconModule.controllerVersion; [[TSSUserDefaults standardUserDefaults] setObject:curVersion forKey:TPDeviceIconCurrentVersionKey]; } } - (BOOL)hasDownLoadDevice:(NSString *)modelAndVersionKey { if (IsEmptyString(modelAndVersionKey)) { return NO; } return [self.imageCache diskImageExistsWithKey:modelAndVersionKey];; } - (UIImage *)deviceImage:(NSString *)deviceModel andModelVersion:(NSString *)modelVersion { NSString *modelAndVersionKey = [DMSDNDeviceImageInfo modelAndVersionKeyFromModel:deviceModel andVersion:modelVersion]; if (IsEmptyString(modelAndVersionKey)) { return nil; } UIImage *image = [self deviceImageFromModelAndVersionKey:modelAndVersionKey]; UIImage *finalImage = image == nil ? [self vigiDeviceImage:modelAndVersionKey] : image; if (finalImage == nil) { [self updateCacheInfo]; } return finalImage; } - (UIImage *)deviceImageFromModelAndVersionKey:(NSString *)modelAndVersionKey { UIImage *image = [self.imageCache imageFromDiskCacheForKey:modelAndVersionKey]; return image; } - (NSArray<NSString *> *)deviceIconModelList { NSArray<NSString *> *deviceModelList = [[TSSUserDefaults standardUserDefaults] objectForKey:TPDeviceIconMdelListKey]; return deviceModelList == nil ? [NSArray new] : deviceModelList; } - (UIImage *)vigiDeviceImage:(NSString *)modelAndVersionKey { NSArray<NSString *> *modelList = [self deviceIconModelList]; modelList = [modelList sortedArrayUsingComparator:^NSComparisonResult(NSString * obj1, NSString * obj2) { return obj1.length < obj2.length; }]; for (NSString *modelStr in modelList) { if (!IsEmptyString(modelAndVersionKey) && [modelAndVersionKey containsString:modelStr]) { return [self deviceImageFromModelAndVersionKey:modelStr]; } } return nil; } @end
最新发布
10-31
评论 2
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值