国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

如何提高代碼性能、使代碼遠離Bug、令代碼更優雅

奈因PCB電路板設計 ? 來源:博客園 ? 作者:濤姐濤哥 ? 2021-08-17 09:42 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

背景:如何更規范化編寫Java代碼的重要性想必毋需多言,其中最重要的幾點當屬提高代碼性能、使代碼遠離Bug、令代碼更優雅。

一、MyBatis不要為了多個查詢條件而寫1=1

當遇到多個查詢條件,使用where 1=1 可以很方便的解決我們的問題,但是這樣很可能會造成非常大的性能損失,因為添加了 “where 1=1 ”的過濾條件之后,數據庫系統就無法使用索引等查詢優化策略,數據庫系統將會被迫對每行數據進行掃描(即全表掃描) 以比較此行是否滿足過濾條件,當表中的數據量較大時查詢速度會非常慢;此外,還會存在SQL 注入的風險。

反例:

《select id=“queryBookInfo” parameterType=“com.tjt.platform.entity.BookInfo” resultType=“java.lang.Integer”》 select count(*) from t_rule_BookInfo t where 1=1《if test=“title !=null and title !=‘’ ”》 AND title = #{title} 《/if》 《if test=“author !=null and author !=‘’ ”》 AND author = #{author}《/if》 《/select》

正例:

《select id=“queryBookInfo” parameterType=“com.tjt.platform.entity.BookInfo” resultType=“java.lang.Integer”》 select count(*) from t_rule_BookInfo t《where》《if test=“title !=null and title !=‘’ ”》 title = #{title} 《/if》《if test=“author !=null and author !=‘’ ”》 AND author = #{author}《/if》《/where》 《/select》

UPDATE 操作也一樣,可以用《set》 標記代替 1=1。

二、迭代entrySet()獲取Map的key和value

當循環中只需要獲取Map 的主鍵key時,迭代keySet() 是正確的;但是,當需要主鍵key 和取值value 時,迭代entrySet() 才是更高效的做法,其比先迭代keySet() 后再去通過get 取值性能更佳。

反例:

//Map 獲取value 反例:HashMap《String, String》 map = new HashMap《》();for (String key : map.keySet()){String value = map.get(key);}

正例:

//Map 獲取key & value 正例:HashMap《String, String》 map = new HashMap《》(); for (Map.Entry《String,String》 entry : map.entrySet()){ String key = entry.getKey(); String value = entry.getValue();}

三、使用Collection.isEmpty()檢測空

使用Collection.size() 來檢測是否為空在邏輯上沒有問題,但是使用Collection.isEmpty() 使得代碼更易讀,并且可以獲得更好的性能;除此之外,任何Collection.isEmpty() 實現的時間復雜度都是O(1) ,不需要多次循環遍歷,但是某些通過Collection.size() 方法實現的時間復雜度可能是O(n)。O(1)緯度減少循環次數例子。

反例:

LinkedList《Object》 collection = new LinkedList《》();if (collection.size() == 0){ System.out.println(“collection is empty.”); }

正例:

LinkedList《Object》 collection = new LinkedList《》(); if (collection.isEmpty()){ System.out.println(“collection is empty.”); }

//檢測是否為null 可以使用CollectionUtils.isEmpty() if (CollectionUtils.isEmpty(collection)){ System.out.println(“collection is null.”);

}

四、初始化集合時盡量指定其大小

盡量在初始化時指定集合的大小,能有效減少集合的擴容次數,因為集合每次擴容的時間復雜度很可能時O(n),耗費時間和性能。

反例:

//初始化list,往list 中添加元素反例:int[] arr = new int[]{1,2,3,4};List《Integer》 list = new ArrayList《》();for (int i : arr){ list.add(i);}

正例:

//初始化list,往list 中添加元素正例: int[] arr = new int[]{1,2,3,4}; //指定集合list 的容量大小 List《Integer》 list = new ArrayList《》(arr.length); for (int i : arr){ list.add(i); }

五、使用StringBuilder拼接字符串

一般的字符串拼接在編譯期Java 會對其進行優化,但是在循環中字符串的拼接Java 編譯期無法執行優化,所以需要使用StringBuilder 進行替換。

反例:

//在循環中拼接字符串反例String str = “”;for (int i = 0; i 《 10; i++){ //在循環中字符串拼接Java 不會對其進行優化 str += i;}

正例:

//在循環中拼接字符串正例 String str1 = “Love”; String str2 = “Courage”; String strConcat = str1 + str2; //Java 編譯器會對該普通模式的字符串拼接進行優化 StringBuilder sb = new StringBuilder(); for (int i = 0; i 《 10; i++){ //在循環中,Java 編譯器無法進行優化,所以要手動使用StringBuilder sb.append(i); }

六、若需頻繁調用Collection.contains方法則使用Set

在Java 集合類庫中,List的contains 方法普遍時間復雜度為O(n),若代碼中需要頻繁調用contains 方法查找數據則先將集合list 轉換成HashSet 實現,將O(n) 的時間復雜度將為O(1)。

反例:

//頻繁調用Collection.contains() 反例List《Object》 list = new ArrayList《》();for (int i = 0; i 《= Integer.MAX_VALUE; i++){ //時間復雜度為O(n) if (list.contains(i)) System.out.println(“list contains ”+ i); }

正例:

//頻繁調用Collection.contains() 正例 List《Object》 list = new ArrayList《》(); Set《Object》 set = new HashSet《》(); for (int i = 0; i 《= Integer.MAX_VALUE; i++){ //時間復雜度為O(1) if (set.contains(i)){ System.out.println(“list contains ”+ i); } }

七、使用靜態代碼塊實現賦值靜態成員變量

對于集合類型的靜態成員變量,應該使用靜態代碼塊賦值,而不是使用集合實現來賦值。

反例:

//賦值靜態成員變量反例 private static Map《String, Integer》 map = new HashMap《String, Integer》(){ { map.put(“Leo”,1); map.put(“Family-loving”,2); map.put(“Cold on the out side passionate on the inside”,3); } }; private static List《String》 list = new ArrayList《》(){ { list.add(“Sagittarius”); list.add(“Charming”); list.add(“Perfectionist”); } };

正例:

//賦值靜態成員變量正例private static Map《String, Integer》 map = new HashMap《String, Integer》(); static { map.put(“Leo”,1); map.put(“Family-loving”,2); map.put(“Cold on the out side passionate on the inside”,3); }

private static List《String》 list = new ArrayList《》(); static { list.add(“Sagittarius”); list.add(“Charming”); list.add(“Perfectionist”); }

八、刪除未使用的局部變量、方法參數、私有方法、字段和多余的括號。

九、工具類中屏蔽構造函數

工具類是一堆靜態字段和函數的集合,其不應該被實例化;但是,Java 為每個沒有明確定義構造函數的類添加了一個隱式公有構造函數,為了避免不必要的實例化,應該顯式定義私有構造函數來屏蔽這個隱式公有構造函數。

反例:

public class PasswordUtils { //工具類構造函數反例 private static final Logger LOG = LoggerFactory.getLogger(PasswordUtils.class);

public static final String DEFAULT_CRYPT_ALGO = “PBEWithMD5AndDES”;

public static String encryptPassword(String aPassword) throws IOException { return new PasswordUtils(aPassword).encrypt(); }

正例:

public class PasswordUtils { //工具類構造函數正例 private static final Logger LOG = LoggerFactory.getLogger(PasswordUtils.class);

//定義私有構造函數來屏蔽這個隱式公有構造函數 private PasswordUtils(){}

public static final String DEFAULT_CRYPT_ALGO = “PBEWithMD5AndDES”;

public static String encryptPassword(String aPassword) throws IOException { return new PasswordUtils(aPassword).encrypt(); }

十、刪除多余的異常捕獲并拋出

用catch 語句捕獲異常后,若什么也不進行處理,就只是讓異常重新拋出,這跟不捕獲異常的效果一樣,可以刪除這塊代碼或添加別的處理。

反例:

//多余異常反例private static String fileReader(String fileName)throws IOException{

try (BufferedReader reader = new BufferedReader(new FileReader(fileName))) { String line; StringBuilder builder = new StringBuilder(); while ((line = reader.readLine()) != null) { builder.append(line); } return builder.toString(); } catch (Exception e) { //僅僅是重復拋異常 未作任何處理 throw e; }}

正例:

//多余異常正例private static String fileReader(String fileName)throws IOException{

try (BufferedReader reader = new BufferedReader(new FileReader(fileName))) { String line; StringBuilder builder = new StringBuilder(); while ((line = reader.readLine()) != null) { builder.append(line); } return builder.toString(); //刪除多余的拋異常,或增加其他處理: /*catch (Exception e) { return “fileReader exception”; }*/ }}

十一、字符串轉化使用String.valueOf(value)代替“”+value

把其它對象或類型轉化為字符串時,使用String.valueOf(value) 比 “”+value 的效率更高。

反例:

//把其它對象或類型轉化為字符串反例:int num = 520;// “” + valueString strLove = “” + num;

正例:

//把其它對象或類型轉化為字符串正例:int num = 520;// String.valueOf() 效率更高String strLove = String.valueOf(num);

十二、避免使用BigDecimal(double)

BigDecimal(double) 存在精度損失風險,在精確計算或值比較的場景中可能會導致業務邏輯異常。

反例:

// BigDecimal 反例BigDecimal bigDecimal = new BigDecimal(0.11D);

正例:

// BigDecimal 正例BigDecimal bigDecimal1 = bigDecimal.valueOf(0.11D);

十三、返回空數組和集合而非null

若程序運行返回null,需要調用方強制檢測null,否則就會拋出空指針異常;返回空數組或空集合,有效地避免了調用方因為未檢測null 而拋出空指針異常的情況,還可以刪除調用方檢測null 的語句使代碼更簡潔。

反例:

//返回null 反例public static Result[] getResults() { return null;}

public static List《Result》 getResultList() { return null;}

public static Map《String, Result》 getResultMap() { return null;}

正例:

//返回空數組和空集正例public static Result[] getResults() { return new Result[0];}

public static List《Result》 getResultList() { return Collections.emptyList();}

public static Map《String, Result》 getResultMap() { return Collections.emptyMap();}

十四、優先使用常量或確定值調用equals方法

對象的equals 方法容易拋空指針異常,應使用常量或確定有值的對象來調用equals 方法。

反例:

//調用 equals 方法反例private static boolean fileReader(String fileName)throws IOException{ // 可能拋空指針異常 return fileName.equals(“Charming”); }

正例:

//調用 equals 方法正例private static boolean fileReader(String fileName)throws IOException{

// 使用常量或確定有值的對象來調用 equals 方法 return “Charming”.equals(fileName);

//或使用:java.util.Objects.equals() 方法 return Objects.equals(“Charming”,fileName); }

十五、枚舉的屬性字段必須是私有且不可變

枚舉通常被當做常量使用,如果枚舉中存在公共屬性字段或設置字段方法,那么這些枚舉常量的屬性很容易被修改;理想情況下,枚舉中的屬性字段是私有的,并在私有構造函數中賦值,沒有對應的Setter 方法,最好加上final 修飾符。

反例:

public enum SwitchStatus { // 枚舉的屬性字段反例 DISABLED(0, “禁用”), ENABLED(1, “啟用”);

public int value; private String description;

private SwitchStatus(int value, String description) { this.value = value; this.description = description; }

public String getDescription() { return description; }

public void setDescription(String description) { this.description = description; }}

正例:

public enum SwitchStatus { // 枚舉的屬性字段正例 DISABLED(0, “禁用”), ENABLED(1, “啟用”);

// final 修飾 private final int value; private final String description;

private SwitchStatus(int value, String description) { this.value = value; this.description = description; }

// 沒有Setter 方法 public int getValue() { return value; }

public String getDescription() { return description; }}

十六、tring.split(String regex)部分關鍵字需要轉譯

使用字符串String 的plit 方法時,傳入的分隔字符串是正則表達式,則部分關鍵字(比如 。[]()| 等)需要轉義。

反例:

// String.split(String regex) 反例String[] split = “a.ab.abc”.split(“。”);System.out.println(Arrays.toString(split)); // 結果為[]String[] split1 = “a|ab|abc”.split(“|”);System.out.println(Arrays.toString(split1)); // 結果為[“a”, “|”, “a”, “b”, “|”, “a”, “b”, “c”]

正例:

// String.split(String regex) 正例// 。 需要轉譯String[] split2 = “a.ab.abc”.split(“\。”);System.out.println(Arrays.toString(split2)); // 結果為[“a”, “ab”, “abc”]

// | 需要轉譯String[] split3 = “a|ab|abc”.split(“\|”);System.out.println(Arrays.toString(split3)); // 結果為[“a”, “ab”, “abc”]

END

作者:濤姐濤哥來源:cnblogs.com/taojietaoge/p/11575376.html

版權歸原作者所有,如有侵權,請聯系刪除。

編輯:jq

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • JAVA
    +關注

    關注

    20

    文章

    3001

    瀏覽量

    116419
  • 代碼
    +關注

    關注

    30

    文章

    4967

    瀏覽量

    73954
  • Value
    +關注

    關注

    0

    文章

    11

    瀏覽量

    9008
  • mybatis
    +關注

    關注

    0

    文章

    64

    瀏覽量

    7139

原文標題:16條yyds的代碼規范

文章出處:【微信號:pcbgood,微信公眾號:奈因PCB電路板設計】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    AI代碼之爭忽略了什么

    人工智能的興起讓 COBOL 重新成為話題焦點,市場上也涌現出不少號稱能轉換遺留代碼、破解現代化難題的工具。但關鍵在于厘清這究竟意味著什么,以及它不包含什么。代碼轉換是一回事,平臺現代化則完全是另一碼事。這兩者并非同一概念,而橫亙其間的鴻溝,恰恰是大多數企業遇到麻煩的地方
    的頭像 發表于 03-02 15:20 ?279次閱讀

    基于知識工程JoyAgent雙RAG的智能代碼評審系統的探索與實踐

    的前置與集中,使得封板前的代碼評審任務量顯著增加。我們面臨著一個嚴峻的“量與質”的挑戰: 如何在時間緊、任務重的雙重壓力下,確保代碼評審的效率與質量,從而前置發現潛在風險,有效攔截線上BUG? 傳統的
    的頭像 發表于 01-21 18:26 ?2019次閱讀
    基于知識工程JoyAgent雙RAG的智能<b class='flag-5'>代碼</b>評審系統的探索與實踐

    基于知識工程&amp;JoyAgent雙RAG的智能代碼評審系統的探索與實踐

    的前置與集中,使得封板前的代碼評審任務量顯著增加。我們面臨著一個嚴峻的“量與質”的挑戰: 如何在時間緊、任務重的雙重壓力下,確保代碼評審的效率與質量,從而前置發現潛在風險,有效攔截線上BUG? 傳統的
    的頭像 發表于 01-15 15:12 ?179次閱讀
    基于知識工程&amp;JoyAgent雙RAG的智能<b class='flag-5'>代碼</b>評審系統的探索與實踐

    HarmonyOS應用代碼混淆技術方案

    代碼混淆技術可以增加代碼的復雜性和模糊性,從而提高攻擊者分析代碼的難度。
    的頭像 發表于 11-21 16:17 ?5603次閱讀
    HarmonyOS應用<b class='flag-5'>代碼</b>混淆技術方案

    代碼開發平臺推薦:2025國內低代碼開發平臺排名TOP10

    代碼開發平臺排行榜 在企業數字化轉型的浪潮中,低代碼開發平臺正逐漸成為企業實現高效開發和快速迭代的重要工具。隨著技術的不斷進步和市場需求的持續增長,低代碼開發平臺的市場競爭也日益激烈。以下
    的頭像 發表于 10-28 10:22 ?731次閱讀

    2025主流低代碼平臺有哪些:低代碼開發平臺選型指南指南

    在企業數字化轉型進入深水區的當下,低代碼開發平臺已從早期的“效率工具”升級為“核心基建”。其工程化能力、流程適配深度、技術延展性與行業積淀,直接決定了企業轉型的成效。據Gartner預測,到2026
    的頭像 發表于 10-22 11:49 ?395次閱讀

    外殼防護等級(IP代碼)全解讀

    什么是外殼防護等級(IP代碼)IP代碼,全稱為“國際防護等級”,是由國際電工委員會制定的全球通用標準。這一標準旨在為電子設備外殼的防護能力提供一個清晰、統一的評判體系。簡單來說,IP代碼就是電子設備
    的頭像 發表于 10-14 12:13 ?1193次閱讀
    外殼防護等級(IP<b class='flag-5'>代碼</b>)全解讀

    代碼開發云平臺是什么?零編程零成本搭建

    代碼物聯網云平臺是種融合了低代碼開發能力與物聯網(IoT)技術的云端服務平臺,其核心目標是大幅降低物聯網應用的開發門檻和成本,讓用戶無需專業編程經驗,也能快速構建、部署和管理物聯網系統。 低代碼
    的頭像 發表于 07-31 15:25 ?757次閱讀

    Ansible代碼上線項目實戰案例

    在DevOps浪潮中,自動化部署已經成為每個運維工程師的必備技能。今天我將分享一個完整的Ansible代碼上線項目實戰案例,讓你的部署效率提升10倍!
    的頭像 發表于 07-24 14:03 ?580次閱讀

    單模光纜型號字母代碼及其含義

    單模光纜的型號字母代碼主要用于標識光纜的分類、結構、護層及光纖類型等關鍵信息,以下是一些常見的單模光纜型號字母代碼及其含義: 一、光纜分類代碼 GY:通信用室外光纜,這是最常見的室外光纜分類
    的頭像 發表于 07-17 10:27 ?3096次閱讀

    代碼革命的先鋒:aiXcoder-7B模型介紹

    HuggingFace趨勢榜單TOP30,全球開發者矚目。 ? ? ? ? 背后團隊 aiXcoder 團隊來自北京大學軟件工程研究所,2013就開始搞代碼生成,他們不但是國際上最早將深度學習技術用于
    的頭像 發表于 05-20 14:41 ?802次閱讀
    <b class='flag-5'>代碼</b>革命的先鋒:aiXcoder-7B模型介紹

    OLED代碼分享

    OLED代碼
    發表于 04-29 17:04 ?1次下載

    變頻器相同的故障原因不同的故障代碼分類

    變頻器相同的故障原因可能對應不同的故障代碼,這主要取決于變頻器的型號、制造商以及具體的故障檢測機制。以下是一些常見的故障原因及其可能對應的不同故障代碼分類: 一、過電流故障 ● 故障原因:電動機銘牌
    的頭像 發表于 04-25 14:31 ?2536次閱讀
    變頻器相同的故障原因不同的故障<b class='flag-5'>代碼</b>分類

    【JVM開發者必看】IntelliJ IDEA代碼分析實踐指南:實時糾錯、冗余檢測、自動修復等

    【IntelliJ IDEA中的代碼分析技巧】靜態代碼分析是指在不實際運行代碼的情況下掃描代碼以發現潛在問題。IntelliJ IDEA中的檢查可以在您編譯項目之前檢測到其中的潛在問題
    的頭像 發表于 03-13 10:34 ?1059次閱讀
    【JVM開發者必看】IntelliJ IDEA<b class='flag-5'>代碼</b>分析實踐指南:實時糾錯、冗余檢測、自動修復等

    貼片電感的感值代碼與讀取方法

    貼片電感作為電子電路中的重要元件,其感值的準確性和讀取方法的便捷性對于電路的性能至關重要。本文將詳細介紹貼片電感的感值代碼及其讀取方法。 貼片電感的感值代碼通常采用數碼表示法,這種方法通過特定的數字
    的頭像 發表于 03-06 14:15 ?1834次閱讀
    貼片電感的感值<b class='flag-5'>代碼</b>與讀取方法