在日常的學習,、工作,、生活中,肯定對各類范文都很熟悉吧,。范文書寫有哪些要求呢?我們怎樣才能寫好一篇范文呢,?這里我整理了一些優(yōu)秀的范文,,希望對大家有所幫助,,下面我們就來了解一下吧。
java虛擬機是實現(xiàn)跨平臺的基礎篇一
相信大家已經(jīng)了解到java具有跨平臺的特性,,可以“一次編譯,到處運行”,,在windows下編寫的程序,無需任何修改就可以在linux下運行,,這是c和c++很難做到的,。那么,跨平臺是怎樣實現(xiàn)的呢,?歡迎大家閱讀!更多相關信息請關注相關欄目,!
jvm也是一個軟件,,不同的平臺有不同的版本,。我們編寫的java源碼,,編譯后會生成一種 .class 文件,,稱為字節(jié)碼文件。java虛擬機就是負責將字節(jié)碼文件翻譯成特定平臺下的機器碼然后運行,。也就是說,只要在不同平臺上安裝對應的jvm,,就可以運行字節(jié)碼文件,,運行我們編寫的java程序。
而這個過程中,,我們編寫的java程序沒有做任何改變,,僅僅是通過jvm這一”中間層“,就能在不同平臺上運行,,真正實現(xiàn)了”一次編譯,,到處運行“的目的。
jvm是一個”橋梁“,,是一個”中間件“,,是實現(xiàn)跨平臺的關鍵,java代碼首先被編譯成字節(jié)碼文件,,再由jvm將字節(jié)碼文件翻譯成機器語言,,從而達到運行java程序的目的。
注意:編譯的結果不是生成機器碼,,而是生成字節(jié)碼,,字節(jié)碼不能直接運行,必須通過jvm翻譯成機器碼才能運行,。不同平臺下編譯生成的字節(jié)碼是一樣的,,但是由jvm翻譯成的機器碼卻不一樣,。
所以,運行java程序必須有jvm的支持,,因為編譯的結果不是機器碼,,必須要經(jīng)過jvm的再次翻譯才能執(zhí)行。即使你將java程序打包成可執(zhí)行文件(例如 .exe),,仍然需要jvm的支持,。
注意:跨平臺的是java程序,不是jvm,。jvm是用c/c++開發(fā)的,,是編譯后的機器碼,不能跨平臺,,不同平臺下需要安裝不同版本的jvm,。
java 推出的前幾年,人們有不同的看法,,解釋字節(jié)碼肯定比全速運行機器碼慢很多,,犧牲性能換來跨平臺的優(yōu)勢是否值得?
然而,,jvm 有一個選項,,可以將使用最頻繁的字節(jié)碼翻譯成機器碼并保存,這一過程被稱為即時編譯,。這種方式確實很有效,,致使微軟的 .net 平臺也使用了虛擬機。
現(xiàn)在的及時編譯器已經(jīng)相當出色,,甚至成了傳統(tǒng)編譯器的競爭對手,,某些情況下甚至超過了傳統(tǒng)編譯器,原因是jvm可以監(jiān)控運行時信息,。例如,,即時編譯器可以監(jiān)控使用頻率高的代碼并進行優(yōu)化,可以消除函數(shù)調用(即“內嵌”),。
但是,,java 畢竟有一些c/c++沒有的額外的開銷,關鍵應用程序速度較慢,。比如java采用了與平臺無關的繪圖方式,,gui程序(客戶端程序)執(zhí)行要慢;虛擬機啟動也需要時間,。
java 的gui庫稱不上出色,,界面不算友好,大部分用戶不太習慣,;java 的.客戶端資源消耗也比較大,,大數(shù)據(jù)量的應用和功能復雜的應用性能堪憂,。
更加不能接受的是,微軟因自身利益和sun分家后,,windows 便不再預裝jvm了,,用戶安裝你的程序之前,必須要安裝jvm并正確設置,,你可以要求普通用戶安裝你的軟件,,但是你能期望他了解jvm的有關知識并正確安裝設置嗎?
雖然你可以將jvm集成在你的程序中,,自動安裝并設置,,不讓用戶干預,但是你希望附帶一個比你的程序還要大好多的jvm嗎,?一個軟件這樣做或許可以接受,,成千上萬個軟件都這樣做,那用戶要安裝多少個jvm,?磁盤空間要浪費多少,?
所以,直接投放市場的面向普通用戶的客戶端程序,,用java開發(fā)的很少,,大部分java開發(fā)的客戶端是給企業(yè)內部員工使用,員工領到電腦時,,技術部已經(jīng)給配置好了,。如果你希望從事客戶端開發(fā),建議學習 c/c++ 和 .net,,它們在window客戶端開發(fā)方面有較大的優(yōu)勢。
種種原因,,注定了java客戶端不利于推向市場,,讓普通用戶接受。不過話又說回來,,客戶端開發(fā)也不是java的初衷,,java最初是面向嵌入式的,卻隨著互聯(lián)網(wǎng)的興起而快速成長,,在web開發(fā)上大顯身手,。
s("content_relate");