`
IcyFenix
  • 浏览: 363083 次
  • 性别: Icon_minigender_1
  • 来自: 珠海
文章分类
社区版块
存档分类
最新评论

自己动手编译Windows版的OpenJDK 7

阅读更多
声明:
  1. 本文来自于《深入理解Java虚拟机:JVM高级特性与最佳实践》第一章,转载请注明出处。
  2. 作者推荐大家对本文“看过就算”,真正要编译JDK的话,请不要选择在Windows平台编译,难度……嗯,应该说是“麻烦程度”比Linux平台编译高几个数量级。在Linux平台的JDK编译攻略,请参考撒迦这篇文章。相信我,哪怕你没有Linux环境,临时装一个ubuntu,加上安装操作系统的时间都比直接在Windows下编译来得快。
  3. 如果要在Windows平台编译的话,看看是否需要把整个JDK(HotSpot、Library、Utils(如VisualVM等)、JAXWS、etc)都编译出来,相信大部分人只想要一个虚拟机,那可以关闭掉其他部分的编译,省事不少。但本文是按照“全部编译”来写的攻略。
-------------------------- 上面是唠叨,下面是攻略,我是分割线 --------------------------

1.5 实战:自己编译JDK

  想要一探JDK内部的实现机制,最便捷的路径之一就是自己编译一套JDK,通过阅读和跟踪调试JDK源码去了解Java技术体系的原理,虽然门槛会高一点,当肯定会比阅读各种文章、书籍来得更加贴近本质些。另外JDK中的很多底层方法都是Native的,需要跟踪这些方法的运作或对JDK进行Hack的时候,都需要自己编译一套JDK。
  现在网络上有不少开源的JDK实现可以供我们选择,如Apache Harmony、OpenJDK等。考虑到Sun系列的JDK是现在使用得最广泛的JDK版本,笔者选择了OpenJDK进行这次编译实战。


1.5.1 获取JDK源码

  首先确定要使用的JDK版本,OpenJDK 6和OpenJDK 7都是开源的,源码都可以在它们的主页(http://openjdk.java.net/)上找到,OpenJDK 6的源码其实是从OpenJDK 7的某个基线中引出的,然后剥离掉JDK 1.7相关的代码,从而得到一份可以通过TCK 6的JDK 1.6实现,因此直接编译OpenJDK 7会更加“原汁原味”一些,其实这两个版本的编译过程差异并不大。
  获取源码有两种方式。一是通过Mercurial代码版本管理工具从Repository中直接取得源码(Repository地址:http://hg.openjdk.java.net/jdk7/jdk7),这是最直接的方式,从版本管理中看变更轨迹比看什么Release Note都来得实在,不过坏处自然是太麻烦了一些,尤其是Mercurial远不如SVN、ClearCase或CVS之类的版本控制工具那样普及。另外一种就是直接下载官方打包好的源码包了,可以从Source Releases页面(地址:http://download.java.net/openjdk/jdk7/)取得打包好的源码,一般来说大概一个月左右会更新一次,虽然不够及时,但的确方便了许多。笔者下载的是OpenJDK 7 Early Access Source Build b121版,2010年12月9日发布的,大概81.7MB,解压出来约308MB。


1.5.2 系统需求

  如果可能,笔者建议尽量在Linux或Solaris上构建OpenJDK,这要比在Windows平台上轻松许多,而且网上能找到的资料绝大部分都是在Linux上编译的。如果一定要在Windows平台上编译,建议读者认真阅读一下源码中的README-builds.html文档(无论在OpenJDK网站上还是在下载的源码包里面都有这份文档),因为编译过程中需要注意的细节非常多。虽然不至于像文档上所描述的“Building the source code for the JDK requires a high level of technical expertise. Sun provides the source code primarily for technical experts who want to conduct research(编译JDK需要很高的专业技术,Sun提供JDK源码是为了技术专家进行研究之用)”那么夸张,但是如果读者是第一次编译,那在上面耗费一整天乃至更多的时间都很正常。
  笔者在本次实战中演示的是在32位Windows 7平台下编译x86版的OpenJDK(也就是32位的JDK),如果需要编译x64版,那毫无疑问也需要一个64位的操作系统。另外编译涉及的所有文件都必须存放在NTFS格式的文件系统中,因为FAT32格式无法支持大小写敏感的文件名。在官方文档上写到:编译至少需要512MB的内存和600MB的磁盘空间。如果读者耐心很好的话,512MB的内存基本上也可以凑合使用,不过600MB的磁盘空间仅仅是指存放OpenJDK源码和相关依赖项的空间,要完成编译,600MB肯定是无论如何都不够的,这次实战中所下载的工具、依赖项、源码,全部安装、解压完成最少(最少是指只下载C++编译器,不下载VS的IDE)需要超过1GB的空间。
  对系统的最后一点要求就是所有的文件,包括源码和依赖项目,都不要放在包含中文或空格的目录里面,这样做不是一定不可以,只是这样会为后续建立CYGWIN环境带来很多额外的工作,这是由于Linux和Windows的磁盘路径差别所导致的,我们也没有必要自己给自己找麻烦。


1.5.3 构建编译环境

  准备编译环境的第一步是去安装一个CYGWIN 。这是一个在Windows平台下模拟Linux运行环境的软件,提供了一系列的Linux命令支持。需要CYGWIN的原因是在编译中要使用GNU Make来执行Makefile文件(C/C++程序员肯定很熟悉,如果只使用Java,那把这个东西当做C++版本的ANT看待就可以了)。安装CYGWIN时不能直接默认安装,因为表1-2中所示的工具都不会进行默认安装,但又是编译过程中需要的,因此要在图1-6的安装界面中进行手工选择。

  表1-2 需要手工选择安装的CYGWIN工具
文件名分类描述
ar.exeDevelbinutilsThe GNU assembler, linker and binary utilities
make.exeDevelmakeThe GNU version of the 'make' utility built for CYGWIN.
m4.exeInterpretersm4GNU implementation of the traditional Unix macro processor
cpio.exeUtilscpioA program to manage archives of files
gawk.exeUtilsawkPattern-directed scanning and processing language
file.exeUtilsfileDetermines file type using 'magic' numbers
zip.exeArchivezipPackage and compress (archive) files
unzip.exeArchiveunzipExtract compressed files in a ZIP archive
free.exeSystemprocpsDisplay amount of free and used memory in the system

  CYGWIN安装时的定制包选择界面如图1-6所示:


图1-6 CYGWIN安装界面
  建立编译环境的第二步是安装编译器。JDK中最核心的代码(Java虚拟机及JDK中Native方法的实现等)是使用C++语言及少量的C语言编写的,官方文档中说他们的内部开发环境是在Microsoft Visual Studio C++ 2003(VS2003)中进行编译,同时也在Microsoft Visual Studio C++ 2010(VS2010)中测试过,所以最好只选择这两个编译器之一进行编译。如果选择VS2010,那么在编译器之中已经包含了Windows SDK v 7.0a,否则可能还要自己去下载这个SDK,并且更新PlatformSDK目录。由于笔者没有购买Visual Studio 2010的IDE,所以仅仅下载了VS2010 Express中提取出来的C++编译器,这部分是免费的,但单独安装好编译器比较麻烦。建议读者选择使用整套Visual Studio C++ 2010或Visual Studio C++ 2010 Express版进行编译。
  需要特别注意的一点:CYGWIN和VS2010安装之后都会在操作系统的PATH环境变量中写入自己的bin目录路径,必须检查并保证VS2010的bin目录一定要在CYGWIN的bin目录之前,因为这两个软件的bin目录之中各自都有个连接器“link.exe”,但是只有VS2010中的连接器可以完成OpenJDK的编译。
  准备JDK编译环境的第三步就是下载一个已经编译好了的JDK。这听起来也许有点滑稽——要用鸡蛋孵小鸡还真得必须先养一只母鸡呀?但仔细想想其实这个步骤很合理:因为JDK包含的各个部分(Hotspot、JDK API、JAXWS、JAXP……)有的是使用C++编写的,而更多的代码则是使用Java自身实现的,因此编译这些Java代码需要用到一个可用的JDK,官方称这个JDK为“Bootstrap JDK”。而编译OpenJDK 7的话,Bootstrap JDK必须使用JDK6 Update 14或之后的版本,笔者选用的是JDK6 Update 21。
  最后一个步骤是下载一个Apache ANT,JDK中Java代码部分都是使用ANT脚本进行编译的,ANT版本要求在1.6.5以上,这部分是Java的基础知识,对本书的读者来说应该没有难度,笔者就不再详述。


1.5.4 准备依赖项

  前面说过,OpenJDK中开放的源码并没有达到100%,还有极少量的无法开源的产权代码存在。OpenJDK承诺日后将逐步使用开源实现来替换掉这部分产权代码,但至少在今天,编译JDK还需要这部分闭源包,官方称之为“JDK Plug”(注1) ,它们从前面的Source Releases页面就可以下载到。在Windows平台的JDK Plug是以Jar包的形式提供的,通过下面这条命令可以安装它:
java –jar jdk-7-ea-plug-b121-windows-i586-09_dec_2010.jar
  运行后将会显示如图1-7的协议,点击ACCEPT接受协议,然后把Plug安装到指定目录即可。安装完毕后建立一个环境变量“ALT_BINARY_PLUGS_PATH”,变量值为此JDK Plug的安装路径,后面编译程序时需要用到它。


图1-7 JDK Plug安装协议

  除了要用到JDK Plug外,编译时还需要引用JDK的运行时包,这个是编译JDK中用Java代码编写的那部分所需要的,如果仅仅是想编译一个HotSpot虚拟机的话则可以不用。官方文档把这部分称之为“Optional Import JDK”,可以直接使用前面Bootstrap JDK的运行时包,我们需要建立一个名为“ALT_JDK_IMPORT_PATH”的环境变量指向JDK的安装目录。
  第三步是安装一个大于2.3版的FreeType ,这是一个免费的字体渲染库,JDK的Swing部分和JConsole这类工具要使用到它。安装好后建立两个环境变量“ALT_FREETYPE_LIB_PATH”和“ALT_FREETYPE_HEADERS_PATH”,分别指向FreeType安装目录下的bin目录和include目录。另外还有一点官方文档没有提到但必须要做的事情是把FreeType的bin目录加入到PATH环境变量中。
  第四步是下载Microsoft DirectX 9.0 SDK(Summer 2004),安装后大约有298MB,在微软官方网站上搜索一下就可以找到下载地址,它是免费的。安装后建立环境变量“ALT_DXSDK_PATH”指向DirectX 9.0 SDK的安装目录。
  第五步是去寻找一个名为“MSVCR100.DLL”的动态链接库,如果读者在前面安装了全套的Visual Studio 2010,那这个文件在本机就能找到,否则上网搜索一下也能找到单独的下载地址,大概有744KB。建立环境变量“ALT_MSVCRNN_DLL_PATH”指向这个文件所在的目录。如果读者选择的是VS2003,这个文件名应当为“MSVCR73.DLL”,应该在很多软件中都包含有这个文件,如果找不到的话,前面下载的“Bootstrap JDK”的bin目录中应该也有一个,直接拿来用吧。


1.5.5 进行编译

  现在需要下载的编译环境和依赖项目都准备齐全了,最后我们还需要对系统做一些设置以便编译能够顺利通过。
  首先执行VS2010中的VCVARS32.BAT,这个批处理文件的目的主要是设置INCLUDE、LIB、和PATH这几个环境变量,如果和笔者一样只是下载了编译器的话则需要手工设置它们,各个环境变量的设置值可以参考下面给出的代码清单1-1中的内容。批处理运行完之后建立“ALT_COMPILER_PATH”环境变量让Makefile知道在哪里可以找到编译器。
  再建立“ALT_BOOTDIR”和“ALT_JDK_IMPORT_PATH”两个环境变量指向前面提到的JDK 1.6的安装目录。建立“ANT_HOME”指向Apache ANT的安装目录。建立的环境变量很多,为了避免遗漏,笔者写了一个批处理文件以供读者参考,如代码清单1-1所示。

  代码清单1-1 环境变量设置
SET ALT_BOOTDIR=D:/_DevSpace/JDK 1.6.0_21
SET ALT_BINARY_PLUGS_PATH=D:/jdkBuild/jdk7plug/openjdk-binary-plugs
SET ALT_JDK_IMPORT_PATH=D:/_DevSpace/JDK 1.6.0_21
SET ANT_HOME=D:/jdkBuild/apache-ant-1.7.0
SET ALT_MSVCRNN_DLL_PATH=D:/jdkBuild/msvcr100
SET ALT_DXSDK_PATH=D:/jdkBuild/msdxsdk
SET ALT_COMPILER_PATH=D:/jdkBuild/vcpp2010.x86/bin
SET ALT_FREETYPE_HEADERS_PATH=D:/jdkBuild/freetype-2.3.5-1-bin/include
SET ALT_FREETYPE_LIB_PATH=D:/jdkBuild/freetype-2.3.5-1-bin/bin

SET INCLUDE=D:/jdkBuild/vcpp2010.x86/include;D:/jdkBuild/vcpp2010.x86/sdk/Include;%INCLUDE%
SET LIB=D:/jdkBuild/vcpp2010.x86/lib;D:/jdkBuild/vcpp2010.x86/sdk/Lib;%LIB%
SET LIBPATH=D:/jdkBuild/vcpp2010.x86/lib;%LIB%
SET PATH=D:/jdkBuild/vcpp2010.x86/bin;D:/jdkBuild/vcpp2010.x86/dll/x86;D:/Software/OpenSource/cygwin/bin;%ALT_FREETYPE_LIB_PATH%;%PATH%

  最后还需要再进行两项调整,官方文档没有说明这两项,但是必须要做完才能保证编译过程的顺利通过:一是取消环境变量JAVA_HOME,这点很简单;另外一项是尽量在英文的操作系统上编译,估计大部分读者会感到比较为难吧。如果不能在英文的系统上编译就把系统的文字格式调整为“英语(美国)”,在控制面板-区域和语言选项的第一个页签中可以设置。如果这个设置还不能更改就建立一个“BUILD_CORBA”的环境变量,将值设置为false,取消编译CORBA部分。否则Java IDL(idlj.exe)为*.idl文件生成CORBA适配器代码的时候会产生中文注释,而这些中文注释会因为字符集的问题而导致编译失败。
  完成了上述繁琐的准备工作之后,我们终于可以开始编译了。进入控制台(Cmd.exe)后运行刚才准备好的设置环境变量的批处理文件,然后输入bash进入Bourne Again Shell环境(习惯sh或ksh的读者请自便)。如果JDK的安装源码中存在“jdk_generic_profile.sh”这个Shell脚本,先执行它,笔者下载的OpenJDK 7 B121版没有这个文件了,所以直接输入make sanity来检查我们前面所做的设置是否全部正确。如果一切顺利几秒钟之后会有类似代码清单1-2所示的输出。

  代码清单1-2 make sanity检查
D:\jdkBuild\openjdk7>bash
bash-3.2$ make sanity
cygwin warning:
  MS-DOS style path detected: C:/Windows/system32/wscript.exe
  Preferred POSIX equivalent is: /cygdrive/c/Windows/system32/wscript.exe
  CYGWIN environment variable option "nodosfilewarning" turns off this warning.
  Consult the user's guide for more details about POSIX paths:
    http://cygwin.com/cygwin-ug-net/using.html#using-pathnames
( cd  ./jdk/make && \

……因篇幅关系,中间省略了大量的输出内容……

OpenJDK-specific settings:
  FREETYPE_HEADERS_PATH = D:/jdkBuild/freetype-2.3.5-1-bin/include
    ALT_FREETYPE_HEADERS_PATH = D:/jdkBuild/freetype-2.3.5-1-bin/include
  FREETYPE_LIB_PATH = D:/jdkBuild/freetype-2.3.5-1-bin/bin
    ALT_FREETYPE_LIB_PATH = D:/jdkBuild/freetype-2.3.5-1-bin/bin

OPENJDK Import Binary Plug Settings:
  IMPORT_BINARY_PLUGS = true
  BINARY_PLUGS_JARFILE = D:/jdkBuild/jdk7plug/openjdk-binary-plugs/jre/lib/rt-closed.jar
    ALT_BINARY_PLUGS_JARFILE =
  BINARY_PLUGS_PATH = D:/jdkBuild/jdk7plug/openjdk-binary-plugs
    ALT_BINARY_PLUGS_PATH = D:/jdkBuild/jdk7plug/openjdk-binary-plugs
  BUILD_BINARY_PLUGS_PATH = J:/re/jdk/1.7.0/promoted/latest/openjdk/binaryplugs
    ALT_BUILD_BINARY_PLUGS_PATH =
  PLUG_LIBRARY_NAMES =

Previous JDK Settings:
  PREVIOUS_RELEASE_PATH = USING-PREVIOUS_RELEASE_IMAGE
    ALT_PREVIOUS_RELEASE_PATH =
  PREVIOUS_JDK_VERSION = 1.6.0
    ALT_PREVIOUS_JDK_VERSION =
  PREVIOUS_JDK_FILE =
    ALT_PREVIOUS_JDK_FILE =
  PREVIOUS_JRE_FILE =
    ALT_PREVIOUS_JRE_FILE =
  PREVIOUS_RELEASE_IMAGE = D:/_DevSpace/JDK 1.6.0_21
    ALT_PREVIOUS_RELEASE_IMAGE =
Sanity check passed.

  Makefile的Sanity检查过程输出了编译所需的所有环境变量,如果看到“Sanity check passed.”说明检查过程通过了,可以输入“make”执行整个Makefile,然后就去喝个下午茶再回来了,笔者Core i5 / 4GB RAM的机器编译整个JDK大概需要半个小时多点。如果失败则需要根据系统输出的失败原因,回头再检查一下对应的设置。并且最好在下一次编译之前先执行“make clean”来清理掉上次编译遗留的文件。
  编译完成之后,打开OpenJDK源码下的build目录,看看是不是已经有一个编译好的JDK在那里等着了?执行一下“java -version”,看到以自己机器命名的JDK了吧,很有成就感吧?

【注1】:在2011年,JDK plug已经不再需要了,但在笔者写本次实战时使用的2010年12月9日发布的OpenJDK b121版还是需要这些JDK plug。
  • 大小: 31.4 KB
  • 大小: 33.1 KB
分享到:
评论
22 楼 逆风翔 2015-05-19  
我是按照楼主前言找到这个博客,离大牛还是很近的。openjdk的jdk7的现在的版本的b147,Mercurial是不是不能像svn那样下载历史b121版本?
21 楼 javacainiaosc 2015-05-07  
我根据OpenJDK Build README文档在linux环境上构建OpenJDK8,构建成功后的OpenJDK8可以在windows环境下使用吗?
20 楼 javacainiaosc 2015-05-07  
在Ubuntu 编译的jdk在windows下可以使用吗
19 楼 _Young_嗯嗯 2014-01-13  
hihi,你好, 本人菜鸟一枚 , 我想像博主一样提取这个C++编译器, 请指教  
18 楼 czyeclipse 2013-12-05  
为什么我运行编译后的openjdk7报这个错误啊
17 楼 Bll 2013-12-04  
RednaxelaFX 写道
guanzhenxing 写道
楼主你好,我买了您的书。但是,按照您上面提供的地址,我找不到OpenJDK源码的下载地址,您能发一份源码吗?谢谢! guan.zhenxing@foxmail.com

那个…我没有出过书诶 不知道您买的是哪本书呢?或许是IcyFenix的书?
OpenJDK的源码在官网就可以下载到,http://openjdk.java.net/,页面左边有bundles,可以选择版本来下载打包好的源码包。如果会使用Mercurial的话也可以用它来下载最新的代码。


怎么下着下着速度就没了,公司网速不慢哪,还有没有别的地方可以下呢?
16 楼 Bll 2013-12-04  
1.输入书上的网址,怎么下不了——下一会儿速度就没了,变成了0;
http://download.java.net/openjdk/jdk7/


2.后面网上搜了一下关键字 b121,结果也是下着下着速度就变成了0——试了很多次都这样
http://download.java.net/openjdk/jdk7/promoted/b121/


奇怪!
15 楼 jarry8359 2012-08-10  
LZ的书不错,但是在windows下编译老出问题,google之后发现,需要替换make.exe文件,还差cygwin/bin/cygintl-3.dll文件,文件夹不能有中文或空格。搞了半天还是报错。

ERROR: Cannot find the REBASE utility from path: /usr/bin/rebase
       This is normally obtained from the WINDOWSSDKDIR.
ERROR: Cannot find the RC utility from path: /usr/bin/rc
       This is normally obtained from the WINDOWSSDKDIR.
ERROR: FreeType version  2.3.0  or higher is required.

WIN7下的64位和XP的32位,都是这个错误。百度,谷歌找了半天没答案,望楼主解答。

确定freetype是2.3.5的win安装版,和LZ的配置一样。
14 楼 zhctj159 2012-06-13  
不能回复啊。。
13 楼 RednaxelaFX 2012-04-05  
guanzhenxing 写道
楼主你好,我买了您的书。但是,按照您上面提供的地址,我找不到OpenJDK源码的下载地址,您能发一份源码吗?谢谢! guan.zhenxing@foxmail.com

那个…我没有出过书诶 不知道您买的是哪本书呢?或许是IcyFenix的书?
OpenJDK的源码在官网就可以下载到,http://openjdk.java.net/,页面左边有bundles,可以选择版本来下载打包好的源码包。如果会使用Mercurial的话也可以用它来下载最新的代码。
12 楼 guanzhenxing 2012-04-04  
楼主你好,我买了您的书。但是,按照您上面提供的地址,我找不到OpenJDK源码的下载地址,您能发一份源码吗?谢谢! guan.zhenxing@foxmail.com
11 楼 Fatyu 2011-11-14  
李钦珑 写道
楼主加油,我已经在当当预订了书。昨天也按照你给的步骤,成功搞出1.7了。。。哈哈,受教了

你老人家怎么弄成的
10 楼 boy00fly 2011-06-21  
RednaxelaFX 写道
IcyFenix 写道
boy00fly 写道

再请教下楼主从事开发的产品所面向的行业是什么,工作内容主要做什么?平时一直在做jvm这方面的研究吗?
我本身学习jvm也是自身的一个兴趣,工作中其实根本用不到,如果工作中能够用到,再加上自身的兴趣的话,可能就会更加有动力了。。


其实工作和JVM扯不上太大关系,应该说是兴趣吧。

国内企业貌似就淘宝有对JVM实现级别的改进和调优了。

当然不是啦。跟JVM相关的工作还是有好些地方有的。

龙芯相关的话,OpenJDK的MIPS移植项目现在应该还在进行中吧。好一段时间没跟他们聊过了。

以前的话Intel北京也应该有过相关研究吧?现在也应该还有类似JVM的VM开发工作进行中。
IBM以前在上海也有Harmony相关研发(不过貌似主要是类库一侧;DRLVM的部分确实也有国人在参与不过我不太熟…)

嵌入式的JVM开发的话应该很多地方都有在做,特别是各种硬件平台上的定制、移植之类的。

楼上讲得都很深啊,面很广啊,有机会也想尝试尝试呢。呵呵
9 楼 RednaxelaFX 2011-06-20  
IcyFenix 写道
boy00fly 写道

再请教下楼主从事开发的产品所面向的行业是什么,工作内容主要做什么?平时一直在做jvm这方面的研究吗?
我本身学习jvm也是自身的一个兴趣,工作中其实根本用不到,如果工作中能够用到,再加上自身的兴趣的话,可能就会更加有动力了。。


其实工作和JVM扯不上太大关系,应该说是兴趣吧。

国内企业貌似就淘宝有对JVM实现级别的改进和调优了。

当然不是啦。跟JVM相关的工作还是有好些地方有的。

龙芯相关的话,OpenJDK的MIPS移植项目现在应该还在进行中吧。好一段时间没跟他们聊过了。

以前的话Intel北京也应该有过相关研究吧?现在也应该还有类似JVM的VM开发工作进行中。
IBM以前在上海也有Harmony相关研发(不过貌似主要是类库一侧;DRLVM的部分确实也有国人在参与不过我不太熟…)

嵌入式的JVM开发的话应该很多地方都有在做,特别是各种硬件平台上的定制、移植之类的。
8 楼 IcyFenix 2011-06-20  
scottcgi 写道
楼主加油,这书我肯定买

李钦珑 写道
楼主加油,我已经在当当预订了书。昨天也按照你给的步骤,成功搞出1.7了。。。哈哈,受教了

多谢支持。
7 楼 IcyFenix 2011-06-20  
boy00fly 写道

再请教下楼主从事开发的产品所面向的行业是什么,工作内容主要做什么?平时一直在做jvm这方面的研究吗?
我本身学习jvm也是自身的一个兴趣,工作中其实根本用不到,如果工作中能够用到,再加上自身的兴趣的话,可能就会更加有动力了。。


其实工作和JVM扯不上太大关系,应该说是兴趣吧。

国内企业貌似就淘宝有对JVM实现级别的改进和调优了。

6 楼 李钦珑 2011-06-20  
楼主加油,我已经在当当预订了书。昨天也按照你给的步骤,成功搞出1.7了。。。哈哈,受教了
5 楼 scottcgi 2011-06-20  
楼主加油,这书我肯定买
4 楼 boy00fly 2011-06-20  
最近也是一直在研究看看JVM相关的内容,结合《深入JVM》第二版这本书。刚刚看了下楼主写的书目录。对了下两本书的对比:
第一章 走进Java
        这个不用多说了,不过实战自己编译JDK却是亮点。
第二章 Java内存区域与内存溢出异常
       2.3节多出了一个OutOfMemoryError异常的处理的例子,其他的都是差不多的。
第三章 垃圾收集器与内存分配策略
       基本上都差不多(但应该会有些楼主自己多年工作经验的积累)
第四章 虚拟机性能监控、故障处理工具
第五章 调优案例分析与实践
       这个是多出来的两个章节,是属于实战性比较强的内容,没有多年经验很难写得出来。
第六章 类文件结构
第七章 虚拟机类加载机制
第八章 虚拟机字节码执行引擎
       以上三章属于基础类知识,应该是差不多的内容,毕竟很多是JVM设计者自身设计上面的内容,讲规范较多。
第九章 类加载与执行子系统的案例与分析
       这个也是偏重实战较多,结合JVM本身的ClassLoader机制,分析现有软件的机制,自己再分析如何实现。
第十章 早期(编译期)优化
第十一章 晚期(运行期)优化
         介绍了JVM在不同时期的优化相关的内容
第十二章 Java内存模型与线程
第十三章 线程安全与锁优化
         这个也是两本书中均有谈到的内容,估计应该差不了多少。

总体来讲还是有不少地方值得看的,写出一本书来,没有多年的经验,恐怕很难完成,或许多年以后我也会尝试在某一个领域做深入学习得出一些心德出来。
以上分析得有不妥的地方还请楼主谅解,本人自身经验尚浅,呵呵。

ps:再请教下楼主从事开发的产品所面向的行业是什么,工作内容主要做什么?平时一直在做jvm这方面的研究吗?
我本身学习jvm也是自身的一个兴趣,工作中其实根本用不到,如果工作中能够用到,再加上自身的兴趣的话,可能就会更加有动力了。。
3 楼 hatedance 2011-06-18  
c/cpp程序员喜欢用make来编译项目,虽然用ide比如eclipse for cdt其实也能支持编译;
java程序员喜欢让ide负责编译,虽然也可以用ant来完成编译;

一个原本简单的编译任务,被make搞得很专业,很复杂。以至于我试图用cdt来编译jdk的时候感到很绝望。

相关推荐

    已编译好的windows版openjdk7 part2

    已编译好的java.net官网的windows版的openjdk7下载 part2 请下载共2part以后放在同一个文件夹里面解压(推荐360压缩,我是用这个加压的) 所有下载链接: http://blog.csdn.net/qgmzzn1/article/details/16918153

    已编译好的windows版openjdk7 part1

    已编译好的java.net官网的windows版的openjdk7下载 part1 请下载共2part以后放在同一个文件夹里面解压(推荐360压缩,我是用这个加压的) 所有下载链接: http://blog.csdn.net/qgmzzn1/article/details/16918153

    自己编译的windows环境openjdk1.7 32位全源码 src.zip太大放在了另一个文件里

    标题中的“自己编译的windows环境openjdk1.7 32位全源码 src.zip太大放在了另一个文件里”表明这是一个关于在Windows操作系统环境下,32位架构下自行编译OpenJDK 1.7的项目。OpenJDK是Java开发工具包的一个开源实现...

    OPENJDK编译之后版本

    OPENJDK-7 windows编译之后版本

    编译OpenJDK7资料夹.rar

    本资料夹包含的内容是关于在Linux环境下编译OpenJDK7的完整过程及可能遇到的问题解决方法。 首先,要编译OpenJDK7,你需要一个Linux环境,因为OpenJDK主要是为类Unix系统设计的。推荐使用Ubuntu或Debian这样的基于...

    openjdk 1.7 windows 64位

    OpenJDK 1.7,也被称为Java Development Kit (JDK) 7,是由OpenJDK社区开发的一个开源实现,它是Java平台标准版(Java SE)的免费版本。这个版本的OpenJDK专为Windows 64位操作系统设计,因此在64位Windows环境下...

    openjdk-7(2)

    OpenJDK 7是Java开发工具包...虽然OpenJDK 7在Windows上的编译版本已经有些年代,但它对于理解Java发展历程和学习经典特性仍然具有很高的价值。同时,对于需要兼容旧版Java应用的场景,OpenJDK 7仍然是一个可靠的选择。

    openjdk 18 windows版本 解压安装包

    OpenJDK 18是Java开发工具包的一个版本,专为Windows操作系统设计。这个解压安装包包含了所有必要的组件,使开发者能够在Windows环境下编写、编译和运行Java应用程序。OpenJDK是Java Development Kit(JDK)的一个...

    OpenJdk-7.zip

    在Ubuntu中,使用OpenJDK-7进行Java开发,开发者可以利用各种IDE(如IntelliJ IDEA、Eclipse)或命令行工具编写、编译和运行Java程序。此外,还可以通过`update-alternatives`命令来设置默认的Java版本,以便在多个...

    OpenJDK 8_322 windows 解压安装版

    OpenJDK 8_322 Windows 解压安装版是一个针对Windows操作系统的Java开发工具包,它是2022年1月发布的最新版本。OpenJDK(Open Source Java Development Kit)是一个开源的Java平台实现,它遵循GPLv2许可证,旨在提供...

    openjdk 19 windows版本 解压安装包

    总之,OpenJDK 19为Windows用户提供了完整的Java开发和运行环境,它包括了编译、运行、调试和打包Java应用程序所需的所有工具。通过解压安装包并正确配置环境变量,你可以开始享受Java 19带来的新特性和性能提升。...

    openjdk 17.01 windows版本 解压安装包

    在Windows平台上安装OpenJDK 17.0.1,你需要先下载对应的压缩包文件"jdk-17.0.1"。这个压缩包包含了OpenJDK的所有必要组件,如Java虚拟机(JVM)、编译器(javac)、Java运行时环境(JRE)以及各种开发工具。解压后...

    最新版windows openjdk-17.0.1_windows-x64_bin.zip

    OpenJDK,全称为Open Source Java Development Kit,是Java开发工具包的一个开源实现,它为Java编程语言和Java平台标准版(Java SE)提供了一个免费、开放源代码的实现。在本文中,我们将深入探讨OpenJDK 17.0.1版本...

    openjdk-11.0.19-windows版本

    Windows版的OpenJDK 11.0.19特别针对微软的操作系统进行了优化,以提供最佳的兼容性和性能。这包括对Windows API的调用,以及对Windows系统服务的支持。安装后,开发者可以在Windows环境下编写、测试和部署Java应用...

    openjdk 11.02 windows版本 解压安装包

    7. **开发与运行**: 安装完成后,开发者可以在IDE(如Eclipse、IntelliJ IDEA或Visual Studio Code)中配置OpenJDK 11作为项目的JDK版本,或者在命令行中使用`javac`编译Java源代码,用`java`运行编译后的字节码文件...

    openJDK1.8下载(windows版本)

    openJDK1.8下载(windows版本) ,红帽版本,找了好久有需要的可以积分下载.........

    openjdk-1.7.0-u80-windows-amd64-new.zip

    使用OpenJDK 1.7.0_u80,开发者可以编写符合Java 7规范的代码,并在Windows 64位环境下运行和调试。然而,需要注意的是,随着技术的发展,Java已经有了更多的更新版本,比如Java 8、9、11等,它们带来了更多新特性和...

    openjdk-6.tar.gz

    "orig"通常意味着原始或者未经修改的版本,这可能是一个未经打包或编译的源代码版本,开发者可以用它来编译自己的OpenJDK 6实例。 在Linux系统上安装和使用OpenJDK 6通常涉及以下步骤: 1. 解压文件:使用`tar -...

    Win7下编译openjdk8源代码 完整版本 原创

    在介绍如何在Windows 7环境下编译OpenJDK 8源代码之前,有必要了解一些基础知识和前提条件。OpenJDK是Java平台的开源实现,其中包括JVM(Java虚拟机)和Java类库。OpenJDK的源代码使用C和C++编写,支持跨平台编译。...

    openjdk-1.7.0_121.zip

    因此,当用户尝试在Ubuntu 18.04上进行Android 6源码的编译工作时,发现无法通过常规的`apt-get`命令安装OpenJDK 7,这无疑增加了开发的难度。 在这种情况下,`openjdk-1.7.0_121.zip`的备份就显得尤为珍贵。这个...

Global site tag (gtag.js) - Google Analytics