- File类
- 基本用法
- 枚举
- 创建枚举类型
- 递归结构
- 递归计算一个数的阶乘
- 递归打印目录树
- java.io.File 类:代表文件和目录。 在开发中,读取文件、生成文件、删除文件、修改文件的属性时经常会用到本类。
- File 类的常见构造方法:public File(String pathname)
以 pathname 为路径创建 File 对象,如果 pathname 是相对路径,则默认的当前路径在系统属性 user.dir 中存储。
package com.ssc.manyclass;
import java.io.File;
import java.io.IOException;
import java.util.Date;
public class FIleClass {
public static void main(String[] args) throws IOException {
// TODO Auto-generated method stub
//获取项目路径
System.out.println(System.getProperty("user.dir"));
File uFile = new File("E:/eclipse_code/Ssc/a.txt");
//在上面的路径创建一个a.txt
uFile.createNewFile();
System.out.println("File是否存在:"+uFile.exists());
System.out.println("File是否在目录:"+uFile.isDirectory());
System.out.println("File是否是文件:"+uFile.isFile());
System.out.println("File最后修改时间:"+new Date(uFile.lastModified()));
System.out.println("File的大小:"+uFile.length());
System.out.println("File的文件名:"+uFile.getName());
System.out.println("File的目录路径:"+uFile.getPath());
File uFile1 = new File("E:/eclipse_code/Ssc/filetest/a.txt");
uFile1.mkdirs();
uFile1.delete();//删除最后一个文件
}
}
枚举
创建枚举类型
enum Season{
枚举体(常量列表)
}
- 所有的枚举类型隐性地继承自 java.lang.Enum。枚举实质上还是类!而每个被枚举的成员实质就是一个枚举类型的实例,他们默认都是 public static final 修饰的。可以直接通过枚举类型名使用它们。
package com.ssc.manyclass;
import java.util.Random;
public class Enumerate {
public static void main(String[] args) {
// TODO Auto-generated method stub
System.out.println(Senson.AUTUMN);
//枚举遍历
for(week k:week.values()) {
System.out.println(k);
}
int a = new Random().nextInt(4);
switch (Senson.values()[a]) {
case SPRING:
System.out.println("春天");
break;
case SUMMER:
System.out.println("夏天");
break;
case AUTUMN:
System.out.println("秋天");
break;
case WINTER:
System.out.println("冬天");
break;
default:
break;
}
}
}
enum Senson{
SPRING,SUMMER,AUTUMN,WINTER
}
enum week{
星期一,星期二,星期三,星期四,星期五,星期六,星期日
}
递归结构
- 自己调用自己
package com.ssc.manyclass;
public class Recursion {
public static int num = 10;
public static void main(String[] args) {
// TODO Auto-generated method stub
Recursion.a();
long d1 = System.currentTimeMillis();
System.out.printf("%d阶乘的结果果:%s%n",10,factorial(10));
long d2 = System.currentTimeMillis();
System.out.printf("递归耗时:%s%n",d2-d1);
}
static long factorial(int i) {
// TODO Auto-generated method stub
if(i==1) {//递归头
return 1;
}
return i*factorial(i-1);//递归体
}
//简单递归
public static void a() {
num--;
System.out.println("a");
if(num>0) {
a();
}
}
}
递归打印目录树
package com.ssc.manyclass;
import java.io.File;
public class EnumerateTree {
public static void main(String[] args) {
// TODO Auto-generated method stub
File a = new File("I:/手机相册");
printFileTree(a, 1);
}
static void printFileTree(File file,int level) {
//输出层次
for(int i=0;i");
}
//输出文件名
//文件名字过滤
//if(file.isDirectory() || file.getName().toLowerCase().endsWith(".jpg")) {
System.out.println(file.getName());
//}
//如果文件是目录,则获取子文件列表,并对每个子文件及逆行相同的操作
if(file.isDirectory()) {
File[] files = file.listFiles();
for(File temp:files) {
//调用递归注意level加1
printFileTree(temp, level+1);
}
}
}
}



