代码统计分析工具(SourceCounter)- 开发工作量估算、测试用例、统计缺陷预测工具
代码统计分析工具概览 代码统计分析工具是源码一款强大的开发辅助软件,专为代码统计、统计工作量估算和缺陷预测设计。源码最新版本的统计4.0更新了界面至wxWidgets 3.1.4,修复了编译错误并优化了图标。源码以下是统计工具的核心功能和使用指南。功能概览
支持多种源代码格式,源码如C++、VB.Net等,全面统计代码行数、注释、空行和文件大小等数据。
分析软件项目开发阶段的数据,包括工时、成本和质量指标,如单元测试、结合测试的缺陷密度预测。
导出统计结果为CSV或HTML格式,便于数据分析和报告制作。
灵活设置统计范围,支持多目录递归统计,自定义文件扩展名。
提供工数、成本和质量指标的组态软件源码价格预测功能,支持单元测试和结合测试阶段的预测。
主界面详解
主界面由菜单栏、工具栏、统计设定和分析参数面板,以及结果、过滤器和状态栏构成。工具栏包含了导出、过滤器控制、全屏切换等功能键。使用教程
1. 设置统计目录:选择要分析的代码文件,可选中子目录并设定代码类型。 2. 开始统计:点击"开始",实时查看统计结果,可随时暂停或继续。分析参数
参数包括编码效率、成本系数和测试密度等,需要根据实际情况调整。结果展示
结果面板提供详细分类,如文件、目录、总计和报表,支持排序和筛选。导出与联系
软件支持HTML和CSV导出,便于分享和进一步分析。联系可通过微信或邮件获取帮助。dev C++和codeblocks有什么区别
两者在是否可以跨平台和是否可以支持code folder两方面存在区别。一、是否可以跨平台
dev C++:Dev C++不能跨平台,只能在Windows下用。
codeblocks:CodeBlocks是跨平台的,在Windows、ectouch微营销源码Linux、Mac OS等多个平台下都可以使用。
二、是否可以支持code folder
dev C++:不能支持code folder。
codeblocks:可以支持code folder。
扩展资料
Code::Blocks是开放源码软件。Code::Blocks由纯粹的C++语言开发完成,它使用了著名的图形界面库wxWidgets(2.6.2 unicode)版。对于追求完美的C++程序员,再也不必忍受Eclipse的缓慢。
主要特点
1、从年3月日版本:1.0 revision 开始,Code::Blocks在它的每日构建中正式提供GNU/Linux版本,这样 Code::Blocks在1.0发布时就成为了跨越平台的C/C++IDE,支持Windows和GNU/Linux。
由于其开放源码的特点,Windows用户可以不依赖于VS. NET,编写跨平台C++应用。
2、Code::Blocks提供了许多工程模板。
这包括:控制台应用、DirectX应用、动态连接库、FLTK应用、GLFW应用、Irrlicht工程、OGRE应用、OpenGL应用、QT应用、SDCC应用、SDL应用、openjdk源码怎么下载SmartWin应用、静态库、Win GUI应用、wxWidgets应用、wxSmith工程。
另外还支持用户自定义工程模板。在wxWidgets应用中选择UNICODE支持中文。
3、Code::Blocks支持语法彩色醒目显示,支持代码完成,支持工程管理、项目构建、调试。
Code::Blocks支持插件,包括代码格式化工具AStyle;代码分析器;类向导;代码补全;代码统计;编译器选择;复制字符串到剪贴板;调试器;文件扩展处理器;Dev-C++DevPak更新/安装器。
DragScroll,源码导出器,帮助插件,键盘快捷键配置,插件向导;To-Do列表;wxSmith;wxSmith MIME插件;wsSmith工程向导插件;Windows7外观。
百度百科-Code::Blocks
源代码审计工具之:SonarQube
SonarQube是一个开源的代码分析平台,用于持续分析和评估项目源代码的质量。它能检测出项目中的重复代码、潜在bug、代码规范和安全性漏洞等问题,并通过web UI展示结果。
1. Sonar简介
1.1 SonarQube是什么?
1. 代码质量和安全扫描和分析平台。
2. 多维度分析代码:代码量、安全隐患、编写规范隐患、重复度、手机抓取软件源码复杂度、代码增量、测试覆盖率等。
3. 支持+编程语言的代码扫描和分析,包括Java、Python、C#、JavaScript、Go、C++等。
4. 涵盖了编程语言的静态扫描规则:代码编写规范和安全规范。
5. 能够与代码编辑器、CI/CD平台完美集成。
6. 能够与SCM集成,可以直接在平台上看到代码问题是由哪位开发人员提交。
7. 帮助程序猿写出更干净、更安全的代码。
静态扫描主要针对开发人员编写的源代码。
通过定义好的代码质量和安全规则,对开发人员编写的代码进行扫描和分析。
将分析的结果多维护的呈现出来,以方便开发人员进行代码的优化和规范编写。
1.2 SonarQube的各个功能:
1.2.1 代码可靠性
1. BUG检测
2. 设置需要的代码标准
3. 代码异味
4. 代码安全性
5. 对于开发的各个路径进行检测
1.2.2 软件安全性
1. Security Hotspots: 代码存在安全问题的部分
2. Vulnerabilities: 代码是否存在漏洞
1.3 SonarQube如何工作?
Sonar静态代码扫描由两部分组成:SonarQube平台和sonar-scanner扫描器。
SonarQube: web界面管理平台。
1)展示所有的项目代码的质量数据。
2)配置质量规则、管理项目、配置通知、配置SCM等。
SonarScanner: 代码扫描工具。
专门用来扫描和分析项目代码。支持+语言。
代码扫描和分析完成之后,会将扫描结果存储到数据库当中,在SonarQube平台可以看到扫描数据。
SonarQube和sonarScanner之间的关系:
2 检测
Sonar是一个用于代码质量管理的开源平台,用于管理源代码的质量,可以从七个维度检测代码质量。通过插件形式,可以支持包括Java、C#、C/C++、PL/SQL、Cobol、JavaScript、Groovy等等二十几种编程语言的代码质量管理与检测。
2.1 Rules提示
2.1.1 Rule界面
2.1.2 Rule正确实例提示
2.2 糟糕的复杂度分布
文件、类、方法等,如果复杂度过高将难以改变,这会使得开发人员难以理解它们,且如果没有自动化的单元测试,对于程序中的任何组件的改变都将可能导致需要全面的回归测试。
2.3 重复
显然程序中包含大量复制粘贴的代码是质量低下的,Sonar可以展示源码中重复严重的地方。
2.4 缺乏单元测试
Sonar可以很方便地统计并展示单元测试覆盖率。
2.5 没有代码标准
Sonar可以通过PMD、CheckStyle、Findbugs等等代码规则检测工具规范代码编写。
2.6 没有足够的或者过多的注释
没有注释将使代码可读性变差,特别是当不可避免地出现人员变动时,程序的可读性将大幅下降,而过多的注释又会使得开发人员将精力过多地花费在阅读注释上,亦违背初衷。
2.7 潜在的bug
Sonar可以通过PMD、CheckStyle、Findbugs等等代码规则检测工具检测出潜在的bug。
2.8 糟糕的设计(原文Spaghetti Design,意大利面式设计)
通过Sonar可以找出循环,展示包与包、类与类之间的相互依赖关系,可以检测自定义的架构规则;通过Sonar可以管理第三方的jar包,可以利用LCOM4检测单个任务规则的应用情况,检测耦合。
3. Sonar组成
4. Sonar集成过程
开发人员在他们的IDE中使用SonarLint运行分析本地代码。
开发人员将他们的代码提交到代码管理平台中(SVN、GIT等),
持续集成工具自动触发构建,调用SonarScanner对项目代码进行扫描分析,
分析报告发送到SonarQube Server中进行加工,
SonarQube Server加工并且保存分析报告到SonarQube Database中,通过UI显示分析报告。
请问谁有在线统计的源码提供一下,最好能帮设计像以下的效果:在此先谢谢了。 好像有JS和HTML网页,我
这个功能我已经用javascript实现了,但是个人对CSS不太了解,做出来的外观不太像,如果看不懂源代码,联系我。<!DOCTYPE htmlPUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"/ajax/libs/jquery/1.8.0/jquery.min.js"></script>
<script >
$(document).ready(function(){
//$("div").focus(function(){
// $("div").animate({ center:'px'});
//});
function preconditioning(content){
content = content.replace(/\n/g,""); // 去掉换行符
//处理纯空格的字符串
if(content.replace(/[" "]/g,"").length==0){
//alert("it has spaces");
content="";
}
//alert(content.length);
return content;
}
function generateObjectArray(content){
//词组的边界,默认为[ 和 ]
var size = content.length;
var fi=0;
var ei=0;
var entity;
var entitis = new Array();
var i = 0;
//字符串最后面有空格时,会出现异常,具体原因不明
//alert(size);
//所以,应该去掉这些多余的空格
size = content.lastIndexOf("]")+1;
while(i<size){
fi = content.indexOf("[",ei);
ei = content.indexOf("]",ei+1);
i=ei+1;
//alert(str[i]);
entity = content.substring(fi+1,ei);
// alert("the entity is :"+entity);
// alert("the current index is :"+i);
entitis.push(entity);
}
// alert("数组中的结果"+entitis);
return entitis;
}
$("#count").click(function(){
var draftContent = $("#draftContent").val();
var objectCotnent = $("#objectContent").val();
var errormessage ;
draftContent = preconditioning(draftContent);
objectCotnent = preconditioning(objectCotnent);
if(draftContent.length==0||objectCotnent.length==0){
alert("你妹的,你什么都不写,我怎么测试?");
return;
}
//alert("待统计的名单为:"+draftContent);
//alert("统计对象为:"+objectCotnent);
var draftArray = generateObjectArray(draftContent);
var objectArray = generateObjectArray(objectCotnent);
var result ="the result is ";
//alert(draftArray);
//alert(objectArray);
for(x in objectArray){
var object = objectArray[x];
var num =0;
for(y in draftArray){
var draft = draftArray[y];
if(object==draft){
num = ++num;
}
}
result = result+"\n"+ num+"次 :"+ object;
}
//alert(result);
$("#resultContent").val(result);
});
$("#btn_countInput").click(function(){
$("#draftContent").val("");
});
$("#btn_PatterInput").click(function(){
$("#objectContent").val("");
});
$("#btn_result").click(function(){
$("#resultContent").val("");
});
});
</script>
<title>在线统计器</title>
</head>
<body>
<div class="border" >
<div id="title">
<h1 >在线统计器</h1>
</div>
<div id="functionArea">
<div>
<p><input type="button" id="btn_countInput" value="请输入草稿名单"/></p>
<textarea id="draftContent">
</textarea>
</div>
<div >
<p><input type="button" id="btn_PatterInput" value="请输入统计对象"/></p>
<textarea id="objectContent">
</textarea>
<input id="count" type="button" value="进行统计"></input>
</div>
<div id="result">
<p><input type="button" id="btn_result" value="统计结果"/></p>
<textarea id="resultContent">
</textarea>
</div>
<div id="prompt">
<p>注意事项
<ul>
<li>本统计器用于统计草稿中,对应统计对象出现的次数</li>
<li>草稿和统计对象词组,每个词组都应该用[]括起来</li>
<li>后期会提供多样的选择,例如,对于中文,用做词组边界</li>
</ul>
</p>
</div>
</div>
</div>
</body>
</html>
怎么统计JAVA代码行数?有什么工具?
要统计JAVA代码行数,可以利用源代码行数统计器1.5这款工具。该软件专为统计软件工程源代码行数设计,能够对指定的子目录或整个目录树中的所有指定类型的源代码文件进行行数统计。
使用源代码行数统计器1.5,首先需要确保软件已正确安装并配置到你的开发环境。接着,根据实际需求,选择要统计行数的目录。无论是单个子目录还是整个目录树,均可轻松实现统计。
对于JAVA代码,软件会自动识别并统计包括注释在内的所有行数。这不仅包括代码逻辑行,还包括空行和注释行,为开发者提供详尽的统计结果。
除了统计代码行数外,源代码行数统计器1.5还支持多种编程语言的源代码统计,包括但不限于C、C++、Python、JavaScript等。这使得开发者在进行多语言项目开发时,也能轻松获取各类代码文件的行数统计信息。
借助这款工具,开发者能够更直观地了解项目的代码规模,有助于项目管理、代码审查和维护等工作。通过统计代码行数,可以直观地判断代码量的增减,有助于评估项目的复杂度和规模,从而做出合理的时间和资源规划。
总的来说,源代码行数统计器1.5是一款高效、易用的工具,它能帮助开发者快速准确地统计JAVA及多种其他编程语言的代码行数,为项目管理和代码维护提供有力支持。
.NET开源、强大的Web报表统计系统
CellReport,一个专为.NET环境设计的开源、强大Web报表统计系统。此系统旨在快速生成统计报表,满足日常需求。CellReport以复杂统计报表为核心目标,提供直观的界面,支持多种数据源,包括数据库、Excel文件、API服务、现有报表等。内置集合函数,灵活组织数据,实现类Excel界面展示结果。
CellReport技术实现上,前端设计器基于Vue、luckysheet、echarts等现代前端技术,实现高效、动态的报表制作界面。后端报表引擎则依托.NET6框架,确保高性能的计算与处理能力。
CellReport项目源代码清晰可读,提供丰富的功能和特性,感兴趣的开发者可以通过访问项目开源地址,探索更多内容。项目地址:gitee.com/NoneDay/CellR...在线文档地址:noneday.gitee.io/cellre...
CellReport已入选C#/.NET/.NET Core优秀项目和框架精选,通过关注精选可实时获取相关领域的最新动态和最佳实践,提高开发效率。如您认为项目有价值,欢迎提交PR或自荐,让优秀项目不被埋没,地址:github.com/YSGStudyHard...
欢迎加入DotNetGuide技术社区微信交流群,与更多开发者共享知识,共同成长。
2024-12-29 08:42
2024-12-29 08:39
2024-12-29 08:31
2024-12-29 07:46
2024-12-29 06:37