<tt id="mmm0m"></tt>
  • <tt id="mmm0m"><table id="mmm0m"></table></tt>
  • <tt id="mmm0m"><table id="mmm0m"></table></tt>
  • <tt id="mmm0m"><table id="mmm0m"></table></tt>
  • <li id="mmm0m"><table id="mmm0m"></table></li>
  • <tt id="mmm0m"><table id="mmm0m"></table></tt>
  • <li id="mmm0m"><tt id="mmm0m"></tt></li>
    <li id="mmm0m"><tt id="mmm0m"></tt></li>
  • 悅刻電子煙貨源網,悅刻一手貨源批發網站,提供微商正品relx貨源

    版本管理和分支策略:IntelliJIDEA最佳實踐(版本管理方法)

    小編

    IntelliJ IDEA是一個功能強大的集成開發環境,提供了豐富的版本管理工具和功能,可以幫助你更好地管理代碼庫和版本控制。下面是一些在使用IntelliJ IDEA進行版本管理時的最佳實踐和版本控制方法:

    1. 版本控制工具的集成: IntelliJ IDEA支持多種版本控制工具,包括Git、SVN、Mercurial等。確保你的項目已經與所選的版本控制工具集成,并在項目設置中正確配置了版本控制。

    2. 使用Git作為首選版本控制工具: Git是最常用的版本控制工具之一,也是IntelliJ IDEA的默認選擇。如果你的項目還沒有使用Git,強烈建議遷移到Git,并在IntelliJ IDEA中進行配置。

    3. 創建代碼倉庫: 使用版本控制工具創建一個代碼倉庫,并將你的項目添加到倉庫中。確保忽略不必要的文件和目錄,以保持代碼倉庫的干凈和高效。

    4. 分支策略: 使用合適的分支策略來組織你的開發工作。通常,可以采用以下分支策略:

    • 主分支(main或master):用于穩定的生產版本。
    • 開發分支(develop):用于集成所有開發工作,并進行測試。
    • 特性分支(feature branches):每個新功能或任務都應該在自己的特性分支上進行開發。完成后,將其合并到開發分支中。
    • 修復分支(bug fix branches):用于修復生產環境中的問題。修復后,將其合并到主分支和開發分支中。

    5. 使用IntelliJ IDEA的版本控制工具窗口: IntelliJ IDEA提供了一個版本控制工具窗口,可以方便地查看和管理提交、分支、合并等操作。確保你熟悉這個工具窗口的使用。

    6. 提交和推送: 頻繁地提交你的更改,并將它們推送到版本控制服務器。這有助于保持代碼庫的同步,并使合作更加順暢。

    7. 沖突解決: 當多個開發者同時修改同一部分代碼時,可能會發生沖突。IntelliJ IDEA提供了工具來幫助你解決這些沖突,確保代碼的一致性。

    8. 使用版本控制的歷史記錄: 使用版本控制工具來查看和比較歷史記錄,以了解代碼的演變和更改歷史。

    9. 使用代碼審查工具: IntelliJ IDEA集成了代碼審查工具,可以幫助你進行代碼審查和合并請求。這有助于確保代碼質量和一致性。

    10. 定期備份和維護: 定期備份你的代碼庫,并確保版本控制工具和插件保持最新。這有助于避免數據丟失和確保工具的穩定性。

     

    2.語法基礎

      2.1 Java類初始化順序

      這是所有情況的類初始化順序,如果實際類中沒有定義則跳過:父類靜態變量——父類靜態代碼塊——子類靜態代碼塊——父類非靜態變量——父類非靜態代碼塊——父類構造函數——子類非靜態變量——子類非靜態代碼塊——子類構造函數

      2.2 值傳遞和引用傳遞

      可能很多人對此不屑一顧,心想老子都工作一年了,對這些還不熟悉嗎?但實際情況并非這樣,JDK中東西全部熟悉了嗎?以一個最簡單的例子開始,你覺得下圖中代碼執行完之后fatherList中的元素是什么?

      

      這是一個最基礎的值傳遞和引用傳遞的例子,你覺得好簡單,已經想躍躍欲試的挑戰了,那么請看下面的,StringBuffer很好理解,但是當你執行一遍之后發現是不是和預想中的輸出不一樣呢?String不是引用類型嗎,怎么會這樣呢?如果你無法理解,那么請看下String的實現源碼,了解下其在內存中分配的實現原理。

      

      2.3 集合的使用

      這部分幾乎每個人都會用到,而且大家還都不陌生。下圖來源于互聯網,供大家復習一下。但是利用集合的特性進行巧妙的組合運用能解決優化很多復雜問題。Set不可重復性,List的順序性,Map的鍵值對,SortSet/SortMap的有序性,我在工作中有很多復雜的業務都巧妙的使用了這些,涉及到公司保密信息,我就不貼出代碼了。工作越久越發現這些和越巧妙。

      

      2.3 異常處理

      1.看著try、catch、finally非常容易,如果和事務傳播結合在一起,就會變得極其復雜。

      2.finally不一定必須執行,return在catch/finally中處理情況(建議親自操刀試一下)。

      3.catch中可以繼續拋自定義異常(并把異常一步步傳遞到控制層,利用切面抓取封裝異常,返回給調用者)。

      4.Java學習交流QQ群:589809992 禁止閑聊,非喜勿進!

      2.4 面向對象思想

      一提起面向對象,大家都知道抽象、封裝、繼承、和多態。但是實際工作經驗中又知道多少呢,對于項目中如何巧用估計更不要提了。

      共性的機會每個都需要用的建立基類,如每個控制層方法可能要通過security獲取一個登錄用戶id,用于根據不同的用戶操作不同的數據,可以抽象出一個應用層基類,實現獲取id的protect方法。同理DAO層可以利用泛型提取出一個包含增刪改查的基類。

      多態的Override:基類的引用變量不僅可以指向基類的實例對象,也可以指向其子類的實例對象,如果指向子類的實例對象,其調用的方法應該是正在運行的那個對象的方法。在策略模式中使用很普遍。

      提到面向對象,就不可避免的要說設計模式,在工作中,一個技術大牛寫的一個類似策略模式(更復雜一點),十分巧妙的解決了各種業務同一個方法,并且實現了訂單、工單、業務的解耦,看得我是非常佩服。我想很多面試中都會問道單例模式吧,還沒有理解的建議去看一看。

      3.多線程

      3.1 線程安全

      這個是老生常談的問題了,但是確實是問題和bug高發區。線程同步問題不需要單獨寫了,想必大家都清楚,不太熟悉的建議百度一下。

      3.1.1 線程安全問題

      1.代碼中如果有同步操作,共享變量要特別注意(這個一般都能意識到)

      2多個操作能修改數據表中同一條數據的。(這個容易被忽略,業務A可能操作表a,業務B也可以操作表a,業務A、B即使在不同的模塊和方法中,也會引起線程安全問題。例如如果一個人訪問業務A接口,另一個人訪問業務B接口,在web中每個業務請求都是會有單獨的一個線程進行處理的,就會出現線程安全問題)。

      3.不安全的類型使用,例如StringBuffer、StringBuild,HashTable、HashMap等。在工作中我就遇到過有人在for循環進行list的remove,雖然編譯器不報錯,程序可以運行,但是結果卻可想而知。

    版本管理和分支策略:IntelliJIDEA最佳實踐(版本管理方法)

      4.Spring的bean默認是單例的,如果有類變量就要特別小心了(一般情況下是沒人在控制層、業務層、DAO層等用類變量的,用的話建議是final類型,例如日志log,gson等)。

      5.多個系統共享數據庫情況,這個其實和分布式系統類似

      用戶重復提交問題(即使代碼中從數據庫讀取是否存在進行限制不能解決問題)

      3.1.2 線程安全解決

      在需要同步的地方采用安全的類型。

      JDK鎖機制,lock、tryLock,synchronized,wait、notify、notifyAll等

      Concurrent并發工具包,在處理一些問題上,誰用誰知道。強烈建議查看源碼!

      數據表加鎖。(除非某個表的訪問頻率極低,否則不建議使用)

      涉及分布式的,采用中間件技術例如zookeeper等解決。

      3.2 異步

      異步使用場景不影響主線程,且響應較慢的業務。例如IO操作,第三方服務(短信驗證碼、app推送、云存儲上傳等)。

      如果異步任務很多,就需要使用任務隊列了,任務隊列可以在代碼級別實現,也可以利用redis(優勢太明顯了)。

      3.3 多線程通信

      這方面文章非常多,這里不在詳述。

      1.共享變量方式(共享文件、全局變量,信號量機制等)

      2.消息隊列方式

      3. 忙等,鎖機制

      3.4多線程實現

      1.集成Thread類,重寫(這里的重寫指的是override)run方法,調用start方法執行。

      2.實現Runable接口,實現run方法,以Runable實例創建thread對象。

      3.實現Callable接口,實現call方法,FutureTask包裝callable接口,FutureTask對象創建thread對象,常用語異步操作,建議使用匿名內部類,方便閱讀和使用。

      額外需要說明的是:

      1.理解thread的join方法;

      2.不要認為volitate是線程安全的(不明白原因的建議去看jvm運行時刻內存分配策略);

      3.sleep時間片結束后并不保證立馬獲取cpu。

      4.ThreadLocal能夠為每一個線程維護變量副本,常用于在多線程中用空間換時間。

      5.Java學習交流QQ群:589809992 禁止閑聊,非喜勿進!

      4. 開源框架

      4.1 Hibernate、Mybatis

      相信每一個java程序員對這些都不陌生,這里不再詳述。

      需要說明的主要以下幾點:

      1.hibernate一級緩存(內置session緩存),二級緩存(可裝配sessionFactory緩存),二級緩存會引起并發問題。

      2.hibernate延遲加載原理理解。

      3.hibernate 的get、load方法,sava、persist、savaOrUpdate方法區別

      4.session重建了關聯關系卻并沒有同數據庫進行同步和更新

      5.hibernate session關聯關系:detached對象、persistent對象

      6.Spring data集成,注解方式配置屬性和實體。

      7.mybatis 插件。

      8.分頁查詢(數據庫)。

      9.連接池技術

      4.2 Spring IOC

      4.1.1 Spring bean

      1.bean注入 注解方式方便易讀,引用第三方(數據庫連接,數據庫連接池,JedisPool等)采用配置文件方式。

      2. bean作用域:Singleton,prototype,request,session,global session

      3.bean生命周期:如下圖所示(圖片來源于互聯網):

      

      4.3 Spring AOP

      基本概念:關注點、切面Aspect、切入點pointcut、連接點joinpoint、通知advice、織入weave、引入introduction。

      Spring AOP支持5中類型通知,分別是MethodBeforeAdvice、AfterReturningAdvice、ThrowsAdvice、MethodInterceptor、IntroductionInterceptor(吐槽一下名字太長)

      實現方式如下:

      1.基于代理的AOP

      2.基于@Aspect注解驅動的切面。(強烈推薦:可讀性好,易維護,易擴展,開發快)

      3.純POJO切面。

      4.注入式Aspect切面。

      4.4 Srping事務

      4.4.1 事務傳播

      概念:某些操作需要保證原子性,如果中間出錯,需要事務回滾。如果某個事務回滾,那么調用該事務的方法中的事務的作出如何的動作,就是事務傳播。

      短時間內寫不清楚,建議訪問 http://www.cnblogs.com/yangy608/archive/2010/12/15/1907065.html 查看。

      事務傳播屬性:

      1. PROPAGATION_REQUIRED–支持當前事務,如果當前沒有事務,就新建一個事務。這是最常見的選擇。

      2. PROPAGATION_SUPPORTS–支持當前事務,如果當前沒有事務,就以非事務方式執行。

      3. PROPAGATION_MANDATORY–支持當前事務,如果當前沒有事務,就拋出異常。

      4. PROPAGATION_REQUIRES_NEW–新建事務,如果當前存在事務,把當前事務掛起。

      5. PROPAGATION_NOT_SUPPORTED–以非事務方式執行操作,如果當前存在事務,就把當前事務掛起。

      6. PROPAGATION_NEVER–以非事務方式執行,如果當前存在事務,則拋出異常。

      事務隔離級別:

      1. ISOLATION_DEFAULT: 這是一個PlatfromTransactionManager默認的隔離級別,使用數據庫默認的事務隔離級別.另外四個與JDBC的隔離級別相對應

      2. ISOLATION_READ_UNCOMMITTED: 這是事務最低的隔離級別,充許令外一個事務可以看到這個事務未提交的數據。這種隔離級別會產生臟讀,不可重復讀和幻像讀。

      3. ISOLATION_READ_COMMITTED: 保證一個事務修改的數據提交后才能被另外一個事務讀取。另外一個事務不能讀取該事務未提交的數據

      4. ISOLATION_REPEATABLE_READ: 這種事務隔離級別可以防止臟讀,不可重復讀。但是可能出現幻像讀。它除了保證一個事務不能讀取另一個事務未提交的數據外,還保證了避免下面的情況產生(不可重復讀)。

      5. ISOLATION_SERIALIZABLE 這是花費最高代價但是最可靠的事務隔離級別。事務被處理為順序執行。除了防止臟讀,不可重復讀外,還避免了幻像讀。

      4.5 其他Spring 技術棧

      spring boot 輕量級啟動框架

      spring security 用戶權限管理,根據角色和用戶,實現UserDetailsService,進行自定義權限管理。

      spring task 代碼級定時任務,注解方式,使用起來非常方便。需要注意的是,如果某次定時任務出了異常而沒有進行處理,會導致接下來定時任務失效。如果各個任務相互獨立,可以簡單用try,catch包圍(之前就吃過這方面的虧)。

      spring data 注解方式定義實體,屬性等

      spring mvc 簡單明了的mvc框架。url傳值、數組傳值、對象傳值、對象數組等傳值類型,上傳/下載文件類型需要注意。

      spring restful 注意命名,對命名要求很嚴格。

      spring shell 命令行方式執行命令,救火、導入導出數據等用起來非常方便、制作報表。

      5. Web基礎

      5.1 web容器啟動

      1.web.xml加載順序: listener -> filter -> servlet

      2.webt容器啟動過程,java新手很怕配置文件,理解完這些有助于熟悉配置文件 http://blog.csdn.net/u014431852/article/details/47042895

      5.2 Servlet、Interceptor、Listener、Filter

      Servlet 接收請求返回響應,最原始的web業務處理類。

      Interceptor 攔截器,可以實現HandlerInterceptor接口自定義攔截器,在日志記錄、權限檢查、性能監控、通用行為等場景使用,本質是AOP。

      Listener 監聽器 常用于統計在線人數等縱向功能。

      Filter 過濾器 在請求接口處理業務之前改變requset,在業務處理之后響應用戶之前改變response。如果某些數據不加密,很容易用抓包工具加filter作弊。

      5.3 web項目結構

      5.3.1 mvn結構

      熟練掌握幾種常見的mvn項目結構,mvn可以自動生成,這里不再詳述。

      5.3.2 mvn包管理

      1.版本號盡量幾種在一個文件中便于管理。

      2.spring milestone包解決spring包沖突問題。

      3.mvn dependency:tree命令分析所有包依賴,對于沖突的在pom文件中 包圍起來

      5.3.3 版本控制

      1.git、svn等

      2.代碼沖突解決方案

      3.分支管理。

      4.Java學習交流QQ群:589809992 禁止閑聊,非喜勿進!

      對于某個穩定版本上線后,如果在此基礎上開發新功能,一定要新建分支,在新分支上提交代碼,最后在新版發布時合并分支。修改運營環境bug切換到主分支進行修改

      5.4 Http請求

      5.4.1 請求方法

      post、get、put、head、delete、copy、move、connect、link、patch,最常用的是前4、5個。

      5.4.2 請求頭,狀態碼

      常用的請求頭有Accept(下載文件會特殊使用)、Accept-Charset(設置utf-8字符集)、Content-Type(json等配置)等

      常用的響應頭有Content-Type、Content-Type、Content-Length等,偏前端,不再詳述。

      6. 系統架構

      接觸的不是特別多,目前用到的只是服務器主從備份。Nginx反向代理進行配置。

      多個項目nginx配置

      Spring Mvc 用json數據進行交互,配置json轉換的servlet。

      封裝返回值

      自定義RunEnvironmentException(狀態碼,原因),覆蓋原有Exception,切面ExceptionHandler抓取Exception并封裝到返回值中(前后端松耦合)

      令人頭疼的用戶重復(連續快速點擊)提交問題,前端限制治標不治本;后端用sessonid在切面上實現,又需要前端存儲,對所有請求數據加sessionId。最后用jedis中存儲,用接口名+用戶名當做key,根據不同的接口對不同的key可以單獨設置時間,不僅保證了重復提交問題,也避免了惡意請求問題,同時還能自定義請求間隔。(期初擔心redis緩存讀寫時間延誤導致限制失效,后來發現多慮了,對一般的小系統來說,經性能測試,發現即使請求頻率再提高100被也不會導致限制失效)

      testNg單元測試、性能測試,覆蓋測試。

      切面管理日期、權限。緩存等。

      7. Nosql

    版本管理和分支策略:IntelliJIDEA最佳實踐(版本管理方法)

      1.Redis的java庫Jedis。

      Jedispool配置。

      項目中用到的有任務隊列、緩存。

      2. neo4j圖數據庫

      處理社交、推薦

      8. 服務端

      linux操作系統熟悉以centos為例:

      常用簡單命令:ssh、vim、scp、ps、gerp、sed、awk、cat、tail,df、top,shell、chmod、sh、tar、find、wc、ln、|

      目錄結構明細:/etc/、~/、/usr/、/dev/、/home/、/etc/init.d/

      服務端:jdk、tomcat、nginx、mysql、jedis、neo4j啟動與配置(特別說明的是該死的防火墻,nginx啟動后一直訪問不了,查找一下午查不到原因,最后發現是防火墻問題)

      監控服務器狀態(cpu,磁盤,內存),定位pid,日志查看

      nginx負載均衡、反向代理、配置

      自動化部署腳本

      簡單shell腳本書寫,避免大量人力勞動。

      監控系統,代碼拋fatal異常自動發郵件,系統指標持續偏高自動發郵件。

      9. 數據庫相關

      10. 第三方接口對接

      10.1 支付接口

      微信支付坑比較多,用將近兩周時間才把微信支付所有完成。需要在微信后臺配置的地方太多。

      而支付寶支付模塊只用了2天時間就搞定了。

      10.2 推送接口

      為用戶定義tag、定義alias,注意當數據更新時需要同步更新tag、更新alias。如果沒采用異步實現(用戶體驗就是好卡?。?/p>

      10.3 云存儲

      大量文件上傳云端(七牛云),注意創建bucket

      10.4 短信驗證

      很簡單的第三方接口,引入依賴,直接調用即可。需要在第三方后臺設置模板等,注意限定用戶訪問次數。

      10.5 郵件

      很簡單小功能,工具類。

      時間有限,目前先寫這么多技術棧。對于代碼書寫和、算法技巧問題,會抽時間寫在(2)中。


    總之,IntelliJ IDEA提供了強大的版本管理工具和功能,但要充分發揮其優勢,需要遵循良好的版本管理實踐和策略。根據項目的需求和團隊的工作流程,可以調整和定制版本管理方法。確保所有團隊成員都了解并遵守相同的版本管理流程,以確保代碼庫的穩定性和可維護性。

    <tt id="mmm0m"></tt>
  • <tt id="mmm0m"><table id="mmm0m"></table></tt>
  • <tt id="mmm0m"><table id="mmm0m"></table></tt>
  • <tt id="mmm0m"><table id="mmm0m"></table></tt>
  • <li id="mmm0m"><table id="mmm0m"></table></li>
  • <tt id="mmm0m"><table id="mmm0m"></table></tt>
  • <li id="mmm0m"><tt id="mmm0m"></tt></li>
    <li id="mmm0m"><tt id="mmm0m"></tt></li>
  • 与亲女乱系列小说h 永福县| 临海市| 兴义市| 紫阳县| 锦州市| 化德县| 蒲城县| 保靖县| 武胜县| 独山县| 渝北区| 锡林浩特市| 泰兴市| 龙门县| 吉水县| 临湘市| 溧水县| 那曲县| 宁乡县| 清涧县| 同心县| 武鸣县| 纳雍县| 米易县| 治县。| 故城县| 延吉市| 临朐县| 永吉县| 晴隆县| 高台县| 武鸣县| 靖远县| 韶山市| 黄大仙区| 荥经县| 内丘县| 济源市| 雅安市| 望城县| 黄石市| http://444 http://444 http://444