Java基础笔记总结(16)-IO流 File类练习题

获取文件夹的长度

private static Long getFileLength(File file) {

long len = 0;

File[] subLists = file.listFiles();

for (File subFile : subLists) {

if(subFile.isFile()){

len += subFile.length();

}else{

len +=getFileLength(subFile);

}

}

return len;

}

删除文件夹下的所有目录

public static void deleteDirectory(File file){

File[] subLists = file.listFiles();

for (File subFile : subLists) {

if(subFile.isDirectory()){

deleteDirectory(subFile);

}else if(subFile.isFile()){

  subFile.delete();

}else {

}

}

file.delete();

}

拷贝目录文件夹

public static void main(String[] args) throws IOException {

// 1、创建于目标文件相同的源文件夹

File dir = new File("ccc");

boolean flg =dir.mkdir();

copyFile(new File("aaa"), dir);

// 2、获取原文件夹中所有的文件和文件夹

// 3、遍历数组,如果是文件就用IO流读写

// 4、如果是文件夹就递归调用

}

public static void copyFile(File originFile,File destFile) throws IOException{

File[] fileList = originFile.listFiles();

for (File subFile : fileList) {

if(subFile.isDirectory()){

File subDestFile = new File(destFile.getAbsolutePath()+"\\"+subFile.getName());

subDestFile.mkdir();

copyFile(subFile, subDestFile);

}else if(subFile.isFile()){

FileInputStream fis = new FileInputStream(subFile);

FileOutputStream fos = new FileOutputStream(destFile.getAbsolutePath()+"\\"+subFile.getName());

int len = 0;

byte[] arr = new byte[1024];

while((len = fis.read(arr))!= -1){

fos.write(arr, 0, len);

}

fis.close();

fos.close();

}

}

}

按照层级打印

public static void printFileName(File file,int level){

File[] fileLists = file.listFiles();

for (File subFile : fileLists) {

for (int i = 0; i < level; i++) {

System.out.print("\t");

}

System.out.println(subFile);

if(subFile.isDirectory())

printFileName(subFile, level+1);

}

}

}

斐波拉契数列

public class Demo_Rabbit {

public static void main(String[] args) {

System.out.println(getNewRabbit(6));

}

public static int  getNewRabbit(int num){

if(num == 1){

return 1;

}else if(num ==2){

return 1;

}else{

return getNewRabbit(num-1)+getNewRabbit(num-2);

}

}

}

1000的阶乘问题

约瑟夫环

import java.util.ArrayList;

public class Demo_LuckNum {

public static void main(String[] args) {

System.out.println(getLuckNum(8));

}

public static int getLuckNum(int num){

ArrayList<Integer> list = new ArrayList<>();

for (int i = 1; i <= num; i++) {

list.add(i);

}

//去除零

int count = 1;

for (int i = 0; list.size()!=1; i++) {

if(i == list.size()){

i = 0;

}

if(count%3 == 0 ){

list.remove(i--);

}

count++;

}

return list.get(0);

}

}

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 一、 1、请用Java写一个冒泡排序方法 【参考答案】 public static void Bubble(int...
    独云阅读 5,275评论 0 6
  • 【程序1】 题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔...
    开心的锣鼓阅读 8,587评论 0 9
  • 【程序1】 题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一...
    阿里高级软件架构师阅读 8,563评论 0 19
  • Java是一种可以撰写跨平台应用软件的面向对象的程序设计语言。Java 技术具有卓越的通用性、高效性、平台移植性和...
    Java小辰阅读 4,560评论 0 5
  • 一些想要改造另外一些的人,最终都会失败的,结果要么相互影响,相互同化,要么彻底彻底认输,也有可能会让自己陷落。人只...
    一直走别回头M阅读 3,902评论 0 0

友情链接更多精彩内容