方舟編譯器一出是不是Java就可以代替C?
不用方舟,java也能代替c/c++
9102年了,java早就在開發速度和效率上秒殺了一眾c/c++等底層語言,老項目是沒法改了,新項目你看現在有多少c/c++的,TIOBE排行榜上第一位的可是java
4月25日,北京。
“它就是能讓安卓上的應用,跑得跟蘋果iOS上一樣快?!泵鎸ε_下的記者,華為消費者BG軟件部總裁王成錄這么描述方舟編譯器的作用。 此時,距離這個吊起了安卓應用開發者們興趣的編譯器在發布會上被公開,正好過去了兩周。 什么是方舟編譯器? 在4月11日的華為P30中國發布會上,華為消費者業務CEO余承東正式發布了華為方舟編譯器,并表示這個編譯器能改善安卓應用編譯效率,從原先的邊解釋邊執行轉變為全程機器碼高效運行程序。 編譯器,就是將“一種計算機語言(通常為高級語言)”翻譯為“另一種計算機語言(通常為低級語言)”的程序。高級計算機語言便于開發者們編寫、閱讀交流以及維護,如Pascal、C、C++、Java等,而低級機器語言是計算機能直接解讀、運行的機器代碼(Machine code)。 華為的方舟編譯器,就是將安卓應用開發者們所使用的JAVA、C/C++們轉換成機器代碼。據王成錄透露,華為從2009年就開始考慮做編譯器,“因為咱們海思做了芯片以后,需要有自己的編譯器才能真正發揮芯片的能力,從2013年開始,有華為自己的自研編譯器了,叫HCC。” 根據時間表顯示,在2012年,華為成立了編譯器與編程語言實驗室,在2014年,技術大牛Fred Chow加入華為負責編譯器的主架構,經過十年的摸索,華為終于推出了方舟編譯器。 根據華為官方公布的數據顯示,與此前的安卓應用開發相比,方舟編譯器能夠提升24%的系統操作流暢度,提升44%的系統響應能力,還能提升60%的第三方應用(微博極速版)操作流暢度。 它是怎么做到的? 一、 消除了跨語言調用開銷 王成錄向記者們詳細闡述了方舟編譯器能提升流暢度、響應能力的工作原理。 首先,方舟編譯器是多語言聯合優化編譯器,“消除了跨語言調用開銷,這是影響Android性能開銷比較大的核心原因之一。” 據王成錄介紹,目前Android應用市場里95%的APP都是多種開發語言:“邏輯部分,都是Java代碼,但是為了增強它的能力,可能所有的APP的開發者,都會用C寫個庫供Java來調用?!? Java是一門面向對象編程語言,具有簡單性、面向對象、分布式等特點,雖然運行效率不及C++,但開發效率高、跨平臺性更強的優勢,讓JAVA成為了安卓開發的首選,而通過JNI調用本地C/C++庫也是目前開發者們都在做的。 但,Java和C語言之間使用接口調用,必然會形成額外的性能開銷;王成錄表示,華為方舟編譯器將不同語言代碼在開發環境中編譯成一套可執行文件,這樣執行效率更高。 二、消除了影響性能的虛擬機機制并實時回收內存 王成錄認為華為方舟編譯器的第二大特點是消除了影響性能的虛擬機機制。 在安卓系統發展過程中,虛擬機不可被忽視:Android系統是以Linux為內核構建的,為了降低應用的開發難度,并將其適配到不同硬件配置的設備上,Google在Linux內核之上構建了一個虛擬機,Android應用使用java開發,運行在虛擬機之上。 在安卓4.4之前,Dalvik就是安卓系統上使用的虛擬機,基于寄存器。從Android 2.2開始,Dalvik開始使用JIT(Just In Time)技術來進行代碼轉譯,將頻繁調用的代碼轉換為二進制碼,不用每次解釋,而在此前Dalvik虛擬機將所有的Java語句逐句解釋執行,效率很低。。 但Dalvik越來越不能滿足需求,從Android 5.0開始,虛擬機從Dalvik換成了ART。 ART(Android RunTime)虛擬機,采用AOT(Ahead Of Time)技術,會在應用程序安裝時就預編譯字節碼到機器語言,不再在執行時解釋,從而優化了應用運行的速度。 所以,到目前為止,安卓系統的任何機器只要裝上應用裝上就會分配好虛擬機,占用額外的系統資源,消費者從應用市場下載APP以后,真正解釋成機器指令和執行文件是在手機上的虛擬機里做的,因此對系統資源要求高。 王成錄表示,ART的執行效率雖然提高了,但是對于那些Java動態特性的部分,仍然做不到直接編譯,還是要解釋執行。 這源于Java不是Python那樣的動態語言,但開發者經常會用到它一個非常突出的動態相關機制:反射機制。Java反射機制主要提供了以下功能:在運行時判斷任意一個對象所屬的類、在運行時構造任意一個類的對象、在運行時判斷任意一個類所具有的成員變量和方法、在運行時調用任意一個對象的方法、生成動態代理。 王成錄表示,Java動態特性使得開發者“不需要把所有的程序都寫好,只要能夠運行時實現調用就可以了。”但這部分往往只能在運行時進行處理。而方舟編譯器最大的突破就在于此:把動態的部分全部靜態編譯掉。 這確實很難。 王成錄認為,這就像一個優秀的翻譯官,一定要對漢語言文學理解的非常到位,然后再對英語理解非常到位;所以,核心是一定要對Java語言動態特性非常深入的了解和理解,“Java有非常多的庫和業務邏輯,這些業務邏輯它生成各種各樣的應用和代碼和業務邏輯,這些業務邏輯就需要團隊不斷地去理解它,這個理解有點類似于做代碼測試的遍歷一樣,我讓這個代碼全跑到,才知道可不可以,它需要非常多的時間去積累,我對于庫的理解,當然需要技術,我理解這個庫本身的具體含義,有點像AI里面,我要收集東西,訓練一個模型。如果這個東西沒有的話,我訓練出來的模型不好,我這個機器沒法執行,這個道理特別像。” 然后還需要對這些安卓現有的應用可能會用到哪些庫、這些庫之間需要怎么用,需要大量的分析運行狀態,才能夠將這些動態特性完成提前的編譯。“實際上華為對于Android整個系統各種應用的運行,做了非常仔細去確認,相當于一個應用從底層起來,一直跑完以后,到底經過哪些過程,這些過程可能會帶來什么問題?去哪些庫取東西,這些東西積累越多,放到動態庫里面,把它編譯完了。有了這2個積累,才能做成這件事情。” 對于效果,有開發者向網易科技表示,“做成了靜態編譯,速度肯定會更快?!? 方舟編譯器還能提供更高效的內存回收機制。 王成錄表示,Android的原生內存回收,在全局回收時需要暫停應用,等待回收完成,這是產生隨機卡頓的重要原因,“而在方舟編譯器里,會在編譯時為程序配備及時回收的內存處理機制,在程序執行過程當中實時處理。” 三、 可以靈活實現不同應用的性能優化 王成錄表示,方舟編譯器的第三個亮點是可以靈活實現不同應用的性能優化。 他表示,現有的安卓編譯大部分代碼在虛擬機環境運行,而虛擬機的創建由于來自于同一套“模板”,難以作深度的優化:不同應用的優化訴求不一樣;相比之下,方舟編譯器不一樣,每個應用編譯優化方案自己來定,分別形成不同應用優化后的機器碼,“相當于說,我們給每一個有追求的應用開發者,都有了一個把自己的應用做的更好的機會,不再受限于Android虛擬機的限制?!? 王成錄稱,方舟編譯器最理想的目標就是“上層業務代碼不需要改,大家只需要通過華為的方舟編譯器做重新編譯就足夠了。” 他希望,Android陣營所有合作伙伴大家一起努力,從各自場景、各自平臺不斷去打磨它