封装一个计算文件大小的功能

简介: 封装一个计算文件大小的功能

封装一个计算文件大小的功能


第一步:

80d80f54a9d222c8e88a56622f6319eb.png

Snip20161031_5.png

第二步:

eb0b7055d869e330f23d40955e6ffdf3.png

Snip20161031_6.png

第三步:

4a9d3c8d5bf3e96e569a4c37a2b446d2.png

Snip20161031_7.png


#import <Foundation/Foundation.h>
@interface NSString (LYWExtension)
- (unsigned long long)fileSize;
@end
第四步:

cc32c9829e02956388b647ed0856aec7.png

Snip20161031_14.png


#import "NSString+LYWExtension.h"
@implementation NSString (LYWExtension)
- (unsigned long long)fileSize
{
    // 总大小 
    unsigned long long size = 0;
    // 文件管理者
    NSFileManager *mgr = [NSFileManager defaultManager];
    // 是否为文件夹
    BOOL isDirectory = NO;
    // 路径是否存在
    BOOL exists = [mgr fileExistsAtPath:self isDirectory:&isDirectory];
    if (!exists) return size;
    if (isDirectory) { // 文件夹
        // 获得文件夹的大小  == 获得文件夹中所有文件的总大小
        NSDirectoryEnumerator *enumerator = [mgr enumeratorAtPath:self];
        for (NSString *subpath in enumerator) {
            // 全路径
            NSString *fullSubpath = [self stringByAppendingPathComponent:subpath];
            // 累加文件大小
            size += [mgr attributesOfItemAtPath:fullSubpath error:nil].fileSize;
        }
    } else { // 文件
        size = [mgr attributesOfItemAtPath:self error:nil].fileSize;
    }
    return size;
}
@end

初步简单使用

ae927630e23dcf8bfea2fedc91ffff9d.png

Snip20161031_13.png

效果:


806e6973fdd7d284566195e88145de10.jpg

regi.gif

我们打开沙河查看文件大小,对比。

5141822713317448a387695e811a0277.png

Snip20161031_15.png

下面我们就让它显示成多少M  多少G

27994c1b294b60b6902ae642f6e2fe25.png

Snip20161031_17.png


7473a2a7d8508ed1d3a499d110ca2e3c.png

Snip20161031_18.png

清除缓存

34939e7d2d1a457014b5f88ad2fd9d59.png

Snip20161031_19.png


代码附上


#import "SsrtextViewController.h"
#import "NSString+LYWExtension.h"
#import "SVProgressHUD.h"
#import "SDImageCache.h"
@interface SsrtextViewController ()
@property (strong, nonatomic)UILabel *lab;
@end
@implementation SsrtextViewController
- (void)viewDidLoad
{
    [super viewDidLoad];
    _lab = [[UILabel alloc] initWithFrame:CGRectMake(0, 100, 300, 100)];
    _lab.backgroundColor = RandomColor;
    _lab.textAlignment = NSTextAlignmentCenter;
    [self.view addSubview:_lab];
    _lab.text = @"清除缓存(正在计算缓存大小...)";
    // 在子线程计算缓存大小
    dispatch_async(dispatch_get_global_queue(0, 0), ^{
        // 获得缓存文件夹路径(这个是我们自己的缓存文件)
        unsigned long long size = [NSSearchPathForDirectoriesInDomains(NSCachesDirectory, NSUserDomainMask, YES).lastObject stringByAppendingPathComponent:@"Custom"].fileSize;
        //这个是SDWebImage缓存的文件
        size += [SDImageCache sharedImageCache].getSize;
        NSString *sizeText = nil;
        if (size >= pow(10, 9)) { // size >= 1GB
            sizeText = [NSString stringWithFormat:@"%.2fGB", size / pow(10, 9)];
        } else if (size >= pow(10, 6)) { // 1GB > size >= 1MB
            sizeText = [NSString stringWithFormat:@"%.2fMB", size / pow(10, 6)];
        } else if (size >= pow(10, 3)) { // 1MB > size >= 1KB
            sizeText = [NSString stringWithFormat:@"%.2fKB", size / pow(10, 3)];
        } else { // 1KB > size
            sizeText = [NSString stringWithFormat:@"%zdB", size];
        }
        //下面也是一种换算文件大小的方式
        //            if (size >= 1000 * 1000 * 1000) { // size >= 1GB
        //                sizeText = [NSString stringWithFormat:@"%.2fGB", size / 1000.0 / 1000.0 / 1000.0];
        //            } else if (size >= 1000 * 1000) { // 1GB > size >= 1MB
        //                sizeText = [NSString stringWithFormat:@"%.2fMB", size / 1000.0 / 1000.0];
        //            } else if (size >= 1000) { // 1MB > size >= 1KB
        //                sizeText = [NSString stringWithFormat:@"%.2fKB", size / 1000.0];
        //            } else { // 1KB > size
        //                sizeText = [NSString stringWithFormat:@"%zdB", size];
        //            }
        // 生成文字
        NSString *text = [NSString stringWithFormat:@"清除缓存(%@)", sizeText];
        // 回到主线程
        dispatch_async(dispatch_get_main_queue(), ^{
            // 设置文字
            _lab.text = text;
            // 添加手势监听器
            [_lab addGestureRecognizer:[[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(clearCache)]];
        });
    });
}
/**
 *  清除缓存
 */
- (void)clearCache
{
    // 弹出指示器
    [SVProgressHUD showInfoWithStatus:@"正在清除缓存..."];
    // 删除SDWebImage的缓存
    [[SDImageCache sharedImageCache] clearDiskOnCompletion:^{
        // 删除自定义的缓存
        dispatch_async(dispatch_get_global_queue(0, 0), ^{
            //文件管理者
            NSFileManager *mgr = [NSFileManager defaultManager];
            //移除该文件夹
            [mgr removeItemAtPath:[NSSearchPathForDirectoriesInDomains(NSCachesDirectory, NSUserDomainMask, YES).lastObject stringByAppendingPathComponent:@"Custom"] error:nil];
            //再创建该文件夹
            [mgr createDirectoryAtPath:[NSSearchPathForDirectoriesInDomains(NSCachesDirectory, NSUserDomainMask, YES).lastObject stringByAppendingPathComponent:@"Custom"] withIntermediateDirectories:YES attributes:nil error:nil];
            // 所有的缓存都清除完毕
            dispatch_async(dispatch_get_main_queue(), ^{
                // 隐藏指示器
                [SVProgressHUD dismiss];
                // 设置文字
                _lab.text = @"清除缓存(0B)";
            });
        });
    }];
}

我们再来对比看一下

image.png


相关文章
|
23天前
|
监控 开发者
确保动态导入模块按正确顺序加载
【10月更文挑战第12天】 在复杂应用开发中,确保动态导入模块按正确顺序加载至关重要,直接影响应用性能、功能和稳定性。本文深入探讨了动态模块加载顺序的影响因素、解决方案及实践案例,提供了详细的策略和方法,帮助开发者有效管理模块加载顺序,提升应用质量。
|
5月前
|
人工智能 运维 Serverless
函数计算产品使用问题之上传模型文件占用的是什么空间
函数计算产品作为一种事件驱动的全托管计算服务,让用户能够专注于业务逻辑的编写,而无需关心底层服务器的管理与运维。你可以有效地利用函数计算产品来支撑各类应用场景,从简单的数据处理到复杂的业务逻辑,实现快速、高效、低成本的云上部署与运维。以下是一些关于使用函数计算产品的合集和要点,帮助你更好地理解和应用这一服务。
107 2
|
5月前
|
运维 Serverless API
函数计算产品使用问题之创建层如何设置才能支持ffmpeg
函数计算产品作为一种事件驱动的全托管计算服务,让用户能够专注于业务逻辑的编写,而无需关心底层服务器的管理与运维。你可以有效地利用函数计算产品来支撑各类应用场景,从简单的数据处理到复杂的业务逻辑,实现快速、高效、低成本的云上部署与运维。以下是一些关于使用函数计算产品的合集和要点,帮助你更好地理解和应用这一服务。
|
6月前
|
缓存 前端开发 算法
前端需要加载一个大体积的文件时,可以这么优化
前端需要加载一个大体积的文件时,可以这么优化
|
6月前
|
存储 图形学 Android开发
Unity 数据读取|(一)宏的定义和资源路径
Unity 数据读取|(一)宏的定义和资源路径
|
JSON 算法 Java
项目中不同位置资源文件读取的几种方式
项目中不同位置资源文件读取的几种方式
51 0
|
SQL 前端开发 Java
扩展MP提供的方法、实现文件上传功能
MP接口方法扩展,文件上传功能实现
191 0
扩展MP提供的方法、实现文件上传功能
|
存储 安全 JavaScript
请求合并的 3 种方式,大大提高接口性能!
将相似或重复请求在上游系统中合并后发往下游系统,可以大大降低下游系统的负载,提升系统整体吞吐率。文章介绍了 hystrix collapser、ConcurrentHashMultiset、自实现BatchCollapser 三种请求合并技术,并通过其具体实现对比各自适用的场景。
|
存储 XML 缓存
请求合并的 3 种方式,大大提高接口性能。。。
请求合并的 3 种方式,大大提高接口性能。。。
344 0
|
Java 数据库连接 Spring
加载、读取资源的方式(底层都是以流的方式获取资源,具体是通过类加载器进行加载,通过流的方式进行读取,从而获取资源)
加载、读取资源的方式(底层都是以流的方式获取资源,具体是通过类加载器进行加载,通过流的方式进行读取,从而获取资源)
117 0