? Java誕生在一群懶惰、急躁而傲慢的程序天才之中。
主要從事網頁設計、PC網站建設(電腦版網站建設)、wap網站建設(手機版網站建設)、響應式網站、程序開發、微網站、微信小程序等,憑借多年來在互聯網的打拼,我們在互聯網網站建設行業積累了豐富的成都網站設計、網站制作、網絡營銷經驗,集策劃、開發、設計、營銷、管理等多方位專業化運作于一體,具備承接不同規模與類型的建設項目的能力。
? 1990年12月,Sun的工程師Patrick Naughton被當時糟糕的Sun C++工具折磨的快瘋了。他大聲抱怨,并威脅要離開Sun轉投當時在Steve Jobs領導之下的NeXT公司。領導層為了留住他,給他一個機會,啟動了一個叫做Stealth(秘密行動)的項目。
? 隨著James Gosling等人的加入,這個項目更名為Green。其目標是使用C++為嵌入式設備開發一種新的基礎平臺技術,James Gosling本人負責開發一個編輯器。正如人們事后分析的那樣,這位天才的程序員太懶惰,所以沒有把C++學好,開發中碰了一頭包。于是他決定開發一種新的編程語言。他把這種語言命名為C++++--,意思是C++ “加上一些好東西,減去一些壞東西”。顯然這個糟糕的名字不可能長久,于是很快這種頗受同伴喜愛的小語言被命名為Oak。
? 到了1992年9月,Oak語言連同Green OS和一些應用程序一起發布在稱做Start 7的小設備上,有了第一次精彩的亮相。隨后,Sun開了一家名為FirstPerson的公司,整個團隊被轉移到這家公司里研發機頂盒,以投標時代華納公司的一個項目。這幫天才被技術狂熱所鼓舞,開發出了一個高交互性的設備,結果沒想到時代華納公司和有線電視服務商并不愿意用戶擁有那么大的控制權,從而在競標之戰中敗給了SGI。
? Sun無奈地關閉了FirstPerson,召回了整個團隊,java的出路卻沒有因此而斷送,隨著互聯網發展的涌動,java開始離開嵌入式小設備,往互聯網傾斜。1994年,Oak被命名為Java,回到了激情澎湃的IT產業,抓住互聯網的大潮,從此一發不可收拾。
? 剩下的事情,大家都知道了……
1991 年,James Gosling 博士發布產品 Oak( 橡樹),這是 Java 語言的前身。
1995 年,Oak 語言改名為 Java。
1996 年,JDK(Java開發所使用的工具包)1.0 發布,提供了純解釋執行的 Java 虛擬機實現:Sun Classic VM。
1997 年,JDK1.1 發布,代表技術有:JDBC、JavaBeans、內部類、反射。
1998 年,JDK1.2 發布,Java 技術體系被拆分為 J2SE、J2EE、J2ME 三大體系。
2002 年,JDK1.4 發布,Java 真正走向成熟,代表技術有:正則表達式、NIO等。
2004 年,JDK5.0 發布,對語法易用性做了很大改進,新增了泛型、枚舉等,代表技術有:并發包等。
2006 年,JDK6.0 發布,將 J2EE/J2SE/J2ME 的命名方式改為 Java SE 6、Java EE 6、Java ME 6。
2009 年,Sun 公司因為經營不善被 Oracle 公司收購。
2011 年,JDK7 發布。
2013 年,JDK8(LTS) 發布,函數式編程,lamda表達式。
2017年,JDK9
2018年,JDK 10,11(LTS)正式發布
2019年,JDK 12,13
2020年,JDK 14,15
2021年,JDK 16,17(LTS)
附:sun與微軟的軼事
java誕生的1995年,正是微軟在軟件產業地位達到巔峰的時代。但是這個初出茅廬的毛頭小子硬是引起了微軟帝國的關注。所以96年微軟就向sun申請了java認證。
微軟的加持確實推動了人們對java的信心和興趣。
但是好景不長,從1997年發布Visual J++的第一個版本開始,微軟就開始在Java中摻入自己的私有擴展。這毫無疑問引起Sun的高度重視。
1997年10月,Sun向美國加州地方法院起訴微軟公司違反兩公司就微軟使用Java技術所簽定的合同,指控微軟公司在自己的Java產品中做了“不恰當的修改”,違反了合同中承諾向用戶提供Java兼容產品的條款。
這一官司一直打到了2001年1月雙方達成和解。
到了2001年7月,微軟公布新版的Windows XP將不再支持Sun的JVM,并且推出了.NET平臺與Java分庭抗禮。
當然目前.net用的人少了,這是后話。
openjdk vs oraclejdk:
JDK(Java Development Kit)是 Java語言的軟件開發工具包,也是整個java開發的核心,它包含了JRE和開發工具包
JRE(Java Runtime Environment),Java運行環境,包含了JVM和Java的核心類庫(Java API)
JVM(Java Virtual Machine),Java虛擬機,它是運行在操作系統之上的,它與硬件沒有直接的交互
所謂“一次編碼,隨處運行“正是基于不同系統下的jvm幫你掩蓋了系統之間接口的差異:
總結
jdk是開發人員的工具包,它包含了java的運行環境和虛擬機,而一次編寫到處運行就是基于jvm
1、Sun Classic VM
? 世界上第一款商用 Java 虛擬機。
1996年隨著Java1.0的發布而發布,JDK1.4時完全被淘汰
2、BEA JRockit
專注于服務端應用,號稱是世界上最快的JVM
? 后來被 Oracle收購;Oracle JRockit (原來的 Bea JRockit)
3、IBM公司的 J9VM
全稱:IBM Technology for Java Virtual Machine,簡稱IT4J,內部代號:J9
是 IBM 自己開發的一款 JVM
市場定位于HotSpot接近,服務器端、桌面應用、嵌入式等多用途VM
4、HotSpot VM(現在最常用)
? 它是Sun JDK和OpenJDK中所帶的虛擬機,也是目前使用范圍最廣的Java虛擬機。
5、其他
(TaobaoJVM 、Graal VM、Azul VM、Liquid VM、Apache Harmony、)虛擬機
shawn@macpro:~ > java -version
java version "1.8.0_181"
Java(TM) SE Runtime Environment (build 1.8.0_181-b13)
Java HotSpot(TM) 64-Bit Server VM (build 25.181-b13, mixed mode)
hotspot虛擬機
Client VM是專門為快速啟動和小內存(small footprints)而優化的,像GUI就很適合
Server VM是專門為高性能應用而優化的,如服務器應用
版本是基于tag為1.8.0_181
1.源碼編譯:通過Java源碼編譯器將Java代碼編譯成JVM字節碼(.class文件)
2.類加載:通過ClassLoader及其子類來完成JVM的類加載
3.類執行:字節碼被裝入內存,進入JVM虛擬機,被解釋器解釋執行
由上面的圖可以看出,JVM虛擬機中主要是由三部分構成,分別是類加載子系統、運行時數據區、執行引擎。
類加載子系統
Java虛擬機把描述類的數據從Class文件加載到內存,并對數據進行校驗、轉換解析和初始化,最終形成可以被虛擬機直接使用的Java類型。
運行時數據區
Java虛擬機在執行Java程序的過程中會把它所管理的內存劃分為若干個不同的數據區域。
這些區域有各自的用途,以及創建和銷毀的時間,有的區域隨著虛擬機進程的啟動而一直存在,有些區域則是依賴用戶線程的啟動和結束而建立和銷毀。
執行引擎
執行引擎用于執行JVM字節碼指令,主要有兩種方式,分別是解釋執行和編譯執行,區別在于,解釋執行是在執行時翻譯成虛擬機指令執行,而編譯執行是在執行之前先進行編譯再執行。
解釋執行啟動快,執行效率低。編譯執行,啟動慢,執行效率高。
垃圾回收器就是自動管理運行數據區的內存,將無用的內存占用進行清除,釋放內存資源。
本地方法庫、本地庫接口
在jdk的底層中,有一些實現是需要調用本地方法完成的(使用c或c++寫的方法),就是通過本地庫接口調用完成的。比如:System.currentTimeMillis()方法。
了解jvm后續的一切動作,先從字節碼開始。它是一切發生的源頭。
package com.itheima.jvm.demo;
public class ClassStruct {
private static String name = "JVM";
public static void main(String[] args) {
System.out.println("Hello " + name);
}
}
1)maven定義編譯的版本
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>1.8</source>
<target>1.8</target>
</configuration>
</plugin>
</plugins>
</build>
2)編譯
mvn clean compile
1)vscode打開
2)class文件是一個二進制文件,轉化后是16進制展示,實際上class文件就是一張表,它由以下數據項構成,這些數據項從頭到尾嚴格按照以下順序排列:
類型 | 名稱 | 數量 | 描述 |
---|---|---|---|
u4 | magic | 1 | 魔數 |
u2 | minor_version | 1 | 次版本號 |
u2 | major_version | 1 | 主版本號 |
u2 | constant_pool_count | 1 | 常量個數 |
cp_info | constant_pool | constant_pool_count - 1 | 具體常量 |
u2 | access_flags | 1 | 訪問標志 |
u2 | this_class | 1 | 類索引 |
u2 | super_class | 1 | 父類索引 |
u2 | interfaces_count | 1 | 接口索引 |
u2 | interfaces | interfaces_count | 具體接口 |
u2 | fields_count | 1 | 字段個數 |
field_info | fields | fields_count | 具體字段 |
u2 | methods_count | 1 | 方法個數 |
method_info | methods | methods_count | 具體方法 |
u2 | attributes_count | 1 | 屬性個數 |
attribute_info | attributes | attributes_count | 具體屬性 |
3)圖示如下:
1)魔數:
CAFEBABE,咖啡寶寶,固定的。
2)版本號:
34,換成10進制就是52
jdk的版本標記映射關系:
說明編譯用的是jdk8,我們改成1.6,重新執行 mvn clean compile ,再來查看class文件試試:
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>1.6</source>
<target>1.6</target>
</configuration>
</plugin>
</plugins>
</build>
擴展
在開發中,經常會遇到類似Unsupported major.minor version 51.0的錯誤,一般情況下都是JDK版本不匹配造成的。
雖然jdk代碼在執行時基本上向下兼容,但是!開發環境和服務器環境jdk最好一致,不要嘗試這個坑。
區分和理解兩個環境:編譯環境,運行環境
再往下遵從相同的規律: 計數器(標注后面有多少個) + 對應個數的結構體
我們以常量池為例:
1)位置
2)結構說明
常量池記錄了jvm內的一堆常量信息,這部分由 【2個字節計數】 + 【n個cp_info結構】組成
其中cp_info有多種類型:
附:綠色代表指針,橙色代表直接類型
3)案例
下面以String為例,String是一種引用類,它會指向一個utf8類型來存儲真實的信息
jdk提供了一個工具,javap,可以查看常量列表的詳細內容:
javap -v ClassStruct.class
1)說明
常量池之后,是緊挨的一系列信息,這些信息大同小異,無非就是值、或者引用
(參考上面2.3.3里的表格和圖例)
2)注意事項
要看懂javap后的格式,明白這些格式,可以輕松看懂class結構
類型 | 標識符 | 案例 | 說明 |
---|---|---|---|
數組 | [ | [Ljava.lang.String | String數組 |
對象 | L | Lcom.test.Demo | |
基本類型 | 大寫字母開頭 | B=byte,I=int…… | |
組合類型
類型 | 案例 | 說明 |
---|---|---|
類里的屬性、字段、方法等 | com.test.Demo.name:Ljava.lang.String | 英文點號隔開 |
標識什么類型 | com.test.Demo.getName:()Ljava.lang.String | 英文冒號隔開 |
方法 | (參數類型)返回值類型 | 英文括弧,后面是返回值類型 |
3)實例分析
本文由
傳智教育博學谷
教研團隊發布。如果本文對您有幫助,歡迎
關注
和點贊
;如果您有任何建議也可留言評論
或私信
,您的支持是我堅持創作的動力。轉載請注明出處!
分享文章:JVM虛擬機我來了~~~
本文地址:http://vcdvsql.cn/article34/dsdihpe.html
成都網站建設公司_創新互聯,為您提供網站收錄、品牌網站建設、網站維護、域名注冊、關鍵詞優化、外貿網站建設
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯