MyCP(课下作业,必做)

要求

编写MyCP.java 实现类似Linux下cp XXX1 XXX2的功能,要求MyCP支持两个参数:
java MyCP -tx XXX1.txt XXX2.bin 用来把文本文件(内容为十进制数字)转化为二进制文件
java MyCP -xt XXX1.bin XXX2.txt 用来二进制文件把转化为文本文件(内容为十进制数字)
说明: cp指令用于复制文件或目录,如同时指定两个以上的文件或目录,且最后的目的地是一个已经存在的目录,则它会把前面指定的所有文件或目录复制到此目录中。若同时指定多个文件或目录,而最后的目的地并非一个已存在的目录,则会出现错误信息

    • 思路
      题目要求实现文件的复制过程,且能够支持两个参数:-tx和-xt;
      把内容为十进制数字的文本文件转化为二进制文件,所以只需要考虑由数字字符构成的文本文档;
      十进制数字单个数字最大是9,用二进制数字表示需要4位,所以需要把文本文件中的十进制数字的每一位都补齐为四位二进制数。

      • 代码

      import java.io.*;
      public class Mycp {
      public static void main(String args[]) {
      String choose=args[0];//获得第一个参数
      String File1=args[1];//获得第二个参数:文件名
      String File2=args[2];//获得第三个参数:文件名
      File sourceFile = new File(File1);//读取的文件
      File targetFile = new File(File2);//写入的文件
      int ReadLenth=0;
      if (choose.equals("-tx")){
      ReadLenth=1;
      }//如果参数是-tx,每次读取的长度设置为1
      else if(choose.equals("-xt")) {
      ReadLenth=4;
      }//如果参数是-xt,每次读取的长度设置为4
      else{
      System.out.println("输入参数错误!");
      System.exit(0);
      }//如果参数输入错误的话就退出程序
      char c[] =new char[ReadLenth];//定义字符数组
      try{
      Writer out = new FileWriter(targetFile);//指向目的地的输出流
      Reader in = new FileReader(sourceFile);//指向源的输入流
      int n = -1;
      while((n=in.read(c,0,ReadLenth))!=-1) {
      //当文件中还有信息时,继续读取字符到字符数组c中,n是返回的实际读取的字符的个数
      String number="";
      if(ReadLenth==1){
      number=Integer.toBinaryString((int)c[0]-48);
      //把读取到的十进制数转化为二进制数
      while(number.length()<4){
      number="0"+number;//把二进制数扩充为4位
      }
      out.write(number);//写入目标文件
      }
      else if(ReadLenth==4){
      for(int i=0;i<n;i++){
      number=number+c[i];//读取4位的二进制数
      }
      number=Integer.valueOf(number,2).toString();//二进制数转化十进制,再转为字符串形式
      out.write(number);//写入目标文件
      }
      }
      out.flush();
      out.close();
      }
      catch(IOException e) {
      System.out.println("Error "+e);
      }
      }
      }
  • 由于我个人的笔记本电脑主板短路了,短时间内无法修好,所以只能用同学的电脑测试并调试代码。目前只能提交这么多,望老师理解!!!

20175315Mycp的更多相关文章

随机推荐

  1. Command "python setup.py egg_info" failed with error code 1 in C:\Users\w5659\AppData\Local\Temp\pip-install-t7uomu4r\xa dmin\

    Error msg: C:\Users\w5659>pip install xadmin Collecting xadmin Using cached https://files.pythonh ...

  2. [Alpha阶段]项目展示博客

    目录 Alpha阶段项目展示 1.团队成员介绍 2.工程相关信息 (1)我们的用户 (2)产品表现 (3)团队分工 (4)项目管理 (5)测试 (6)文档 (7)用户调研 3.项目信息 (1)实际进展 ...

  3. clipboardjs复制到粘贴板

    <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head runat=&qu ...

  4. eclipse中maven父子项目层级显示设置

    第一步:window-->show view --> project explorer 第二步:小三角---> projects presentation----->hiera ...

  5. Navicat 连接VMware中Ubuntu 下的mysql5.7遇到的坑

    1.用Navicat连接虚拟机下的mysql出现问题: 2003- Can't connect MySQL Server on '192.168.*.*'(10038). 解决方案: 方法:直接授权( ...

  6. Flask--偏函数, 线程安全, 请求上下文

    一 . 偏函数 from functools import partial def func(a, b): return a + b new_func = partial(func, 3, 4) # ...

  7. BZOJ5019[Snoi2017]遗失的答案——FWT+状压DP

    题目描述 小皮球在计算出答案之后,买了一堆皮肤,他心里很开心,但是一不小心,就忘记自己买了哪些皮肤了.==|||万 幸的是,他还记得他把所有皮肤按照1-N来编号,他买来的那些皮肤的编号(他至少买了一款 ...

  8. noip2017部分题目

    D1T3 逛公园 题目描述 策策同学特别喜欢逛公园.公园可以看成一张NN个点MM条边构成的有向图,且没有 自环和重边.其中1号点是公园的入口,NN号点是公园的出口,每条边有一个非负权值, 代表策策经过 ...

  9. P1462 通往奥格瑞玛的道路 (二分+最短路)

    题目 P1462 通往奥格瑞玛的道路 给定\(n\)个点\(m\)条边,每个点上都有点权\(f[i]\),每条边上有边权,找一条道路,使边权和小于给定的数\(b\),并使最大点权最小. 解析 二分一下 ...

  10. Python unittest 测试输入(input)和输出(print)

    Python 自带的 unittest 库可以用来写单元测试. 测试输入输出的解决方法是: 将标准输入输出定向到一个StringIO类(python3是 io.StringIO). import un ...