Error:could not open'C:\Porogram Files\Java\jrelib\j386\jvm.cfg'之解决方法
不知道什么原因,反正重装完后javac -version能查看版本,但是java -version就是不行,老报标题错误!查了很久终于解决了。。。

JDK在安装的过程当中将会生成如下3个项目:
HKEY_LOCAL_MACHINE\SOFTWARE\JavaSoft\Java Development Kit
HKEY_LOCAL_MACHINE\SOFTWARE\JavaSoft\Java Plug-in
HKEY_LOCAL_MACHINE\SOFTWARE\JavaSoft\Java Runtime Environment

同时,JDK安装程序将会把java.exe,javaw.exe,javareg.exe这3个可执行文件拷贝到winnt\system32目录下,由于 winnt\system32被操作系统缺省的设置为最高优先权的PATH搜索路径,因此可保证用户在命令行任何目录下可运行java.exe来启动 JVM。

java.exe在启动时是通过下面方式来确定的:

假如存在../jre/bin/java.dll文件,则查找../jre/lib/ jvm.cfg文件,在该文件中,第1个被列出的jvm.dll类型作为缺省值(假如在java.exe命令行指定了jvm.dll的类型,则使用指定类型)。jvm.dll类型分为hotspot,classic,server三种。假如不存在../jre/lib/jvm.cfg文件,则打印你说的错误信息:

如不存在../jre/bin/java.dll(当运行的是winnt\system32\java.exe),则注册表将在此时发挥作用, HKEY_LOCAL_MACHINE\SOFTWARE\JavaSoft\Java Runtime Environment\ CurrentVersion键值所记录的实际上是winnt\system32\java.exe的版本值,该版本值只保存主、次两个版本号,如 1.2,1.3等。

同时java.exe程序内部本身也有一个标识自身的版本值,如1.2、1.3等。java.exe根据自己内部的版本值和CurrentVersion值相比较,如果发现两个值相等,则将在HKEY_LOCAL_MACHINE\SOFTWARE\ JavaSoft\Java Runtime Environment\MainVersion.MicroVersion项下获取JRE所在目录及动态链接库,这两个键的名称分别是JavaHome 和RuntimeLib,MainVersion表示主版本号,MicroVersion表示次版本号。

如果java.exe内部版本值和CurrentVersion不一致,则报类似以下的错误:

Registry key 'Software\JavaSoft\Java Runtime Environment\CurrentVersion'
has value '1.2', but '1.3' is required.

意思是说,注册表当前所记载的winnt\system32\java.exe版本为1.2,但是此时运行的java.exe版本为1.3。 java.exe抱怨除非注册表有1.3版的记载,否则自己无法正确定位JRE目录和jvm.dll,因此提示1.3是需要的。

这里,我们不能简单的修改注册表的CurrentVersion值来达到这个目的。一般地,当在系统中装了两套版本的Java2 SDK(如先装1.2而后又装了1.3),后面安装的Java2 SDK会将自己带的java.exe和javaw.exe拷贝到winnt\system32目录下,从而覆盖先前版本的java.exe和 javaw.exe,并且在注册表中改写CurrentVersion为1.3。所以建议在安装Java2 SDK前,先卸载以前安装的版本。如果人为的修改CurrentVersion,会使得不同版本的java.exe加载与己版本不符的java.dll及 jvm.dll,将引起难以预料的后果!

特殊情况:
JBuilder自己带一套JDK,在JBuilder安装完成后,JBuilder安装程序会修改CurrentVersion为自己所带JDK的版本,但不会覆盖winnt\system32下的java.exe和javaw.exe。

WebLogic自己带一套JDK,在WebLogic安装完成后,WebLogic安装程序不会修改注册表,也不会覆盖winnt\system32下的java.exe和javaw.exe。

Oracle自己带一套JDK(一般是比较低版本的,例如8.1.7仅仅带JDK 1.1.7),在Oracle安装完成后,Oracle安装程序不会修改注册表,也不会覆盖winnt\system32下的java.exe和 javaw.exe。但是,Oralce安装程序会修改系统PATH变量,将自带的JRE的bin路径加入其中,且置于最前面。随着Oracle安装版本的不同,其自带JRE的JVM启动程序也不同。在笔者机器上安装的Oracle 8.1.7,其JRE就装在C:\Program Files\Oracle下,并将C:\Program Files\Oracle\jre\1.1.7\bin放在PATH变量最前,其JVM启动程序是jre.exe而非java.exe。

以上就是Java2 SDK在Windows下安装时所做的动作,这样会带来兼容性问题:

问题背景:安装Java2 SDK后,安装了JBuilder6,未修改任何PATH变量

问题1
当在操作系统中安装了JDK 1.2,其后安装了JBuilder6(自带JDK 1.3.1),这时CurrentVersion为1.3,在命令行执行java -version时,提示:

Registry key 'Software\JavaSoft\Java Runtime Environment\CurrentVersion'
has value '1.3', but '1.2' is required.

解决方法:将JDK 1.2中java.exe所在路径加入到操作系统PATH的首位,从而保证在命令行调用java时总是执行JDK 1.2中的java.exe,以使得java.exe可正确定位JRE和jvm.dll。

问题2
当在操作系统中安装了JDK 1.3.0,而后安装了JBuilder6(自带JDK 1.3.1),这时CurrentVersion为1.3,但是此1.3是指向的是JBuilder6自带的JDK 1.3.1的JRE,而非指向先前JDK 1.3.0的JRE,当在命令行执行java -version时,此时执行的是JDK 1.3.0拷贝到winnt\system32的一个java.exe副本,但打印的版本信息却是:

java version "1.3.1"
Java(TM) 2 Runtime Environment, Standard Edition (build 1.3.1-b24)
Java HotSpot(TM) Client VM (build 1.3.1-b24, mixed mode)

导致该问题的原因是java.exe只维护小数点后1位的版本号,而非2位。

解决方法:同问题1
问题3:
如果在操作系统中先安装了JDK 1.3.0,而后安装了带有与安装JDK主次版本相同的JBuilder6(带JDK 1.3.1,前两位相同),则问题1实际上被隐蔽了,没有发生的机会;而问题2的隐蔽性也很强,不容易发觉,因为人们往往会忽略JDK的第3个版本号。

如问题2所叙,在命令行执行java,虽然是使用JDK 1.3.0的一个java.exe副本(winnt\system32目录下),而实际上却是使用JBuilder6下JDK 1.3.1的JRE及其目录结构,其结果是当我们使用Java2的extension mechanism将jar文件放到JDK 1.3.0的jre\lib\ext目录下时,发现达不到希望的效果 – 在命令行用java启动程序时,不会自动去JDK 1.3.0的jre\lib\ext目录下去搜索jar文件,它只会去JBuilder6下JDK 1.3.1的jre\lib\ext去搜索jar文件,而JBuilder6下的JDK 1.3.1并不存在jre\lib\ext这么一个目录!

问题3极为隐蔽,除非完全对Java2 SDK的安装及class定位机制了解,一般的开发者是难以发现问题所在的。有关Java2中class定位机制,见《Java2中的class定位机制》一文。

事实上,即使仅仅在系统中存在一份JDK 1.3.0,如果在命令行运行java的话,使用的JRE目录是C:\Program Files\JavaSoft\JRE\1.3,也就是说,即使我们在c:\jdk1.3\jre\lib\ext下放置我们的extension jar,也得不到预期的结果。正确的做法是放在C:\Program Files\JavaSoft\JRE\1.3\lib\ext目录下。

解决方法:同问题1
综上所叙,强烈建议将%JDK_HOME%\bin目录放在Windows操作系统的PATH变量的首位,以避免潜在的问题。

而在UNIX下,则完全不存在类似Windows操作系统上的问题。

我们在命令下执行的java是/bin/java

$which java
$/bin/java

而/bin是到/usr/bin的链接,也就是说/bin/java实际上是/usr/bin/java

而/usr/bin/java实际上链接到/usr/java/bin/java,/usr/java是到/usr/java1.2的链接(Solaris 7或更高系统内置JDK 1.2),所以我们实际上执行的java是

/usr/java1.2/bin/java

根据UNIX上的情况,java在运行时实际上总是可以用../jre/lib/sparc/libjava.so和.. /jre/lib/sparc/libjvm.so来找到这2个文件,前者类似于Windows下的java.dll,而后者类似于Windows下的 jvm.dll。所以java也总是可以确定自己JRE的目录。

Windows和UNIX上用到的动态链接库,实际上在 Sun的文档中称为optional package's native code binaries,optional pakage实际上即为extension mechanism classes,详见《Java2中的class定位机制》。

要更改UNIX上java的版本,更改/usr/java的链接是其中一个方法,具体可参见JDK在UNIX上的安装介绍。

补充:

Windows如何定位Plug-in

根据在PATH环境变量中找到的java.exe的版本号,到HKEY_LOCAL_MACHINE\SOFTWARE\JavaSoft\Java Plug-in下寻找对应版本的Java Plug-in,在HKEY_LOCAL_MACHINE\SOFTWARE\JavaSoft\Java Plug-in下可以有多个版本的Plug-in存在。

不依赖HKEY_LOCAL_MACHINE\SOFTWARE\ JavaSoft\Java Development Kit的CurrentVersion值和HKEY_LOCAL_MACHINE\SOFTWARE\JavaSoft\Java Runtime Environment的CurrentVersion值来定位应该使用哪个版本的Java Plug-in。

上面写了一大堆还没来得及看,暂且拷贝过来

只说一下解决方法:

注册表->HKEY_LOCAL_MACHINE->SOFTWARE\JAVASOFT\   子目录下所有的JavaHome键值修改成新装的JDK目录下的JRE绝对路径

Error:could not open'C:\Porogram Files\Java\jrelib\j386\jvm.cfg'相关推荐

  1. 重装jdk后运行java程序出现Error: could not open `C:\Program Files\Java\jre68\lib\amd64\jvm.cfg'的解决办法

    在windows系统中重装JDK时,由于种种原因,可能导致重装JDK后出现Error: could not open `C:\Program Files\Java\jre68\lib\amd64\jv ...

  2. JAVA-IDEA报错:Error:Cannot run program “C:\Program Files\Java\jdk1.8.0_20\bin\java.exe“

    报错信息:你下载的jdk/bin目录下找不到Java.exe文件. 下在链接:   下载链接:Java Downloads | Oracle 百度网盘:链接:https://pan.baidu.com ...

  3. 【已解决】Error: could not open `C:\Program Files\Java\jre1.8.0_121\lib\amd64\jvm.cfg‘

    我的原因: java升级时,会在环境变量的path路径中增加以下两条路径,与我们安装java的路径重合. 解决方法: 删掉环境变量中的这两条语句, 同时找到对应文件,删除即可. C:\ProgramD ...

  4. Error: could not open 'D:\Program Files\Java\jre7\lib\amd64\jvm.cfg'

    重装JDK后,因为没有装在以前的目录,运行java命令后报错,环境变量的设置都没有问题. 解决方法: 删除c:/windows/system32/目录下的java.exe .javaw.exe.jav ...

  5. 如何解决 could not open `E:\java\lib\amd64\jvm.cfg‘

    这里写自定义目录标题 在path环境变量中找到C:\Program Files (x86)\Common Files\Oracle\Java\javapath,找到这个路径中的javapath文件所在 ...

  6. could not open 'D:\Java\lib\amd64\jvm.cfg

    准备把刚入手的电脑上安装JDK,结果配置好环境变量之后,在cmd上准备验证一下,结果发现爆这个错 顿时烦躁了,虽然JDK这东西安装简单,配置简单,但是真出问题了,还是有点忧伤的.百度了各种解决方式,但 ...

  7. could not open C:\Program Files\Java\jdk1.6.0-11\lib\i386\jvm.cfg

    错误 打开eclipse后显示Error: could not open C:\Program Files\Java\jdk1.6.0-11\lib\i386\jvm.cfg 或者在命令窗口 输入ja ...

  8. Error: could not open `C:\Java\jre7\lib\i386\jvm.cfg

    打开eclipse时出现Error: could not open `C:\Program Files\Java\jre7\lib\i586\jvm.cfg') 删除 c:\windows\syste ...

  9. Error: could not open `C:\Java\jdk1.8.0\lib\i386\jvm.cfg解决方法

    打开eclipse后显示Error: could not open C:\Program Files\Java\jdk1.6.0-11\lib\i386\jvm.cfg或者在命令窗口 输入java命令 ...

最新文章

  1. 【SpringMVC】基本概念
  2. SLAM笔记(五)光束平差法(Bundle Adjustment)
  3. 后视镜什么时候看?老司机也不一定知道
  4. 识别User Agent屏蔽一些Web爬虫防采集
  5. esp8266 wifi模组入网案例
  6. 关于props的注意事项!
  7. C++静态全局变量问题
  8. Loopback for Mac(创建虚拟音频设备与音频编辑工具)
  9. SVN分支合并冲突解决
  10. PL(Planet)卫星群遥感数据介绍及应用
  11. 车道线检测数据集介绍
  12. Duplicate问题
  13. 国家高新技术企业认定要求及快速通过的方法
  14. 自动更新Selenium驱动chromedriver
  15. C++笔记 char
  16. 数字电路之组合逻辑电路
  17. 高中数学40分怎么办_高中数学补课能听懂考试40分
  18. 人和人之间的距离有多远
  19. html 颜色为无色,JS设置对象背景为无色或有色
  20. 互联网日报 | 4月27日 星期二 | 美团回应被立案调查;滴滴开通老年人打车400热线;百度App月活跃用户数达5.58亿

热门文章

  1. php程序应用实例,PHP教程.应用实例1_php
  2. php中icon,php中iconv函数的使用方法
  3. SpringBoot监听redis过期key
  4. C++_重载new,delete
  5. vue 拷贝 数组_Vue实现对数组、对象的深拷贝、复制
  6. Python开发基础总结之XML+time+OO
  7. mysql数据库空闲时间设定_关于数据库连接池的最大空闲时间的配置
  8. 为什么在notebook里面还是显示torch_torch.utils.cpp_extension对c++/cuda进行拓展
  9. C语言将数组中的值逆序存放
  10. android+tv+自动切换,Android TV 重写GridView,实现焦点放大效果