java文件拷贝相关知识
-
java文件拷贝方式在100MB文件条件下速度的比较package com.imooc.io; import java.io.BufferedInputStream; import java.io.BufferedOutputStream; import java.io.File; import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; public class IOUtil { public static void copyFile(File srcFile,File destFile)throws IOException{ if(!srcFile.exists()){ throw new IllegalArgumentException("文件:"+srcFile+"不存在"); } if(!srcFile.isFile()){ throw new I
-
Java字节流实现文件夹的拷贝import java.io.File; import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStream; import java.io.OutputStream; /** java字节流实现文件夹的拷贝 拷贝文件夹,其中文件夹中又有多个文件 1.先遍历这个文件夹,判断是否是目录 2.创建文件夹 3.拷贝文件到新的地方 */ public class FileDirectoryCopyDemo { //遍历文件夹 public static void copy(File srcDir,File destDir){ //遍历srcDir文件夹
-
关于 Java 浅拷贝、深拷贝,你真的知道了吗?这是今天我们在技术群里面讨论的一个知识点,讨论的相当激烈,由于对这一块使用的比较少,所以对这一块多少有些盲区。这篇文章总结了所讨论的内容,希望这篇文章对你有所帮助。 在 Java 开发中,对象拷贝或者说对象克隆是常有的事,对象克隆最终都离不开直接赋值、浅拷贝、深拷贝 这三种方式,其中直接赋值应该是我们最常用的一种方式吧,对于浅拷贝和深拷贝可能用的少,所以或多或少存在一些误区,这篇文章会详细的介绍这三种对象克隆方式。 前置知识 值类型:Java 的基本数据类型,例如
-
java实现拷贝一个文件夹,里面存在目录和文件,使用文件创建和文件流内容我都在注释里说明了,有什么不懂的可以问我.主要是为了回顾下文件的创建和文件流的读写,所以写了这个拷贝的代码,还可以添加很多功能,像拷贝哪个文件到哪都是可以改个,可以用scanner输入,还有就是可以再加个delete()那么程序就变成剪切功能了. package io; import java.io.File; import java.io.RandomAccessFile; /** * java实现拷贝一个文件夹,里面存在目录和文件,使用文件创建和文件流 * 读到file文件复制里面的内容,读到目录,复制目录,并查看里面是否还有文件 * @author 温
java文件拷贝相关课程
java文件拷贝相关教程
- 3. 浅拷贝 Object.assign() 的拷贝属于浅拷贝,也就是说它只拷贝对下的第一层的属性值。如果这个值是一个对象类型,那么 Object.assign() 不会对该对象进行深拷贝,也就是说,拷贝后的对象下的这个对象类型是源对象和拷贝后的对象共有的,无论谁(源对象或拷贝后对象)对这个对象下的值进行修改,另一个对象(源对象或拷贝后对象)也会共享这个改变。看下面的例子更清晰的表达:var target = {};var source = {a: 1, b: {c: 2, d: 3}};Object.assign(target, source);target.a = 5;target.b.c = 9;console.log(target) // {a: 5, b: {c: 9, d: 3}}console.log(source) // {a: 1, b: {c: 9, d: 3}}上面的代码中,源对象 source 是个两层的字面量对象,b 也是一个对象。使用 Object.assign() 拷贝给目标对象 target,拷贝后对 target 对象下的值进行修改,然后打印目标对象和源对象。从打印的结果可以看出,对 target 第一层的 a 进行修改时,源对象是不会改变。但是对 target 下的 b 对象下的值进行修改时,因为 b 也是一个对象,所以源对象中的值也被修改了。到这里可以看出,Object.assign() 没有对 b 进行拷贝。如果需要深拷贝则需要,需要递归地使用去 Object.assign() 来拷贝对象。
- 2.1 数组拷贝 在 ES5 经常会遇到数组和对象的浅拷贝,我们都知道数组和对象都是引用类型,所以不能像字符串那样直接赋值,在 ES5 中数组和对象的拷贝都是通过循环来实现的,下面我们来看几个例子:var arr1 = [1, 2, 3];var arr2 = [];arr1.forEach(function(value){ arr2.push(value);}) console.log(arr2); // [1, 2, 3]上面的代码是把 arr1 数组中的项拷贝到 arr2 中去,还可以使用数组提供的 concat 和 slice 方法来实现。var arr1 = [1, 2, 3];var arr2 = [].concat(arr1);var arr3 = arr1.slice(0);arr1.push(4)console.log(arr1); //[1, 2, 3, 4]console.log(arr2); //[1, 2, 3]console.log(arr3); //[1, 2, 3]在拷贝完后,对 arr1 数组添加元素,可以看到 arr2 和 arr3 没有发生变化,说明它们不是一个引用地址。这是 ES5 所提供的拷贝方式,那么 ES6 是如何简化的呢?var arr1 = [1, 2, 3]; var arr2 = [...arr1];arr1.push(4)console.log(arr1); //[1, 2, 3, 4]console.log(arr2); //[1, 2, 3]使用 ... 展开语法可以实现与上面 ES5 实现的相同效果,而且比较简洁地表达了把 arr1 中的每一项展开放入 arr2 中。
- 2.2 字面量对象拷贝 上面说到了 ES5 和 ES6 数组拷贝的一个对比,那么针对字面量对象的拷贝二者又是怎么来实现的呢?ES5 中针对字面量对象的拷贝方式比较少,没有数组提供的类似的方法可以使用,只能使用循环,但是还可以使用 JSON.stringify 和 JSON.parse 来实现,但是这个方法存在一些缺陷。 下面看 ES5 中字面量的拷贝实例:let obj = {a: 1, b: 2};let copy1 = {};for(let key in obj) { copy1[key] = obj[key] }let copy2 = JSON.parse(JSON.stringify(obj))上面的两种方法给出了 ES5 拷贝字面量对象的方法,比较麻烦,也容易出错。ES6 给出了它的答案:let obj = {a: 1, b: 2};let copy = {...obj};使用展开语法对 obj 进行展开,完美地实现了拷贝过程。Tips: 这里有必要说明一下,以上的方法都是浅拷贝(只拷贝数组和对象的第一层结构)的过程,对于数组和对象第一层以后的内容,如果是引用类型的存储方式,则不会进行拷贝操作,也就是不会进行深拷贝。
- 8. COPY: 将宿主机文件拷贝到镜像中 用法:COPY <宿主机文件路径> <镜像文件路径>示例:COPY app.py /web/除了指定完整的文件名外,COPY 命令还支持 Go 风格的通配符,比如:# * 是任意字符的占位符,匹配文件 test11 test22COPY test* /tmp# ? 是单个字符的占位符,匹配文件 test1.txt test2.txtCOPY test?.txt /tmp对于目录而言,COPY 只复制目录中的内容而不包含目录自身。 如下目录结构:testdir/├── file1└── file2COPY testdir /tmp镜像的 /tmp 目录下,将得到这样的文件结构:tmp/├── file1└── file2如果要带目录拷贝到镜像中,需要使用:COPY testdir /tmp/testdirADD和COPY用法类似,一般优先使用 COPY。COPY 只支持简单将本地文件拷贝到容器中,而 ADD 还有从压缩包中提取文件的功能,如:# 宿主机压缩包test.tar 解压到 镜像/tmp中ADD test.tar /tmp
- 5. 拷贝异常时会被打断 在拷贝时如果发生异常,则拷贝会被终止,并报错,前面已经被拷贝的不会被影响可以继续使用,但后面没有被拷贝的则不能被使用。var target = Object.defineProperty({}, "a", { value: 1, writable: false});Object.assign(target, {b: 2}, {a: 3}, {c: 4});// Uncaught TypeError: Cannot assign to read only property 'a' of object 'console.log(target.b); // 2console.log(target.c); // undefined上面的代码中,定义了目标对象 target 上的属性 a 是只读的,也就是不能不被修改,在合并代码时,源对象上有 a,则报了 a 是对象上的只读属性不能被 assign 操作。从后面的打印结果可以看出,b 已经被拷贝到目标对象上了可以正常使用,但由于拷贝中发生异常,最后一个对象没有被拷贝,所以 c 的值是 undefined。
- 2.2 拷贝对象 let target = {};let source = {a: 1, b: 2, c: 3};Object.assign(target, source);target.d = 4;console.log(target) // {a: 1, b: 2, c: 3, d: 4}console.log(source) // {a: 1, b: 2, c: 3}上面的代码可以看出,Object.assign () 的主要用法就是把源对象拷贝到指定的对象上去,目标对象的更改不会影响源对象。
java文件拷贝相关搜索
-
j2ee
j2ee是什么
jar格式
java
java api
java applet
java c
java jdk
java list
java map
java script
java se
java socket
java swing
java switch
java web
java xml
java 程序设计
java 多线程
java 环境变量