0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
电子发烧友
开通电子发烧友VIP会员 尊享10大特权
海量资料免费下载
精品直播免费看
优质内容免费畅学
课程9折专享价
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

新版本 IDE 的啟動速度變快了?原來是在背后做了這些!

龍智 ? 來源:jf_15970448 ? 作者:jf_15970448 ? 2025-01-24 13:49 ? 次閱讀

IntelliJ IDEA 功能強(qiáng)、范圍廣,因此對資源有一定需求。根據(jù)您正在處理的項(xiàng)目,IDE 可能會出現(xiàn)滯后,這自然會令人沮喪。

打開項(xiàng)目時也許是開發(fā)者需要等待的最常見場景。IntelliJ IDEA 需要加載和同步項(xiàng)目、執(zhí)行索引編制以及完成許多其他小任務(wù)才能啟用所有實(shí)用功能。

在這篇博文中,我們將介紹在新版本 IntelliJ IDEA 中為提高性能而采取的措施,這些措施縮短了代碼可交互時間并使 IDE 從啟動開始就具有更高的響應(yīng)速度。

我們的使命:改進(jìn)代碼可交互時間

對于 2023.2 之前的 IntelliJ IDEA 版本,IDE 必須等待項(xiàng)目的 Maven 或 Gradle 項(xiàng)目模型完全同步后才能開始編制索引。然后,在等待索引編制完成時,IDE 的所有智能功能都被禁用,包括代碼高亮顯示和導(dǎo)航。只有在索引編制完成后才能使用它們。

下面是相關(guān)組件的示意圖:

wKgZPGeTKO2AOO6ZAADB5TQdSwU816.png

項(xiàng)目越大,同步項(xiàng)目和編制項(xiàng)目索引所需的時間越長。雖然這在意料之中,因?yàn)榇笮晚?xiàng)目對于 IDE 來說更加復(fù)雜,但等待幾分鐘才能開始工作仍然有些糟糕。然而,由于加載項(xiàng)目時要執(zhí)行的步驟太多,即使是較小的步驟也會花費(fèi)大量時間,讓人感覺 IntelliJ IDEA 運(yùn)行緩慢。沒人喜歡等待,尤其是您想要投入工作的時候。因此,我們將改善這種狀況作為一項(xiàng)高度優(yōu)先的任務(wù)。為了衡量我們的進(jìn)度,我們決定跟蹤我們所謂的“代碼可交互時間”– 從應(yīng)用程序啟動或項(xiàng)目打開到可以在其中正常處理代碼的時間。我們的目標(biāo)是盡可能縮短代碼可交互時間

改進(jìn)項(xiàng)目打開流和體驗(yàn)

在 IntelliJ IDEA 中改進(jìn)啟動和項(xiàng)目打開的問題實(shí)際上非常復(fù)雜,因?yàn)樗Q于多個組件及其互連。不過,這種復(fù)雜性也有好處,因?yàn)樗梢宰屛覀儚亩鄠€角度解決問題。在等待技術(shù)改進(jìn)方面的長期工作取得成果的同時,我們還調(diào)整了 IntelliJ IDEA 的索引編制方式,用戶已經(jīng)可以體驗(yàn)到在代碼可交互時間方面的顯著改進(jìn)。

技術(shù)改進(jìn) >>

縮短代碼可交互時間的一個明顯方式是執(zhí)行技術(shù)更新以提高 IDE 的性能 – 優(yōu)化代碼和架構(gòu)、使用更好的硬件、并行化等。IntelliJ IDEA 已有 20 多年的歷史,早期的一些架構(gòu)和算法決策仍然存在于產(chǎn)品中。這方面的工作正在開展。我們投入了大量精力來適當(dāng)監(jiān)測、調(diào)查和優(yōu)化性能瓶頸,并且已經(jīng)取得了一些顯著成果。我們將應(yīng)用程序的啟動應(yīng)用程序性能指數(shù) (Apdex) 提升到

頂級類別

,得分為 0.94,將多線程索引編制的速度提高了 25%,并消除了并行索引編制過程中不必要的鎖,減少了其他線程等待此類鎖的時間。但這將是一個漫長的過程,因?yàn)橹貥?gòu)可能會對 IDE 中的其他子系統(tǒng)產(chǎn)生影響,需要經(jīng)過較長時間的仔細(xì)評估。

在技術(shù)層面開展工作的同時,我們還決定另辟蹊徑來解決 IDE 的感知性能問題。

分階段同步索引編制 >>

IDE 不一定需要技術(shù)改進(jìn),用戶就能體驗(yàn)到它的速度提升。

只要能夠更快開始工作,他們就會感受到性能改進(jìn)

。通過研究,我們了解到許多用戶認(rèn)為,當(dāng)他們能夠看到項(xiàng)目結(jié)構(gòu)和正確的代碼高亮顯示時,IDE 就可以開始用于工作了。所以,這就是我們努力的重點(diǎn)。IDE 必須執(zhí)行幾個關(guān)鍵步驟才能使高亮顯示和導(dǎo)航正常運(yùn)作,但我們想知道這些步驟是否真的需要按順序依次執(zhí)行。2023.3 版本中一些很有前景的實(shí)驗(yàn)表明,

將同步和索引編制過程分為幾個階段并以異步方式運(yùn)行,可以讓用戶更快地開始與代碼交互。

因此,作為第一步,我們讓 IntelliJ IDEA 在實(shí)際從 Gradle 或 Maven 等底層構(gòu)建工具獲取項(xiàng)目模型之前開始對項(xiàng)目目錄中的文件編制索引。這樣做的缺點(diǎn)是,不必要的文件也被編入索引,并且與構(gòu)建工具同步后,需要重新編制索引。不過,根據(jù)我們的測試套件,整體代碼可交互時間(包括同步和完整索引編制)顯著縮短,在大型項(xiàng)目中的速度提高了 1.5 倍。但是,如果不加載項(xiàng)目模型,就無法正確建立項(xiàng)目各部分之間的關(guān)系、顯示正確的項(xiàng)目樹、高亮顯示或提供導(dǎo)航。為了解決這個問題,我們實(shí)現(xiàn)了所謂的分階段同步。我們讓 IDE 分階段獲取模型,而不是一次性從構(gòu)建工具請求完整項(xiàng)目模型。目前有兩個階段。

階段 1:跳過依賴項(xiàng)解析

在第一階段,即項(xiàng)目加載過程的早期階段,IntelliJ IDEA 不會解析依賴項(xiàng)或連接到互聯(lián)網(wǎng)。它只是提供一個足夠精確的模型,讓 IDE 能夠顯示項(xiàng)目樹、對項(xiàng)目中最必要的部分編制索引,并提供一些必要的智能功能。顯然,這個階段之后一些依賴項(xiàng)可能仍然缺失,從而導(dǎo)致解析問題,甚至出現(xiàn)代碼即使正確也被標(biāo)記為紅色的情況。IDE 實(shí)際上可以感知這些誤報錯誤,并通過抑制因缺少依賴項(xiàng)而導(dǎo)致的錯誤在個別語言支持級別解決這些問題。它還能正確處理帶有相應(yīng)消息的導(dǎo)航嘗試。自 2024.2 版本起,此錯誤抑制適用于 Java,在 2024.3 版本中,支持已擴(kuò)展到 Kotlin。Maven 中第一階段尤其快速,因?yàn)樗撵o態(tài) pom.xml 配置文件可以由 IDE 解析而無需啟動 Maven,同時還能提供足夠的知識來構(gòu)建非常精確的模型。對于本質(zhì)上動態(tài)且腳本非常靈活的 Gradle,IntelliJ IDEA 目前無法獨(dú)立解析腳本,這意味著它必須運(yùn)行 Gradle 守護(hù)進(jìn)程。通過僅向 Gradle 請求 sourceSets、必需語言級別和其他基本信息,我們加快了這一過程。不過,通過聲明式 Gradle 計(jì)劃,我們將來也許能夠帶來大幅改善。

階段 2:下載并解析依賴項(xiàng)

在第二階段,IntelliJ IDEA 下載所有插件和依賴項(xiàng),正確解析所有配置,并為 IDE 提供完全準(zhǔn)確的模型。然后,索引根據(jù)完整模型更新。通過這種兩階段方式,在依賴項(xiàng)下載和解析的同時,您可以更快獲得幾乎功能齊全的 IntelliJ IDEA 版本。

作為一項(xiàng)額外改進(jìn),我們使許多功能在索引尚未就緒時也能運(yùn)行,進(jìn)一步縮短了代碼可交互時間。最重要的是個別文件中的代碼高亮顯示、部分代碼解析和運(yùn)行配置。當(dāng)然,準(zhǔn)備好底層索引會讓這些操作更快,但即使只有部分索引,它們也能可靠地工作。

結(jié)果

總體來看,整個流程現(xiàn)在是這樣的:

wKgZPGeTKKqAcXGtAACVLetFHRU940.png

我們怎么知道是否值得?

根據(jù)項(xiàng)目,我們測試套件中的代碼可交互時間(或者更準(zhǔn)確地說,以上架構(gòu)中完全高亮顯示之前的時間)在第一次打開項(xiàng)目時速度最多能快上幾倍。

調(diào)查顯示,大約 30% 的用戶認(rèn)為 IntelliJ IDEA 2024.2 讓他們能夠更快開始編碼。

后續(xù)計(jì)劃

雖然并非所有 IntelliJ IDEA 功能都能在編制項(xiàng)目索引時使用,但兩階段同步方式無疑加快了整體啟動性能,讓您更快地開始與代碼交互。此外,我們還使許多操作與沒有索引或只有部分索引的情況兼容。在 2024.2 版本中,大約 10% 的用戶確實(shí)在整個同步和索引編制過程完成之前編寫代碼。但我們的工作還沒有結(jié)束。

我們現(xiàn)在的目標(biāo)是改進(jìn)分階段同步,尤其是與 Gradle 的同步,進(jìn)一步縮短代碼可交互時間。我們還在更新依賴項(xiàng)尚未解析時處理項(xiàng)目的用戶體驗(yàn)。

同時,我們希望您能享受我們在縮短代碼可交互時間方面取得的成果。

本博文英文原作者:Kerry Beetge

關(guān)于 IntelliJ IDEA

JetBrains 的旗艦 IDE IntelliJ IDEA 專為高效的 JVM 開發(fā)而設(shè)計(jì)。憑借對語言和技術(shù)的深入了解以及符合人體工程學(xué)的用戶界面,IntelliJ IDEA 使開發(fā)成為愉悅的體驗(yàn)!

免費(fèi)的開源 IntelliJ IDEA 社區(qū)版和 IntelliJIDEA Edu 也可以用于學(xué)習(xí)和教學(xué)編程。

咨詢JetBrains授權(quán)合作伙伴-龍智,進(jìn)一步了解 IntelliJ IDEA:

審核編輯 黃宇

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • IDE
    IDE
    +關(guān)注

    關(guān)注

    0

    文章

    348

    瀏覽量

    47537
收藏 0人收藏

    評論

    相關(guān)推薦
    熱點(diǎn)推薦

    普華基礎(chǔ)軟件開源汽車操作系統(tǒng)新版本代碼上線

    近日,第二十一屆上海國際汽車工業(yè)展覽會現(xiàn)場,開源車用操作系統(tǒng)新版本代碼上線儀式中國電科展臺成功召開。全球首個開源智能駕駛操作系統(tǒng)微內(nèi)核龘EasyAda V2.1和首個規(guī)?;?、量產(chǎn)級安全車控操作系統(tǒng)
    的頭像 發(fā)表于 04-30 09:17 ?322次閱讀

    普華基礎(chǔ)軟件開源車用操作系統(tǒng)迎來全新版本

    近日,普華基礎(chǔ)軟件開源車用操作系統(tǒng)媒體發(fā)布會在上海中國汽車會客廳召開——全球首個開源智能駕駛操作系統(tǒng)微內(nèi)核龘EasyAda、開源安全車控操作系統(tǒng)小滿EasyXMen全新版本正式發(fā)布。現(xiàn)場,普華基礎(chǔ)軟件開源項(xiàng)目技術(shù)團(tuán)隊(duì)專家就開源項(xiàng)目新版本技術(shù)亮點(diǎn)、新增功能及社區(qū)治理與運(yùn)營等
    的頭像 發(fā)表于 04-25 16:18 ?284次閱讀

    網(wǎng)絡(luò)傳輸利器索尼NXL-ME80 V1.2新版本發(fā)布

    網(wǎng)絡(luò)傳輸利器NXL-ME80,憑借著高畫質(zhì)、高壓縮比、低延時、高密度輕巧機(jī)箱,高冗余能力,一經(jīng)上市就收到全球客戶的大量好評?;谟脩舴答伜褪袌鲂枨螅琋XL-ME80新版本V1.2強(qiáng)勢來襲,必將為使用者帶來更好的體驗(yàn)。
    的頭像 發(fā)表于 04-23 14:37 ?374次閱讀
    網(wǎng)絡(luò)傳輸利器索尼NXL-ME80 V1.2<b class='flag-5'>新版本</b>發(fā)布

    SOA架構(gòu)開發(fā)小助手PAVELINK.SOA-Converter 2.1.2新版本發(fā)布

    為提升汽車SOA架構(gòu)設(shè)計(jì)開發(fā)效率,優(yōu)化用戶體驗(yàn),我們對PAVELINK.SOA-Converter進(jìn)行了全新升級。本次2.1.2新版本升級,聚焦于提升軟件性能、擴(kuò)展功能特性及增強(qiáng)用戶交互體驗(yàn)。
    的頭像 發(fā)表于 04-09 10:37 ?869次閱讀
    SOA架構(gòu)開發(fā)小助手PAVELINK.SOA-Converter 2.1.2<b class='flag-5'>新版本</b>發(fā)布

    keil不同版本,有的文件新版本上報錯怎么辦?要裝兩個版本一起用?

    有的文件新版本上報錯怎么辦?要裝兩個版本一起用?
    發(fā)表于 03-10 07:05

    新版本 IDE啟動速度變快了?原來是背后做了這些!

    IDEA 需要加載和同步項(xiàng)目、執(zhí)行索引編制以及完成許多其他小任務(wù)才能啟用所有實(shí)用功能。在這篇博文中,我們將介紹新版本 IntelliJ IDEA 中為提高性能而采取的
    的頭像 發(fā)表于 02-12 15:58 ?370次閱讀
    <b class='flag-5'>新版本</b> <b class='flag-5'>IDE</b> 的<b class='flag-5'>啟動</b><b class='flag-5'>速度</b><b class='flag-5'>變快了</b>?<b class='flag-5'>原來是</b><b class='flag-5'>在</b><b class='flag-5'>背后</b><b class='flag-5'>做了</b><b class='flag-5'>這些</b>!

    GUI Guider v1.9.0全新版本上線

    新年伊始,GUI Guider也迎來了全新版本!這一次,我們帶來了多項(xiàng)重磅更新,旨在為你提供更強(qiáng)大、更便捷的開發(fā)體驗(yàn)。無論你是工業(yè)控制、智能家居,還是消費(fèi)電子領(lǐng)域的開發(fā)者,這些更新都將為你的項(xiàng)目注入新的活力!
    的頭像 發(fā)表于 02-07 10:43 ?2623次閱讀

    高通推出Qualcomm Aware平臺最新版本

    CES 2025上,高通技術(shù)公司宣布推出Qualcomm Aware平臺的最新版本,這一基于云的服務(wù)平臺支持企業(yè)為物流、零售、能源、智能家居和機(jī)器人等行業(yè)的智能網(wǎng)聯(lián)終端增加可觀測性、監(jiān)測和定位功能
    的頭像 發(fā)表于 01-07 10:36 ?706次閱讀

    索尼發(fā)布空間現(xiàn)實(shí)顯示播放器新版本

    索尼于2024年12月發(fā)布適用于空間現(xiàn)實(shí)顯示屏ELF-SR1和ELF-SR2的空間現(xiàn)實(shí)顯示播放器新版本。
    的頭像 發(fā)表于 12-24 15:19 ?566次閱讀

    特斯拉發(fā)布“完全自動駕駛”軟件最新版本FSDV13.2

    近日,特斯拉終于推出了備受期待的“完全自動駕駛”軟件最新版本——FSD V13.2。盡管此前曾承諾感恩節(jié)之前發(fā)布,但特斯拉還是11月份的最后時刻兌現(xiàn)了承諾,展現(xiàn)了其人工智能團(tuán)隊(duì)的不懈努力和重要進(jìn)展。
    的頭像 發(fā)表于 12-03 10:59 ?1064次閱讀

    經(jīng)緯恒潤INTEWORK-VBA新版本正式發(fā)布

    和前后端信息傳遞的壓力。面對這一問題,經(jīng)緯恒潤積極響應(yīng)市場需求,正式推出INTEWORK-VBAV3系列新版本,整合仿真、診斷、標(biāo)定和測試等多個應(yīng)用場景,一站式解
    的頭像 發(fā)表于 11-01 08:00 ?621次閱讀
    經(jīng)緯恒潤INTEWORK-VBA<b class='flag-5'>新版本</b>正式發(fā)布

    達(dá)索系統(tǒng)SOLIDWORKS2025新版本即將來襲

    里程碑式的新版本——SOLIDWORKS?2025。這一新版本不僅集成了眾多用戶驅(qū)動的增強(qiáng)功能,還在協(xié)作、設(shè)計(jì)和性能上實(shí)現(xiàn)了重大突破,預(yù)示著CAD設(shè)計(jì)領(lǐng)域的新一輪創(chuàng)新與升級。
    的頭像 發(fā)表于 10-12 14:18 ?1368次閱讀

    品英Pickering最新版本的微波開關(guān)設(shè)計(jì)工具, 增強(qiáng)了仿真能力和原理圖設(shè)計(jì)功能

    這 款免 費(fèi) 線 工具的最新版本將在 EuMW 2024(9 月 24 日至 26 日,法國巴黎)上首次亮相,該版本的開關(guān)配置功能尤為突出。 ? 2024年9月25日,英國
    發(fā)表于 09-25 09:05 ?292次閱讀
    品英Pickering最<b class='flag-5'>新版本</b>的微波開關(guān)設(shè)計(jì)工具,  增強(qiáng)了仿真能力和原理圖設(shè)計(jì)功能

    經(jīng)緯恒潤INTEWORK-TPA 新版本正式發(fā)布

    正式推出INTEWORK-TPA5.2.0新版本,以科技的力量,為用戶帶來更智能的體驗(yàn)升級!▎AI助力,高效測試新版本的AI小助理上線了!借助她的AI大模型能力,測試
    的頭像 發(fā)表于 08-30 11:46 ?735次閱讀
    經(jīng)緯恒潤INTEWORK-TPA <b class='flag-5'>新版本</b>正式發(fā)布

    GUI Guider V1.8.0全新版本正式上線

    在這個充滿創(chuàng)新與挑戰(zhàn)的時代,我們深知高效、靈活的GUI設(shè)計(jì)工具對人機(jī)交互應(yīng)用的重要性。經(jīng)過幾個月的精心打磨與測試,GUI Guider V1.8.0全新版本正式上線了!本次更新不僅帶來了前所未有的設(shè)計(jì)自由度,更在功能優(yōu)化與用戶體驗(yàn)上實(shí)現(xiàn)了質(zhì)的飛躍。
    的頭像 發(fā)表于 08-02 09:26 ?1381次閱讀

    電子發(fā)燒友

    中國電子工程師最喜歡的網(wǎng)站

    • 2931785位工程師會員交流學(xué)習(xí)
    • 獲取您個性化的科技前沿技術(shù)信息
    • 參加活動獲取豐厚的禮品