编程规约
- For variable name, always use English with lowerCamelCase.
data:image/s3,"s3://crabby-images/d02c3/d02c3fd15c639e1f233b8f35b2e8099e2c006722" alt=""
space in comment:
data:image/s3,"s3://crabby-images/a7925/a7925b9ad29bb7852c368d3b06b4bc02ebb63b72" alt=""
bad example:
data:image/s3,"s3://crabby-images/2d42f/2d42f43af5fd4ad6d590794633955a7b6bd7a417" alt=""
Suggestion: 与其“半吊子”英文来注释,不如用中文注释把问题说清楚。专有名词与关键字保持英文原文即可。
谨慎注释掉代码。在上方详细说明,而不是简单地注释掉。如果无用,则删除。 说明:代码被注释掉有两种可能性:1)后续会恢复此段代码逻辑。2)永久不用。前者如果没有备注信息,难以知晓注释动机。后者建议直接删掉(代码仓库保存了历史代码)。
-
Do not mix production code with test code. All testing codes must be put to folder src\test\java.
-
Constant:
data:image/s3,"s3://crabby-images/9e373/9e373b53bfb35aecdafb6180d2734e1c92f9f4d9" alt=""
data:image/s3,"s3://crabby-images/c1577/c157773325f22c49e9d6ecd35c84d1690f99c80f" alt=""
data:image/s3,"s3://crabby-images/0ae63/0ae637f99682b00f8b644261f312433156ffcada" alt=""
-
For boolean variable in POJO, no "is" prefix is allowed.
-
Always use meaningful naming for self-descriptive purpose.
data:image/s3,"s3://crabby-images/51c6f/51c6f5d7707e80cefd26939cf83d19a3af05b5e1" alt=""
Bad example: no prefix for local variable.
data:image/s3,"s3://crabby-images/4afaa/4afaa65e9ab641345bf369c1457a423f7d540534" alt=""
- Naming per layer
data:image/s3,"s3://crabby-images/6eb53/6eb53964b2f68877383f622695c8defed9b5acf1" alt=""
- Bracket usage
if( XXX ){
yyy;
}
if( XXX ){
yyy;
} else{
}
- space usage
data:image/s3,"s3://crabby-images/175e3/175e3daa931ed0d67505bbe70b42c3bd348107d8" alt=""
bad example:
data:image/s3,"s3://crabby-images/ecf3b/ecf3b12354370649dea5d1285472791844884f88" alt=""
space between method and argument:
data:image/s3,"s3://crabby-images/2fd32/2fd32c3e5d1a27b9d40f10b7882b4b72b4583b92" alt=""
bad example:
data:image/s3,"s3://crabby-images/630bb/630bb0afe1b01ec64911af976dbaac4d813ab346" alt=""
- new line usage
guideline:
data:image/s3,"s3://crabby-images/add9e/add9e91f1ff17d4fedef7587fc158eea2165e4ce" alt=""
bad example:
data:image/s3,"s3://crabby-images/2d658/2d65898d0fc08551a7aa4d1a2b4ca87d1b616a81" alt=""
- text file encoding
IDE text file encoding: UTF-8; IDE new line format: use Unix instead of Windows
IDE setting:
data:image/s3,"s3://crabby-images/cadfc/cadfc22dcf1f71036f6088dab1d391d0a19a5384" alt=""
why we should set this property
- basic type and wrapper object
data:image/s3,"s3://crabby-images/19c6d/19c6d9a76304cae95b5ec052152643f7e5201e1e" alt=""
-
No business logic is allowed in constructor. If initialization logic is needed, put it in init().
-
class method sequence
public method > protected > private > getter / setter
data:image/s3,"s3://crabby-images/4d032/4d0329ac84f4fd5aad2d1d93364820c9842f2119" alt=""
- No business logic in setter/getter
data:image/s3,"s3://crabby-images/24c1b/24c1b6e97e73c71dca41325e143e2397d08e3bb1" alt=""
- Bracket is mandatory in if/else/for/while/do.
Bad example:
if (condition) statements;
Better to use if XXX return; instead of if XXX else YYY:
data:image/s3,"s3://crabby-images/efc6f/efc6f97ef577755723d38f9b52b37b0ec34700b7" alt=""
参考文档
更多Jerry的原创文章,尽在:"汪子熙":
data:image/s3,"s3://crabby-images/5c245/5c2451227ab390a16b5fe9bdbec5d83178d7661c" alt=""
网友评论