zoukankan      html  css  js  c++  java
  • 比较两个文件内容是否相同

          /* 判断两个文件的内容是否相同,文件名要用绝对路径
           * @param fileName1 :文件1的绝对路径
           * @param fileName2 :文件2的绝对路径
           * @return 相同返回true,不相同返回false
           */
        public boolean isSameFile(String fileName1,String fileName2){
            FileInputStream fis1 = null;
            FileInputStream fis2 = null;
            try {
                fis1 = new FileInputStream(fileName1);
                fis2 = new FileInputStream(fileName2);
                
                int len1 = fis1.available();//返回总的字节数
                int len2 = fis2.available();
                
                if (len1 == len2) {//长度相同,则比较具体内容
                    //建立两个字节缓冲区
                    byte[] data1 = new byte[len1];
                    byte[] data2 = new byte[len2];
                    
                    //分别将两个文件的内容读入缓冲区
                    fis1.read(data1);
                    fis2.read(data2);
                    
                    //依次比较文件中的每一个字节
                    for (int i=0; i<len1; i++) {
                        //只要有一个字节不同,两个文件就不一样
                        if (data1[i] != data2[i]) {
                            System.out.println("文件内容不一样");
                            return false;
                        }
                    }
                    System.out.println("两个文件完全相同");
                    return true;
                } else {
                    //长度不一样,文件肯定不同
                    return false;
                }
            } catch (FileNotFoundException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            } finally {//关闭文件流,防止内存泄漏
                if (fis1 != null) {
                    try {
                        fis1.close();
                    } catch (IOException e) {
                        //忽略
                        e.printStackTrace();
                    }
                }
                if (fis2 != null) {
                    try {
                        fis2.close();
                    } catch (IOException e) {
                        //忽略
                        e.printStackTrace();
                    }
                }
            }
            return false;
        }

    
    
    作者:C_mihoo
    来源:CSDN 原文:https://blog.csdn.net/c_mihoo/article/details/16119523 版权声明:本文为博主原创文章,转载请附上博文链接!
  • 相关阅读:
    整数反转
    最长公共前缀
    罗马数字转整数
    单点登录
    VMware Workstation虚拟机密钥
    Pytest 用例内部执行顺序
    判断是不是回文数
    python端口IP字符串是否合法
    python求二叉树深度
    有两个字符串类型的数字,实现一个方法将它们进行相加,并返回相加后的数值。
  • 原文地址:https://www.cnblogs.com/longlyseul/p/10952840.html
Copyright © 2011-2022 走看看