CodeMetric启动后(以下图)html
代码统计主要包括:注释行、空白行、代码行、总行数(不包括空白行)、总行数(包括空白行)、注释率、空白率、字符数。(也就是下图里面的度量项)java
1、经过点击按钮添加目录/文件添加须要统计的目录/文件。windows
2、选择好代码语言类型,代码文件后缀输入框里面的内容,会自动变成选择的代码语言类型默认文件的后缀,也能够自定义添加代码文件后缀。后端
3、勾选想要统计的度量项。服务器
4、点击度量按钮即可以进行统计。svn
统计输出格式主要分为两种:简单输出格式和XML输出格式。工具
1、简单输出格式:测试
2、XML输出格式:网站
对比两种统计输出格式:spa
1、简单文本格式:可读性仍是比较清晰的。
2、XML格式:可读性通常,看起来比较繁杂一点。
两个细节问题:
1、注释里面的空白行会计算进去,统计注释行数与实际注释行数有所偏高。
2、显示细节错误:注释率(SLOC/TTL) ——〉注释率(CMTL/TTL)
除去上面两个细节问题,总体上来看还算不错,功能比较简单。
启动ICodeStat后,能够看到ICodeStat主要有四个功能,分别是:批处理、版本比较、脚本拆分、代码统计。(以下图)
代码统计主要包括:注释行、空白行、代码行、总行数(不包括空白行)、总文件数、注释率、空白率。
1、经过选择代码统计功能,下面的组合输入框变为文件类型和文件夹,文件类型能够经过输入框选择预先设置好的类型,也能够手工修改和输入,文件夹能够手工输入也能够经过目录选择对话框选择。
2、选择好文件类型和文件夹后,点击处理就能够开始代码统计工做,经过选择文件类型,能够实现对不一样类型的代码进行分别统计的目的。
3、统计完成后,在下面的统计结果栏中会显示整体的统计结果,在列表框中会保存每一个文件的统计结果。
统计输出相似表格的形式,以下图:
统计输出格式以相似表格的输出方式展示,看起来一目了然。
统计准确,无偏差,推荐使用。
StatSVN是一个Java写的开源代码统计程序,从statCVS移植而来,可以从Subversion版本库中取得信息,而后生成描述项目开发的各类表格和图表。好比:代码行数的时间线;针对每一个开发者的代码行数;开发者的活跃程度;开发者最近所提交的;文件数量;平均文件大小;最大文件;哪一个文件是修改最屡次数的;目录大小;带有文件数量和代码行数的Repository tree。StatSVN当前版本可以生成一组包括表格与图表的静态HTML文档。
StartSVN官网地址为:http://www.statsvn.org/index.html
StartSVN的下载页面为:http://www.statsvn.org/downloads.html
如今官网上最新的版本为:statsvn-0.7.0
StatSVN的运行须要Java的运行环境支持,因此你们须要安装Java的运行环境(Java Runtime Environment)。JRE能够从Sun的网站上下载。
Statsvn在使用中须要使用SVN的客户端,所以须要确保机器上能够访问到SVN的客户端命令
首先从SVN仓库中checkout一个须要统计的路径(若是在工做目录下进行统计,首先请更新,保证工做区中的版本是最新的版本,确保统计结果的准确性),例如我把个人某个路径下的工程checkout在个人电脑上的D:\MyProjects路径下。
首先经过命令行进入工做目录:D:\MyProjects ,再使用svn log -v --xml > logfile.log的命令,其中logfile.log为log文件的名称,能够根据须要自行定义。这样就在工做拷贝的目录下生成一个名称为logfile.log的文件。
注:要在命令行中使用svn命令,在安装TortoiseSVN时必须选择安装commend组件,能够在cmd命令行里输入svn help测试一下该组件是否安装,若是未安装是没法使用svn log命令的。若是可以操做svn server的话也能够直接在服务器上生成svn log而后下载到本地来使用
首先咱们把从官网上下载的statsvn-0.7.0.zip包解压缩到D:\statsvn-0.7.0目录下
经过命令行进入D:\statsvn-0.7.0目录
调用命令java -jar statsvn.jar D:\MyProjects\logfile.log D:\MyProjects,命令运行成功即完成了统计工做。
该命令的格式是java -jar statsvn.jar [options] <logfile> <checked-out-module>
参数<logfile>为前一步中生成的svn log文件,<checked-out-module>为checkout工做拷贝目录,注意两个参数都要列出正确的全路径,不然会提示错误如logfile.log找不到等等
1. 先导出svn log
svn log -v --xml -rStartrevision:Endrevision > svn.log local_project
其中Startrevision和Endrevision用来导出一个revision段的svn日志.local_project是svn上的project checkout到本地的结果.
2. 经过statsvn工具作分析
java -jar statsvn.jar svn.log local_project
运行完成后,就会在$PWD(unix下)或者%CD%(windows下)下生成对应的分析文件,在index.html文件中就有代码量统计。
输出以html的方式展现统计内容。(以下图)
优势
1、StatSVN会把当前SVN库的状态用图片和图表的方式展示出来,能够按不一样分类分别展开,功能强大。
缺点
1、StatSVN统计的是全部代码行,包括注释和空行,但通常度量要求是有效代码行,在分析时须要注意这一点。
2、StatSVN不考虑修改的代码行数,只考虑与上一版本相比新增(+)与删除(-)的代码行数。
统计结果以图标的形式表现,功能比较强大,由于统计的内容比较多,我的感受准确率通常。
diffcount代码行差别统计工具,用于比较两个代码包的新增,修改,删除的代码量.资源挺好的,统计出来的结果和我本身统计的有些差别。能够统计的文件类型有些少,并且偏后端语言。另外,在windows下使用的时候,直接敲命令行便可。
1. 差别统计:统计某一个版本的代码包相对于一个原始的基线代码包,变更的代码量,以及变更的代码量中各语言非空非注释行(NBNC)的结果;
2.代码统计:若是须要,能够把diffcount看成普通的代码行统计工具,统计一个代码包;
diffcount命令行方式的编译是直接经过Makefile进行的,目前提供Linux,Cygwin,Windows(MinGW)三种环境下的编译脚本,其余环境中,若是须要编译和使用,请经过修改Makefile文件进行。
diffcount 的可执行程序名为 diffcount.exe
想查询参数信息,请使用 diffcount --help 查询帮助
diffcount --cn-help 能够查询中文帮助, 也能够查看doc下的"命令行参数说明.txt"
diffcount的参数说明:
使用方法: diffcount [OPTION]... (Baseline) Target
功能:对两个代码包进行差别统计、或者对一个代码包进行代码行统计packages 是差别统计的两个对象,也能够是仅做统计的一个对象
-c --count-only FILE/DIR
仅仅对一个文件或者目录完成统计代码行的功能,没有比较对象,这样Packages参数的数量只能有一个(文件或目录)
--ignore-case (DIFF USE ONLY)
在比较的时候,忽略文件名的大小写差别(缺省状况会做为两个彻底不一样的文件)仅在“差别统计”时有效。
Tips: 一些产品的代码,存在不一样的版本的目录和文件的大小写不同的状况多是copy或者传送过程当中形成的,对于这种状况,请使用该开关。
--print-lines-info (DEBUG USE OLY)
输出每一个文件差别比较后的差别结果和初步统计信息(逐行),主要用于分析错误,
注意不要针对大型代码包使用,不然逐行打印时间消耗惊人
--print-files-info
使用这个开关,当每一个文件差别比较和统计之后,输出该文件差别统计的结果信息
缺省不打印每一个文件的信息,只打印最后的结果
Tips: 上边两个开关都须要打印控制台,若是文件较多的话,打印的时间会很长
所以除非有具体分析须要,不然尽可能不要打开
--force-parse-all (DIFF USE ONLY)
强制对全部文件进行分析处理(即便它们是彻底相同的),缺省对彻底相同的文件略过
仅在“差别统计”时有效,代码行统计(count-only)时全部文件都要处理
--for-program-reading
改变输出方式,以格式化文本形式输出,便于其余程序读取结果信息在由第三方程序调用diffcount,并须要读取统计结果的时候使用,该选项会屏蔽--print-lines-info选项
-v --version
输出当前的版本信息
--help
输出帮助信息
1.差别统计
统计某一个版本的代码包相对于一个原始的基线代码包,变更的代码量以及变更的代码量中各语言非空非注释行(NBNC)的结果
diffcount 缺省执行的就是差别统计,直接跟上两个代码包的目录便可
在diffcount目录下执行:
diffcount test\sp1 test\sp2
实际使用中,可能会有文件名和目录名大小写不一致的状况,若是但愿忽略文件名大小写的差别,须要使用 --ignore-case参数,不然两个同样的文件,一个会算做删除,一个会算做新增
ADD MOD DEL A&M BLK CMT NBNC RATE 的 含义分别为:新增、修改、删除、新增+修改、空行、注释、非空非注释行、标准C折算率
2、代码统计:
若是须要,能够把diffcount看成普通的代码行统计工具,统计一个代码包
代码统计使用 -c (或者--count-only)参数,在diffcount目录下执行
diffcount -c test\count
执行结果以下:
Diffcount主要功能包括代码统计和差别统计,代码统计操做经过命令式方式操做,整体操做还算简单,适合开发者操做,代码统计相对于上面其余三个没特别优点,若是是想用差别统计推荐使用Diffcount。