融入團隊代碼風格,代碼越寫越爛!
共 20584字,需瀏覽 42分鐘
·
2024-05-09 09:19
往期熱門文章:
1、4 個 GitHub 上令人驚艷的項目! 2、90 后程序員辭職搞灰產(chǎn),不到一年獲利超 700 萬,結局很刑! 3、Redis“叛逃”開源,得罪了幾乎所有人 4、潛伏開源項目3年,混成核心開發(fā)者,竟然只為加一個后門 5、就因為開發(fā)環(huán)境用了 Docker,就被開除了
Alibaba Java Coding Guidelines
CheckStyle
-
代碼規(guī)范檢查:CheckStyle 插件會分析項目中的源代碼,并根據(jù)預定義的規(guī)則檢查代碼,包括縮進、命名約定、代碼注釋、代碼結構等。它可以幫助團隊確保代碼風格一致,符合公司或項目的規(guī)范。
-
自定義規(guī)則:您可以自定義 CheckStyle 規(guī)則,以便根據(jù)您的項目需求和編碼標準添加自定義規(guī)則。這使得 CheckStyle 插件非常靈活,可以適應各種項目。
-
代碼質(zhì)量改進:通過檢查代碼中的潛在問題和不良實踐,CheckStyle 插件可以幫助開發(fā)者識別和修復代碼中的問題,從而提高代碼質(zhì)量。
<?xml version="1.0"?>
<!DOCTYPE module PUBLIC
"-//Puppy Crawl//DTD Check Configuration 1.3//EN"
"http://www.puppycrawl.com/dtds/configuration_1_3.dtd">
<!--checkStyle -->
<module name="Checker">
<!-- 檢查文件是否以一個空行結束 -->
<module name="NewlineAtEndOfFile"/>
<!-- 文件長度不超過1500行 -->
<module name="FileLength">
<property name="max" value="1500"/>
</module>
<!-- 長度檢查 -->
<!-- 每行不超過140個字符 -->
<module name="LineLength">
<property name="fileExtensions" value="java"/>
<property name="max" value="140"/>
<property name="ignorePattern" value="^package.*|^import.*|a href|href|http://|https://|ftp://"/>
</module>
<!--禁止打印e.printStackTrace錯誤信息-->
<module name="RegexpSingleline">
<property name="format" value="printStackTrace"/>
<property name="message" value="Prohibit invoking printStackTrace in source code !"/>
</module>
<!-- 每個java文件一個語法樹 -->
<module name="TreeWalker">
<!-- import檢查-->
<!-- 避免使用* -->
<module name="AvoidStarImport">
<property name="excludes" value="java.io,java.net,java.lang.Math"/>
<!-- 實例;import java.util.*;.-->
<property name="allowClassImports" value="false"/>
<!-- 實例 ;import static org.junit.Assert.*;-->
<property name="allowStaticMemberImports" value="true"/>
</module>
<!-- 檢查是否導入了多余的包 -->
<module name="RedundantImport"/>
<!-- 沒用的import檢查,比如:1.沒有被用到2.重復的3.import java.lang的4.import 與該類在同一個package的 -->
<module name="UnusedImports"/>
<!-- 注釋檢查 -->
<!-- 檢查構造函數(shù)的javadoc -->
<module name="JavadocType">
<!--允許位置的tag如@date,@description等-->
<property name="allowUnknownTags" value="true"/>
<message key="javadoc.missing" value="類注釋:缺少Javadoc注釋。"/>
</module>
<!--方法注釋-->
<module name="JavadocMethod">
<property name="tokens" value="METHOD_DEF"/>
<!--允許get set 方法沒有注釋-->
<!-- <property name="allowMissingPropertyJavadoc" value="true"/>-->
<message key="javadoc.missing" value="方法注釋:缺少Javadoc注釋。"/>
</module>
<!--校驗方法的注釋-->
<module name="MissingJavadocMethod">
<!--允許get set 方法沒有注釋-->
<property name="allowMissingPropertyJavadoc" value="true"/>
<!--允許構造方法沒有注釋-->
<!-- <property name="" value="true"/>-->
<property name="scope" value="private"/>
</module>
<!-- 命名檢查 -->
<!-- 局部的final變量,包括catch中的參數(shù)的檢查 -->
<module name="LocalFinalVariableName"/>
<!-- 局部的非final型的變量,包括catch中的參數(shù)的檢查 -->
<module name="LocalVariableName"/>
<!-- 包名的檢查(只允許小寫字母),默認^[a-z]+(\.[a-zA-Z_][a-zA-Z_0-9_]*)*$ -->
<module name="PackageName">
<property name="format" value="^[a-z]+(\.[a-z][a-z0-9]*)*$"/>
<message key="name.invalidPattern" value="包名 ''{0}'' 要符合 ''{1}''格式."/>
</module>
<!-- 僅僅是static型的變量(不包括static final型)的檢查 -->
<module name="StaticVariableName"/>
<!-- Class或Interface名檢查,默認^[A-Z][a-zA-Z0-9]*$-->
<module name="TypeName">
<property name="severity" value="warning"/>
<message key="name.invalidPattern" value="名稱 ''{0}'' 要符合 ''{1}''格式."/>
</module>
<!-- 非static型變量的檢查 -->
<module name="MemberName"/>
<!-- 方法名的檢查 -->
<module name="MethodName"/>
<!-- 方法的參數(shù)名 -->
<module name="ParameterName "/>
<!-- 常量名的檢查(只允許大寫),默認^[A-Z][A-Z0-9]*(_[A-Z0-9]+)*$ -->
<module name="ConstantName"/>
<!-- 定義檢查 -->
<!-- 檢查數(shù)組類型定義的樣式 -->
<module name="ArrayTypeStyle"/>
<!-- 檢查long型定義是否有大寫的“L” -->
<module name="UpperEll"/>
<!-- 方法不超過100行 -->
<module name="MethodLength">
<property name="tokens" value="METHOD_DEF"/>
<property name="max" value="100"/>
</module>
<!-- 方法的參數(shù)個數(shù)不超過5個。 并且不對構造方法進行檢查-->
<module name="ParameterNumber">
<property name="max" value="5"/>
<property name="ignoreOverriddenMethods" value="true"/>
<property name="tokens" value="METHOD_DEF"/>
</module>
<!-- 空格檢查-->
<!-- 方法名后跟左圓括號"(" -->
<module name="MethodParamPad"/>
<!-- 在類型轉換時,不允許左圓括號右邊有空格,也不允許與右圓括號左邊有空格 -->
<module name="TypecastParenPad"/>
<!-- 檢查在某個特定關鍵字之后應保留空格 -->
<module name="NoWhitespaceAfter"/>
<!-- 檢查在某個特定關鍵字之前應保留空格 -->
<module name="NoWhitespaceBefore"/>
<!-- 操作符換行策略檢查 -->
<module name="OperatorWrap"/>
<!-- 圓括號空白 -->
<module name="ParenPad"/>
<!-- 檢查分隔符是否在空白之后 -->
<module name="WhitespaceAfter"/>
<!-- 檢查分隔符周圍是否有空白 -->
<module name="WhitespaceAround"/>
<!-- 修飾符檢查 -->
<!-- 檢查修飾符的順序是否遵照java語言規(guī)范,默認public、protected、private、abstract、static、final、transient、volatile、synchronized、native、strictfp -->
<module name="ModifierOrder"/>
<!-- 檢查接口和annotation中是否有多余修飾符,如接口方法不必使用public -->
<module name="RedundantModifier"/>
<!-- 代碼塊檢查 -->
<!-- 檢查是否有嵌套代碼塊 -->
<module name="AvoidNestedBlocks"/>
<!-- 檢查是否有空代碼塊 -->
<module name="EmptyBlock"/>
<!-- 檢查左大括號位置 -->
<module name="LeftCurly"/>
<!-- 檢查代碼塊是否缺失{} -->
<module name="NeedBraces"/>
<!-- 檢查右大括號位置 -->
<module name="RightCurly"/>
<!-- 代碼檢查 -->
<!-- 檢查空的代碼段 -->
<module name="EmptyStatement"/>
<!-- 檢查在重寫了equals方法后是否重寫了hashCode方法 -->
<module name="EqualsHashCode"/>
<!-- 檢查子表達式中是否有賦值操作 -->
<module name="InnerAssignment"/>
<!-- 檢查是否有"魔術"數(shù)字 -->
<module name="MagicNumber">
<property name="ignoreNumbers" value="0, 1"/>
<property name="ignoreAnnotation" value="true"/>
</module>
<!-- 檢查switch語句是否有default -->
<module name="MissingSwitchDefault"/>
<!-- 檢查是否有過度復雜的布爾表達式 -->
<module name="SimplifyBooleanExpression"/>
<!-- 檢查是否有過于復雜的布爾返回代碼段 -->
<module name="SimplifyBooleanReturn"/>
<!-- 類設計檢查 -->
<!-- 檢查類是否為擴展設計l -->
<!-- 檢查只有private構造函數(shù)的類是否聲明為final -->
<module name="FinalClass"/>
<!-- 語法 -->
<!-- String的比較不能用!= 和 == -->
<module name="StringLiteralEquality"/>
<!-- 限制for循環(huán)最多嵌套2層 -->
<module name="NestedForDepth">
<property name="max" value="2"/>
</module>
<!-- if最多嵌套3層 -->
<module name="NestedIfDepth">
<property name="max" value="3"/>
</module>
<!-- 檢查未被注釋的main方法,排除以Application結尾命名的類 -->
<module name="UncommentedMain">
<property name="excludedClasses" value=".*[Application,Test]$"/>
</module>
<!-- 禁止使用System.out.println -->
<module name="Regexp">
<property name="format" value="System\.out\.println"/>
<property name="illegalPattern" value="true"/>
</module>
<!-- return個數(shù) 3個-->
<module name="ReturnCount">
<property name="max" value="3"/>
</module>
<!--try catch 異常處理數(shù)量 3-->
<module name="NestedTryDepth ">
<property name="max" value="3"/>
</module>
</module>
</module>
FindBugs
-
靜態(tài)代碼分析:Bug IDEA插件可以執(zhí)行靜態(tài)代碼分析,以檢測潛在的編碼錯誤、代碼風格問題和性能問題。它可以識別諸如未使用的變量、空指針異常、不一致的縮進、未處理的異常等問題。 -
代碼質(zhì)量評估:該插件可以生成代碼質(zhì)量報告,幫助開發(fā)人員了解代碼的質(zhì)量水平。這些報告通常包括代碼復雜性、代碼覆蓋率、代碼重復率等指標。 -
檢查代碼規(guī)范:Bug IDEA插件可以根據(jù)您選擇的編碼標準或規(guī)范檢查代碼,確保團隊的代碼風格一致性,并提供建議以改進代碼。 -
自動修復問題:插件通常提供了自動修復選項,可以幫助開發(fā)人員快速修復代碼中的問題,提高代碼的質(zhì)量和可維護性。 -
安全漏洞檢測:有些Bug IDEA插件還可以檢測潛在的安全漏洞,如SQL注入、跨站腳本攻擊等,以提高應用程序的安全性。 -
代碼重構建議:插件還可以提供有關代碼重構的建議,幫助改進代碼的結構和性能。
SonarLint
往期熱門文章:
1、有人問我數(shù)據(jù)庫ER圖為什么這么好看? 2、我用這10招,能減少了80%的BUG 3、突發(fā)!特斯拉大量毀約應屆生offer… 4、警報炸鍋了,F(xiàn)astJson 又立功了。。 5、一個小公司的技術開發(fā)心酸事(已倒閉) 6、JetBrains 如何看待自己的軟件在中國被頻繁破解? 7、程序員因Bug被要求歸還4萬多年終獎,網(wǎng)友:不還! 8、一套萬能通用的異步處理方案 9、微服務全做錯了!谷歌提出新方法,成本直接降9倍! 10、IntelliJ IDEA 2024 首個大版本發(fā)布,好用到爆!
評論
圖片
表情
