欢迎来到代码驿站!

JAVA代码

当前位置:首页 > 软件编程 > JAVA代码

java实现两个文件的异或运算

时间:2020-11-04 11:24:46|栏目:JAVA代码|点击:

本文实例为大家分享了java实现两个文件的异或运算的具体代码,供大家参考,具体内容如下

以下代码是将两个大小相同的文件异或之后生成一个新的文件,具体思想是用FileInputStream方法读取文件,以字节为单位对两个文件进行异或运算,然后用FileOutputStream方法输出文件,具体代码如下:

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;

public class Test
{ 
  int i=0;
  static int count=0;
  public static void main(String[] args) throws IOException 
  { 
    //创建字节输入流 
    FileInputStream filea = new FileInputStream("d:\\JavaXor\\a");
  FileInputStream fileb = new FileInputStream("d:\\JavaXor\\b");
  File outfile=new File("d:\\JavaXor\\outfile");
  int filesizea=filea.available();//计算文件的大小
  FileOutputStream fos=new FileOutputStream(outfile);

    byte[] bufa = new byte[1024]; //存放filea文件的字节数组
    byte[] bufb = new byte[1024]; //存放fileb文件的字节数组
    byte[] bufc = new byte[1024]; //存放两个文件异或后的字节数组
    byte[] buf_yu=new byte[filesizea%1024]; //存放文件异或的最后一部分,因为文件的大小可能不是1024的整数倍,如果继续用bufc的话输出的文件大小会比应有值大
                        //就是最后一个字节数组没有放满1024个字节

    int hasReada = 0; 
    int hasReadb = 0; 

   //FileInputStream类的read()方法把读取的流放在bufa中,并且返回字节的个数赋给hasReada
    //下面的函数就是将文件的最后一部分与其他部分分别对待
   while( ((hasReada=filea.read(bufa))>0) && ((hasReadb=fileb.read(bufb))>0) )
    {
    if(count<filesizea-filesizea%1024)
    {  
      for(int i=0;i<bufa.length && count<filesizea-filesizea%1024;i++)
       {

        bufc[i]=(byte)((bufa[i]^bufb[i]) & 0xFF);
        count++;

       }
      fos.write(bufc);
    }
    else if(count>=filesizea-filesizea%1024 && count<filesizea)
    {

      for(int j=0; count>=filesizea-filesizea%1024 && count<filesizea ;j++)
      {
        buf_yu[j]=(byte)((bufa[j]^bufb[j]) & 0xFF);
        count++;

      }
      fos.write(buf_yu);
    }

    }
    System.out.println(count);


    filea.close(); //关闭输入输出流
    fileb.close(); 
    fos.close();
  } 
} 

上一篇:JavaBean valication验证实现方法示例

栏    目:JAVA代码

下一篇:Java并发框架:Executor API详解

本文标题:java实现两个文件的异或运算

本文地址:http://www.codeinn.net/misctech/19060.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有