Java【代码 14】一个用于判断磁盘空间和分区表是否需要清理的工具类

一个用于判断磁盘空间和分区表是否需要清理的工具类

1.依赖

        <!--hutool工具箱-->
        <dependency>
            <groupId>cn.hutool</groupId>
            <artifactId>hutool-all</artifactId>
            <version>5.6.6</version>
        </dependency>

2.核心代码

  • 根据路径获取磁盘空间数据
  /**
     * 根据路径获取磁盘空间数据
     *
     * @param path 路径
     * @return 磁盘空间数据
     */
    public Map<String, Object> queryDiskSpaceDataByPath(String path) {
        File file = new File(path);
        long totalSpace = file.getTotalSpace();
        long freeSpace = file.getFreeSpace();
        long freeSpaceLong = freeSpace / 1024 / 1024 / 1024;
        long totalSpaceLong = totalSpace / 1024 / 1024 / 1024;
        double freeRate = 0.0;
        if (totalSpaceLong > 1) {
            freeRate = freeSpaceLong * 1.0 / totalSpaceLong * 100;
        }
        // 数据封装
        Map<String, Object> diskDataMap = new HashMap<>(4);
        diskDataMap.put("path", path);
        diskDataMap.put("diskSpace", "磁盘剩余及总大小[" + freeSpaceLong + "G/" + totalSpaceLong + "G]");
        diskDataMap.put("diskUsageRate", "磁盘剩余率[" + String.format("%.2f", freeRate) + "%]");
        return diskDataMap;
    }
  • 根据参数判断当前表是否需要清理分区
    /**
     * 根据参数判断当前表是否需要清理分区
     *
     * @param partitionDataMap 表的分区信息
     * @param retentionYears   存储年限
     * @return 包含判断结果的表分区信息
     */
    public boolean toDetermineIfTableNeedsToBeClearedUp(Map<String, Object> partitionDataMap, int retentionYears) {
        String partitionType = MapUtils.getString(partitionDataMap, "partitionType");
        String partitionMin = MapUtils.getString(partitionDataMap, "partitionMin");
        // 根据type获取差值
        long differenceValue = getDateDifferenceValueByParam(partitionType, partitionMin);
        boolean isToBe = determineIfTableNeedsToBeClearedUp(partitionType, differenceValue, retentionYears);
        partitionDataMap.put("isToClearedUp", isToBe);
        return isToBe;
    }
  • 根据参数获取差值【跟当前年月】
    /**
     * 根据参数获取差值
     *
     * @param type 类型 year month day
     * @param min  最小分区值【最早分区】
     * @return 差值
     */
    private long getDateDifferenceValueByParam(String type, String min) {
        long differenceValue = 0;
        switch (type) {
            case "year":
                differenceValue = DateUtil.betweenYear(new Date(), DateUtil.parse(min, "yyyy"), false);
                break;
            case "month":
                differenceValue = DateUtil.betweenMonth(new Date(), DateUtil.parse(min, "yyyyMM"), false);
                break;
            case "day":
                differenceValue = DateUtil.betweenDay(new Date(), DateUtil.parse(min, "yyyyMMdd"), false);
                break;
            default:
                break;
        }
        return differenceValue;
    }
  • 根据参数判断大小【判断差值是否大于0】
    /**
     * 根据参数判断大小
     *
     * @param type            类型 year month day
     * @param differenceValue 差值
     * @param retentionYears  比对值
     * @return 是否大于
     */
    private boolean determineIfTableNeedsToBeClearedUp(String type, long differenceValue, int retentionYears) {
        boolean isToBe = false;
        switch (type) {
            case "year":
                isToBe = differenceValue > retentionYears;
                break;
            case "month":
                isToBe = differenceValue > (retentionYears * 12);
                break;
            case "day":
                isToBe = differenceValue > (retentionYears * 365);
                break;
            default:
                break;
        }
        return isToBe;
    }

  • 获取需要调整开始时间的分区【临界分区】
    /**
     * 获取需要调整开始时间的分区
     *
     * @param partitionDataMap 表的分区信息
     * @param retentionYears   存储年限
     * @return 调整开始时间的分区
     */
    public String getAdjustmentPartitionName(Map<String, Object> partitionDataMap, int retentionYears) {
        // 解析参数
        String partitionType = MapUtils.getString(partitionDataMap, "partitionType");
        String partitionPrefix = MapUtils.getString(partitionDataMap, "partitionPrefix");
        String partitionMax = MapUtils.getString(partitionDataMap, "partitionMax");
        // 获取需要调整的分区名称
        String adjustmentPartition = getAdjustmentPartitionName(partitionType, partitionMax, retentionYears);
        return partitionPrefix + adjustmentPartition;
    }
  • 生成要清理的分区列表【需要删除的分区不包含临界分区】
    /**
     * 生成要清理的分区列表
     *
     * @param partitionDataMap 表的分区信息
     * @param retentionYears   存储年限
     * @return 要清理的分区列表
     */
    public List<String> getClearedUpPartitionTableNames(Map<String, Object> partitionDataMap, int retentionYears) {
        // 解析参数
        String partitionType = MapUtils.getString(partitionDataMap, "partitionType");
        String partitionMin = MapUtils.getString(partitionDataMap, "partitionMin");
        String partitionMax = MapUtils.getString(partitionDataMap, "partitionMax");
        // 获取需要调整的分区名称
        String adjustmentPartition = getAdjustmentPartitionName(partitionType, partitionMax, retentionYears);
        // 生成清理分区列表
        return getClearedUpListByParam(partitionType, adjustmentPartition, partitionMin);
    }
  • 根据参数获取调整分区名称(调整分区的开始时间)
    /**
     * 根据参数获取调整分区名称(调整分区的开始时间)
     *
     * @param type           分区类型 year month day
     * @param partitionMax   最大分区
     * @param retentionYears 存储年限
     * @return 需要调整的分区名称
     */
    private String getAdjustmentPartitionName(String type, String partitionMax, int retentionYears) {
        String adjustPartitionName = "";
        switch (type) {
            case "year":
                adjustPartitionName = DateUtil.format(DateUtil.offsetDay(DateUtil.parse(partitionMax, "yyyy"), -365 * retentionYears), "yyyy");
                break;
            case "month":
                adjustPartitionName = DateUtil.format(DateUtil.offsetDay(DateUtil.parse(partitionMax, "yyyyMM"), -365 * retentionYears), "yyyyMM");
                break;
            case "day":
                adjustPartitionName = DateUtil.format(DateUtil.offsetDay(DateUtil.parse(partitionMax, "yyyyMMdd"), -365 * retentionYears), "yyyyMMdd");
                break;
            default:
                break;
        }
        return adjustPartitionName;
    }
  • 根据参数获取区间分区表名称
    /**
     * 根据参数获取区间分区表名称
     *
     * @param type         扶你去类型 year month day
     * @param partitionMax 最大分区值
     * @param partitionMin 最小分区值
     * @return 区间分区表名称列表
     */
    private List<String> getClearedUpListByParam(String type, String partitionMax, String partitionMin) {
        List<String> clearedUpList = new ArrayList<>();
        switch (type) {
            case "year":
                LocalDateTime startYear = LocalDateTime.of(Integer.parseInt(partitionMin), 1, 1, 0, 0);
                LocalDateTime endYear = LocalDateTime.of(Integer.parseInt(partitionMax), 1, 1, 0, 0);
                long numOfYearsBetween = ChronoUnit.YEARS.between(startYear, endYear) - 1;
                if (numOfYearsBetween >= 0) {
                    for (long i = 0; i <= numOfYearsBetween; i++) {
                        clearedUpList.add("p_year_" + DateUtil.format(startYear.plusYears(i), "yyyy"));
                    }
                }
                break;
            case "month":
                LocalDateTime startMonth = LocalDateTime.of(Integer.parseInt(partitionMin.substring(0, 4)), Integer.parseInt(partitionMin.substring(4)), 1, 0, 0);
                LocalDateTime endMonth = LocalDateTime.of(Integer.parseInt(partitionMax.substring(0, 4)), Integer.parseInt(partitionMax.substring(4)), 1, 0, 0);
                long numOfMonthsBetween = ChronoUnit.MONTHS.between(startMonth, endMonth) - 1;
                if (numOfMonthsBetween >= 0) {
                    for (long i = 0; i <= numOfMonthsBetween; i++) {
                        clearedUpList.add("p_month_" + DateUtil.format(startMonth.plusMonths(i), "yyyyMM"));
                    }
                }
                break;
            case "day":
                LocalDateTime startDay = LocalDateTime.of(Integer.parseInt(partitionMin.substring(0, 4)), Integer.parseInt(partitionMin.substring(4, 6)), Integer.parseInt(partitionMin.substring(6)), 0, 0);
                LocalDateTime endDay = LocalDateTime.of(Integer.parseInt(partitionMax.substring(0, 4)), Integer.parseInt(partitionMax.substring(4, 6)), Integer.parseInt(partitionMax.substring(6)), 0, 0);
                long numOfDaysBetween = ChronoUnit.DAYS.between(startDay, endDay) - 1;
                if (numOfDaysBetween >= 0) {
                    for (long i = 0; i <= numOfDaysBetween; i++) {
                        clearedUpList.add("p_day_" + DateUtil.format(startDay.plusDays(i), "yyyyMMdd"));
                    }
                }
                break;
            default:
                break;
        }
        return clearedUpList;
    }

3.用到的核心类

  • java.time.temporal.ChronoUnit【这个类之前用的很少】
  • cn.hutool.core.date.DateUtil【hutool工具箱的时间工具】
<think>好的,用户想要寻找查看磁盘空间的软件,适用于Windows、LinuxMac系统。我需要根据不同的操作系统分别推荐,并且确保推荐的软件确实有效且常用。 首先,回想一下常见的磁盘分析工具。Windows下我记得有TreeSizeWinDirStat,这两个都是用户友好的图形界面工具。还有系统自带的磁盘清理工具,虽然功能基础但也很实用。 对于Linux,命令行工具如dfdu是必须提到的,毕竟它们是系统自带的,而且非常强大。图形界面方面,Baobab(也就是Disk Usage Analyzer)在GNOME环境下很常见,KDE用户可能用Filelight,这两个都是不错的选择。 至于Mac系统,自带的磁盘工具可以查看存储情况,另外还有OmniDiskSweeperDaisyDisk,这两个第三方工具评价不错,特别是DaisyDisk的视觉效果很好,用户可能喜欢。 还要注意跨平台的支持,比如GrandPerspective,它支持MacLinux,不过Windows可能需要其他替代品。另外,用户可能需要知道不同文件系统的支持情况,比如exFAT在三个系统上的兼容性,但用户的问题主要是查看空间,可能不需要深入文件系统细节,不过引用中的信息可以作为补充说明。 需要检查引用内容是否相关。引用1提到了Linux释放磁盘空间的方法,引用23讨论了文件系统,可能与磁盘管理有关,但用户主要需要的是软件推荐。不过可以适当引用,比如提到Linux的df/du时引用1,或者在跨平台文件系统支持时引用23。 另外,用户可能希望软件是免费或开源的,所以尽量推荐这类工具,比如WinDirStat是开源,TreeSize有免费版,BaobabFilelight也是开源。OmniDiskSweeperDaisyDisk可能有免费试用或付费版本,需要注明。 最后,生成相关问题,考虑用户可能的后续问题,比如如何分析大文件、命令行技巧、跨平台工具比较等。</think>### 查看磁盘空间的软件推荐 #### **Windows系统推荐** 1. **TreeSize Free** 可视化磁盘空间占用,支持按目录层级分析,快速定位大文件/文件夹。免费版本功能足够个人使用[^1]。 ![](https://example.com/treesize.png) (图片仅为示意) 2. **WinDirStat** 开源工具,通过彩色区块图直观展示文件类型大小分布,适合深度分析存储占用。 ```bash # 下载地址:https://windirstat.net/ ``` 3. **系统自带工具** - **磁盘清理**:清理临时文件、系统缓存等。 - **资源监视器**(任务管理器 → 性能 → 打开资源监视器):实时监控磁盘活动与存储情况。 --- #### **Linux系统推荐** 1. **命令行工具** - `df -h`:查看分区使用情况,如: $$ df -h /home # 查看/home目录所在分区的空间 $$ - `du -sh *`:统计当前目录下各子目录/文件的大小。 2. **Baobab (Disk Usage Analyzer)** GNOME桌面环境的图形化工具,支持环形图或树形图展示存储分布。 ```bash sudo apt install baobab # Debian/Ubuntu安装 ``` 3. **Filelight (KDE)** KDE环境的交互式工具,通过动态区块图展示磁盘占用。 --- #### **macOS系统推荐** 1. **系统自带工具** - **关于本机 → 存储**:直观显示各类文件(应用、文档、系统等)的占用比例。 - **磁盘工具**:修复权限、分区管理及存储监控。 2. **OmniDiskSweeper** 快速扫描并列出文件大小,支持批量删除冗余文件。 ![](https://example.com/omnidisksweeper.png) 3. **DaisyDisk** 交互式扇形图分析,支持预览文件内容,适合可视化清理[^2]。 --- #### **跨平台工具** - **GrandPerspective**(支持macOS/Linux) 通过热力图定位大文件,适合技术用户[^3]。 - **JDiskReport**(Java开发,支持Windows/Linux/macOS) 提供报表图表分析,但需Java环境支持。 --- ### 文件系统兼容性补充 若需在Windows/Linux/macOS间共享磁盘,建议使用**exFAT**格式,支持大文件且跨平台读写。MBR分区表需注意2TB容量限制,GPT分区无此限制[^3]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

シ風

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值