zoukankan      html  css  js  c++  java
  • 【小程序分享篇 一 】开发了个JAVA小程序, 用于清除内存卡或者U盘里的垃圾文件非常有用

    有一种场景, 手机内存卡空间被用光了,但又不知道哪个文件占用了太大,一个个文件夹去找又太麻烦,所以我开发了个小程序把手机所有文件(包括路径下所有层次子文件夹下的文件)进行一个排序,这样你就可以找出哪个文件占用了内存太大了。

    使用例子如下,用JAVA 运行Sort

    1, 输入你要排序的文件路径 , 如 例子是对H:下的文件和它所有子文件夹下的文件进行排序

    2, 输入需要进行排序显示的最新大小,如 例子是对10M 大小 以上的文件进行排序

    3,从大到小排序后按

    文件路径文件名-------大小 KB--------创建日期进行显示(yyyyMMdd)

    格式进行显示,。

    这样你就可以把太大的文件删除了,清理出空间

    D:hjbsSorftwork20140207SortSizein>java com.he.jinbin.Sort
    输入需要排序文件地址:H:
    输入需要排序文件大小(单位M):10
    运行中,请稍等...
    从大到小文件排序为:
    H:.android_securecom.sg.android.fish-1.asec-------36224000 KB--------20130525
    H:BaiduMapvmphquanguogailue.dat-------27616013 KB--------20130512
    H:DownloadRedGame_Android_2017-2013-11-06_18-54-27-CI-20.apk-------26563096 KB--------20131111
    H:ugameugameSDKdownloads6F9757F4442DD99FC89FA387C80405D2.apk-------26305964KB--------20131025
    H:Downloadcom.tencent.mobileqq_60.apk-------25417880 KB--------20130714
    H:Androiddatacom.android.gallery3dcacheimgcache.0-------22070789 KB--------20140210
    H:ook2014异世灵武天下异世灵武天下.txt-------20279247 KB--------20131114
    H:ook深入java虚拟机.pdf-------19936351 KB--------20130303
    H:ook2014官途官途.txt-------19668417 KB--------20130907
    H:ook金庸世界里的道士.txt-------19004109 KB--------20130102
    H:wandoujiapatch快播_1390061188726.patch-------18649129 KB--------20140119
    H:BaiduMapvmphguangzhou_257.dat-------16645639 KB--------20140120
    H:ook战皇.txt-------15588332 KB--------20121215
    H:Downloadcom.tencent.mobileqq_52.apk-------15128435 KB--------20130521
    H:ook2014超级农民超级农民.txt-------13913630 KB--------20130807
    H:ook2014唐寅在异界唐寅在异界.txt-------13328290 KB--------20130726
    H:ook2014末日蟑螂末日蟑螂.txt-------13177834 KB--------20131129
    H:ook2014易筋经易筋经.txt-------12995888 KB--------20130715
    H:ook2014抗战之红色警戒抗战之红色警戒.txt-------12828979 KB--------20130928
    H:ook ew道.txt-------12445787 KB--------20130326
    H:ook20141895淘金国度1895淘金国度.txt-------12391071 KB--------20140104
    H:ook2014权臣权臣.txt-------11949796 KB--------20130726
    H:install360weishi_167.apk-------11342128 KB--------20131009
    H:ook2013.9.19斗破苍穹.txt-------10776149 KB--------20130103
    H:installaiduditu.apk-------10685159 KB--------20130511
    H:DBOPResourcescfgdb.cfg-------10647552 KB--------20130520

    windows的弊端,不能对文件夹的大小进行显示。

    就两个类,

    package com.he.jinbin;
    
    import java.util.Date;
    /**
     * 用于排序逻辑实体类
     * 
     * @author 何锦彬    QQ 277803242
     *
     */
    public class FileItem implements Comparable {
        private String fileName;
        private long size;
        private Date creatTime;
    
        public FileItem(String fileName, long size, Date creaDate) {
            // TODO Auto-generated constructor stub
            this.fileName = fileName;
            this.size = size;
            this.creatTime = creaDate;
        }
    
        public String getFileName() {
            return fileName;
        }
    
        public void setFileName(String fileName) {
            this.fileName = fileName;
        }
    
        public long getSize() {
            return size;
        }
    
        public void setSize(long size) {
            this.size = size;
        }
    
        public Date getCreatTime() {
            return creatTime;
        }
    
        public void setCreatTime(Date creatTime) {
            this.creatTime = creatTime;
        }
    
        @Override
        public int compareTo(Object o) {
            if (this.size > ((FileItem) o).getSize())
                return 1;
            return -1;
        }
    
    }
    package com.he.jinbin;
    
    import java.io.BufferedInputStream;
    import java.io.BufferedReader;
    import java.io.File;
    import java.io.IOException;
    import java.io.InputStream;
    import java.io.InputStreamReader;
    import java.text.SimpleDateFormat;
    import java.util.ArrayList;
    import java.util.Collections;
    import java.util.Date;
    import java.util.List;
    /**
     * 用于排序逻辑主类
     * 
     * @author 何锦彬    QQ 277803242
     *
     */
    public class Sort {
        public static List<FileItem> fileItems = new ArrayList<FileItem>();
        public static FileItem maxFileItem;
        public final static long M_1 = 1024 * 1024;
        public static long temp = M_1; // 默认大于1M的文件
    
        public static void addFileItem(File file) {
            File[] fileList = file.listFiles();
            for (int i = 0; i < fileList.length; i++) {
                file = fileList[i];
                if (file.isDirectory()) {
                    addFileItem(file);
                } else {
                    if (file.length() > temp) {
                        fileItems.add(new FileItem(file.getPath(), file.length(),
                                new Date(file.lastModified())));
                    }
    
                }
            }
    
        }
    
        public static void main(String[] args) throws IOException {
            String filePath = null;
            System.out.print("输入需要排序文件地址:");
            BufferedReader inRd = new BufferedReader(new InputStreamReader(
                    System.in));
            filePath = inRd.readLine();
            System.out.print("输入需要排序文件大小(单位M):");
            inRd = new BufferedReader(new InputStreamReader(System.in));
            temp = Long.parseLong(inRd.readLine())*M_1;
            inRd.close();
            System.out.println("运行中,请稍等...");
            File file = new File(filePath);
            addFileItem(file);
            SimpleDateFormat fmt = new SimpleDateFormat("yyyyMMdd");
            Collections.sort(fileItems);
            System.out.println("从大到小文件排序为:");
            for (int i = fileItems.size() - 1; i >= 0; i--) {
                FileItem item = fileItems.get(i);
                System.out.println(item.getFileName() + "-------" + item.getSize()
                        + " KB" + "--------" + fmt.format(item.getCreatTime()));
            }
    
        }
    }

    虽然简单, 但个人看法是, 程序只是工具, 为生活带来便利就是好程序,不是为了show技术,仅仅是为了实用

    源码 下载地址https://github.com/bensonHe/sortFile

  • 相关阅读:
    剑指Offer 13.机器人的运动范围
    笔试题目-无向图是否全连通
    面试题目-最小代价的寻路问题
    京东一面问题
    剑指Offer 07.重建二叉树
    剑指Offer 12.矩阵中的路径
    剑指Offer 10-I.斐波那契数列
    剑指Offer 06.从尾到头打印链表
    剑指Offer 05.替换空格
    剑指Offer 04.二维数组中的查找
  • 原文地址:https://www.cnblogs.com/springsource/p/3554269.html
Copyright © 2011-2022 走看看