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

网友投稿 228 2023-07-27

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

{

for(int i=0;i

{

bufc[i]=(byte)((bufa[i]^bufb[i]) & 0xFFzIQKaIoZ);

count++;

}

fos.write(bufc);

}

else if(count>=filesizea-filesizea%1024 && count

{

for(int j=0zIQKaIoZ; count>=filesizea-zIQKaIoZfilesizea%1024 && count

{

buf_yu[j]=(byte)((bufa[j]^bufb[j]) & 0xFF);

count++;

}

fos.write(buf_yu);

}

}

System.out.println(count);

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

fileb.close();

fos.close(zIQKaIoZ);

}

}

{

for(int i=0;i

{

bufc[i]=(byte)((bufa[i]^bufb[i]) & 0xFFzIQKaIoZ);

count++;

}

fos.write(bufc);

}

else if(count>=filesizea-filesizea%1024 && count

{

for(int j=0zIQKaIoZ; count>=filesizea-zIQKaIoZfilesizea%1024 && count

{

buf_yu[j]=(byte)((bufa[j]^bufb[j]) & 0xFF);

count++;

}

fos.write(buf_yu);

}

}

System.out.println(count);

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

fileb.close();

fos.close(zIQKaIoZ);

}

}

{

bufc[i]=(byte)((bufa[i]^bufb[i]) & 0xFFzIQKaIoZ);

count++;

}

fos.write(bufc);

}

else if(count>=filesizea-filesizea%1024 && count

{

for(int j=0zIQKaIoZ; count>=filesizea-zIQKaIoZfilesizea%1024 && count

{

buf_yu[j]=(byte)((bufa[j]^bufb[j]) & 0xFF);

count++;

}

fos.write(buf_yu);

}

}

System.out.println(count);

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

fileb.close();

fos.close(zIQKaIoZ);

}

}

{

for(int j=0zIQKaIoZ; count>=filesizea-zIQKaIoZfilesizea%1024 && count

{

buf_yu[j]=(byte)((bufa[j]^bufb[j]) & 0xFF);

count++;

}

fos.write(buf_yu);

}

}

System.out.println(count);

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

fileb.close();

fos.close(zIQKaIoZ);

}

}

{

buf_yu[j]=(byte)((bufa[j]^bufb[j]) & 0xFF);

count++;

}

fos.write(buf_yu);

}

}

System.out.println(count);

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

fileb.close();

fos.close(zIQKaIoZ);

}

}

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:探索无限可能的免费服务器世界
下一篇:探索数据接口:从数据线到数据库的无限可能
相关文章

 发表评论

暂时没有评论,来抢沙发吧~