java 代码风格指导文档及相关工具
codestyle_guide.md
代码风格指导文档config.xml
对应文档的checkstyle配置文件README.md
项目指南
- 2019/02/13 更新v1.0版本文档和v1.0版本的配置文件
- 2019/02/14 基本完善项目版本,并完成配置文件的简单验证
- 2019/02/25 修复常量命名的问题,改为建议规则。由于没有对应的常量检查规则,所以checkstyle检查到连续的大写字母命名时会报错,请大家以
config.xml
中实际配置为准。(这里感谢17373348刘宸同学)
- 每次作业代码风格部分默认总分为100分,采用扣分制
- 对于设计风格类(即风格文档的第六节)部分
- 类长度风格问题,每个扣50分
- 可见性检查、方法长度问题,每个扣20分
- 参数个数、循环嵌套、语句嵌套问题,每个扣10分
- 嵌套内联条件、布尔表达式、参数赋值问题,每个扣5分
- 对于命名约定类(即风格文档第五章)部分
- 所有的问题,每个扣5分
- 对于除此之外的问题,每个扣2分
- 对于所有的问题扣分上不封顶,扣到0分为止
A:我们会使用一个叫做checkstyle
的Java代码风格检查工具进行代码风格的检查。其中配置文件使用本仓库内提供的config.xml
文件,作为代码风格检查的依据。
值得注意的是,我们的检查对象为你的代码仓库内全部的.java
文件,其他的文件会被系统自动忽略。
A:当然可以。你们有以下几种方法检测自己的代码风格:
-
从Checkstyle官网上下载checkstyle的jar文件,并在本机按照help里提供的命令行参数进行代码风格的检查。
-
对于ubuntu(应该其他unix系统也行,但是只在ubuntu上试过)用户,可以使用我们封装的
pycheckstyle
Python包进行快速代码风格检测(目前仅支持Python3) -
【推荐】对于IDEA用户,可以下载安装
Checkstyle-IDEA
插件(见下文),对ide内的代码进行实时风格检测。只需要安装好插件后在设置中将我们提供的config.xml
载入即可。(更详细的攻略可以自行百度) -
对于Eclipse用户,实际上也存在checkstyle支持,可以自行百度探索。
A:我们的文档主要是将官方文档中相关的部分进行一些较为通俗的解释,可能有些细节上确实不够,也有可能存在少量的偏差。对于这样的情况,我们以checkstyle的官方文档,以及checkstyle
在使用config.xml
时的实际检查结果为准。
A:在我们提供的风格文档中,均将配置文件中的对应部分写了出来。可以根据module
的name
字段信息,在官方文档上查找对应的规则以及说明。
- Checkstyle官方文档(全英文版)
- Google官方代码规范(我们所使用的代码规范的原型)
- Sun官方代码规范
- 【推荐】IDEA Checkstyle插件主页
- 【课程组提供】pycheckstyle封装包
- [PaParaZz1]
- HansBug,邮箱:hansbug@questionor.cn
如有问题或建议,欢迎联系作者。