Java对项目代码行数的统计

本文介绍了一个使用Java编写的代码行数统计器,它能够递归地遍历指定目录下的所有.java文件,并统计其中的代码行数。该程序利用了Java的IO流进行文件读取,展示了递归算法的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

啦啦啦!今天是周三,但是我又来了!
在这里插入图片描述
废话不多说了上代码!!!!!!!!!!!!!!!!!!!

package HW;

import java.io.BufferedReader;
import java.io.File;import java.io.FileFilter;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStreamReader;

public class Homework4 {
	static int count = 0;
	public static void main(String[] args) throws IOException {
        //获取所要查询文件夹路径
		String path = "D:\\Users\\MF\\eclipse-workspace\\tank1.3";
		myCodeCount(new File(path));
		System.out.println("总代码行数为"+count);
	}
	/**
	 * 递归统计代码总行数
	 * @throws IOException 
	 */
	public static void myCodeCount(File file) throws IOException {
        //文件是否为普通文件并以.java为后缀结尾
		if (file.isFile() && (file.getName().endsWith(".java"))) {
			int i = readData(file);
			count += i;
		}
		if (file.isDirectory()) {//测试此抽象路径名表示的文件是否为目录
			File[] files = file.listFiles();
			for (File f : files) {
				File[] files2 = f.listFiles(new FileFilter() {
					@Override
					public boolean accept(File f) {
						if (f.getName().endsWith(".java")) {
							return true;
						}
						return false;
					}
			});
				myCodeCount(f);
			}		
		}			
	}
	/**
	 * 单个文件中的行数
	 */
	public static int readData(File file) throws IOException {
		BufferedReader br = new BufferedReader(new InputStreamReader(new FileInputStream(file)));
		String str = null;
		int i = 0;
		while ((str = br.readLine())!=null) {
			i++;
		}
		br.close();
		System.out.println(file.getName()+"的行数为"+i);
		return i;
	}
}

运行图
在这里插入图片描述

递归是算法设计中的一种常用的基本算法。递归方法即通过函数或过程调用自身将问题转换为本质相同但规模较小的子问题,是分治策略的具体体现。emmmm这段代码主要是在学习IO流时所练习的代码!!

快到12点了,该网抑云了,同志们告辞!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值