You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
p3c/README.md

51 lines
5.7 KiB
Markdown

6 years ago
<a href="https://detail.tmall.com/item.htm?spm=a1zb6.8232479.0.0.17f533e9VNZxB2&id=575107529181&cm_id=140105335569ed55e27b&abbucket=15"><img src="https://img.alicdn.com/tfs/TB1fJAjcirpK1RjSZFhXXXSdXXa-7068-1201.jpg"></a>
6 years ago
2018年9月22日在2018杭州云栖大会上召开《码出高效Java 开发手册》新书发布会并宣布将图书所有收益均捐赠于技术公益项目“83行代码计划”。
6 years ago
阿里巴巴正式在2018杭州云栖大会《开发者生态峰会》上由阿里巴巴高年级同学中间件负责人林昊、阿里巴巴研究员刘湘雯、阿里巴研究员刘国华OpenJDK社区Committer杨晓峰全栈视障工程师蔡勇斌电子工业出版社博文视点出版公司总经理郭立以及两位图书作者杨冠宝孤尽和高海慧鸣莎重磅大咖联合发布新书[《码出高效Java开发手册》跳转至天猫书店](https://detail.tmall.com/item.htm?spm=a1zb6.8232479.0.0.17f533e9VNZxB2&id=575107529181&cm_id=140105335569ed55e27b&abbucket=15)并宣布将图书所有收益均捐赠于技术公益项目“83行代码计划”第一个“83行代码计划”行动将围绕着帮助盲人工程师开发更多无障碍化产品让盲人上网更便捷。未来我们会坚持用技术为公益行业赋能也希望更多人成为技术受益者<
6 years ago
![](https://img.alicdn.com/tfs/TB1fxuedAvoK1RjSZFDXXXY3pXa-1465-603.png)
7 years ago
7 years ago
2017年10月14日杭州云栖大会Java代码规约扫描插件全球首发仪式正式启动规范正式以插件形式公开走向业界引领Java语言的规范之路。目前插件已在[云效公有云产品](https://www.aliyun.com/product/yunxiao)中集成,[立即体验](https://rdc-test.aliyun.com)!(云效>公有云>设置->测试服务->阿里巴巴Java代码规约
7 years ago
7 years ago
# P3C
7 years ago
7 years ago
[![License](https://img.shields.io/badge/license-Apache%202-4EB1BA.svg)](https://www.apache.org/licenses/LICENSE-2.0.html)
7 years ago
7 years ago
## <font color="green">Preface</font>
> We are pleased to present Alibaba Java Coding Guidelines which consolidates the best programming practices over the years from Alibaba Group's technical teams. A vast number of Java programming teams impose demanding requirements on code quality across projects as we encourage reuse and better understanding of each other's programs. We have seen many programming problems in the past. For example, defective database table structures and index designs may cause software architecture flaws and performance risks. Another example is confusing code structures being difficult to maintain. Furthermore, vulnerable code without authentication is prone to hackers attacks. To address these kinds of problems, we developed this document for Java developers at Alibaba.
7 years ago
For more information please refer the *Alibaba Java Coding Guidelines*:
- 中文版: *[阿里巴巴Java开发手册](https://github.com/alibaba/p3c/blob/master/%E9%98%BF%E9%87%8C%E5%B7%B4%E5%B7%B4Java%E5%BC%80%E5%8F%91%E6%89%8B%E5%86%8C%EF%BC%88%E8%AF%A6%E5%B0%BD%E7%89%88%EF%BC%89.pdf)*
7 years ago
- English Version: *[Alibaba Java Coding Guidelines](https://alibaba.github.io/Alibaba-Java-Coding-Guidelines)*
6 years ago
- 《阿里巴巴Java开发手册》书籍版天猫官方店: *[阿里巴巴JAVA开发手册最新版](https://detail.tmall.com/item.htm?spm=a1z2e.8325951.feedDetail.4.3315431gklIXe&id=562626792765&ns=1&abbucket=14)*
- 《码出高效》书籍版天猫官方店: *[码出高效Java开发手册](https://detail.tmall.com/item.htm?spm=a230r.1.14.40.7dee7d6bwpO82U&id=575107529181&ns=1&abbucket=20)*
7 years ago
7 years ago
## <font color="green">Introduction</font>
The project consists of 3 parts:
- [PMD implementations](p3c-pmd)
- [IntelliJ IDEA plugin](idea-plugin)
- [Eclipse plugin](eclipse-plugin)
7 years ago
7 years ago
## <font color="green">Rules</font>
<font color="blue">Forty-nine rules are realized based on PMD, please refer the P3C-PMD documentation for more detailed information. Four rules are implemented within IDE plugins (IDEA and Eclipse) as follows:</font>
7 years ago
7 years ago
- ``[Mandatory]`` Using a deprecated class or method is prohibited.
Note: For example, decode(String source, String encode) should be used instead of the deprecated method decode(String encodeStr). Once an interface has been deprecated, the interface provider has the obligation to provide a new one. At the same time, client programmers have the obligation to check out what its new implementation is.
- ``[Mandatory]`` An overridden method from an interface or abstract class must be marked with @Override annotation.
Counter example: For getObject() and get0bject(), the first one has a letter 'O', and the second one has a number '0'. To accurately determine whether the overriding is successful, an @Override annotation is necessary. Meanwhile, once the method signature in the abstract class is changed, the implementation class will report a compile-time error immediately.
- ``[Mandatory]`` A static field or method should be directly referred by its class name instead of its corresponding object name.
- ``[Mandatory]`` The usage of hashCode and equals should follow:
1. Override hashCode if equals is overridden.
2. These two methods must be overridden for Set since they are used to ensure that no duplicate object will be inserted in Set.
3. These two methods must be overridden if self-defined object is used as the key of Map.
7 years ago
Note: String can be used as the key of Map since these two methods have been rewritten.
7 years ago
## Join us
7 years ago
If you have any questions or comments, please contact junlie by email at caikang.ck@alibaba-inc.com, and please join us to make project P3C perfect for more programmers.
7 years ago
7 years ago
Please follow our WeChat official account as ali_yunxiao below:
7 years ago
![](https://gw.alicdn.com/tfscom/TB1TrNcXjv85uJjSZFNXXcJApXa.png)