发布日期:2018-03-26
在Java程序运行时遇到的“Could not find or load main class(无法找到或者加载主类)”是什么意思?+ 查看更多
在Java程序运行时遇到的“Could not find or load main class(无法找到或者加载主类)”是什么意思?
+ 查看更多
发布日期:2018-03-10 11:04
分类:JAVA
浏览次数:5925
作为Java开发新手遇到的一个常见问题是,他们的程序无法运行并带有错误提示:Could not find or load main class(无法找到或者加载主类) ...
这句话是什么意思?这个错误是什么原因导致的?如果你遇到这个问题,你是如何解决的?
回答:
Java的语法命令<class-name>
首先,您需要了解使用java(或javaw)命令启动程序的正确方法。
正常的命令格式(1)是这样的:
java [
其中<option>是命令行选项(以“ - ”字符开头),<class-name>是包含包名称的完整类名,<argument>是任意传递到应用程序的命令行参数。
1:有一个名为“executable”的JAR文件的并不使用这种语法,稍后我将在底部对其进行描述。
1:有一个名为“executable”的JAR文件的并不使用这种语法,稍后我将在底部对其进行描述。
包含包名称的完整类名通常写成你在Java源代码中,你可以以使用这种方式:
packagename2.packagename2.packagename3.ClassName但是,某些版本的java命令允许你使用斜杠而不是句号,需要修改成:
packagename / packagename2 / packagename3 / ClassName
令人困惑的是这看起来像一个文件路径名,但其实这并不是。你要注意的是fully qualified classname(包含包名称的完整类名)其实是一个标准的Java术语...当然,我刚刚并没有要混淆你的意思:-)
这里是一个java命令格式的示例:
java -Xmx100m com.acme.example.ListUsers fred joe bert
上面的这个命令是将导致java执行以下操作:
1.搜索com.acme.example.ListUsers类的编译版本。
2.加载类。
3.检查类中的一个main方法签名,并返回public static void main(String [])的类型和修饰符。 (注意,方法参数的名称不是Java签名的一部分。)
4.将命令行参数(“fred”,“joe”,“bert”)作为String []传递以调用该方法
2.加载类。
3.检查类中的一个main方法签名,并返回public static void main(String [])的类型和修饰符。 (注意,方法参数的名称不是Java签名的一部分。)
4.将命令行参数(“fred”,“joe”,“bert”)作为String []传递以调用该方法
Java找不到类的原因
当你收到提示“Could not find or load main class ...”并不意味你的代码出现了错误。 java命令无法找到该类事实上有可能的是,消息中的“...”便是java正在寻找的完全限定类名。
那么为什么可能找不到类呢?一般来说有两个主要原因:
第一个可能出现这个问题的原因是你可能提供了错误的类名。 (或者您使用了正确的类名,却使用了错误的格式。)考虑上面的问题,我列了一些错误的指定类名的方法与正确的方法进行对比:
示例#1 – 假设有一个简单的类名:
java ListUser当在包(如:com.acme.example)中声明该类时,你必须在java命令中使用包含包名称的完整类名,例如:
java com.acme.example.ListUser示例#2 – 使用文件名或路径名,而不是类名:
java ListUser.class java com / acme / example / ListUser.class示例#3 -不正确的类名:
java com.acme.example.listuser示例#4 - 错字
java com.acme.example.mistuser
第二个可能出现这个问题的原因是类名是正确的,但是java命令找不到类。那么意味着你需要理解“类路径”的概念。你可以在Oracle文档中找到需要的内容:
- The java command documentation(java命令文档)
- Setting the Classpath.(设置类路径)
- The Java Tutorial - PATH and CLASSPATH (Java教程 - PATH和CLASSPATH)
如果你正确的指定了类名,接下来要检查的是你是否正确的指定了类路径:
1.阅读上面链接的三个文件。(没错,你需要阅读它们。一个Java程序员至少要理解Java类路径机制的工作原理,这是十分重要的一件事)
2.查看命令行和(或)运行java命令时有效的CLASSPATH环境变量。检查目录名和JAR文件名是否正确。
3.如果在类路径中存在相对路径名,请检查它们是否正确地从你运行java命令时有效的目录中进行解析。
4.检查类(在错误提示中提到的那个类)是否位于有效的类路径上。
2.查看命令行和(或)运行java命令时有效的CLASSPATH环境变量。检查目录名和JAR文件名是否正确。
3.如果在类路径中存在相对路径名,请检查它们是否正确地从你运行java命令时有效的目录中进行解析。
4.检查类(在错误提示中提到的那个类)是否位于有效的类路径上。
接下来是我想要补充的内容:
1.当你把一个目录放在类路径上时,它就相当于限定名字空间的根。通过将包含包名称的完整类名映射到路径名,类就会位于该根的目录结构中。因此,例如,如果“/ usr / local / acme / classes”在类路径上,那么当JVM查找一个名为com.acme.example.Foon的类时,它将查找一个“.class”文件路径名:
/usr/local/acme/classes/com/acme/example/Foon.class如果你在类路径上放了“/ usr / local / acme / classes / com / acme / example”,那么JVM便无法找到类。
2.类路径需要包括应用程序所依赖的所有其他(非系统)类。 (系统类是自动定位的,一般来说你不需要关心这一点。)
java -jar <jar file>语法
用于“executable”JAR文件的语法如下:
java [
例如:
java -Xmx100m -jar /usr/local/acme-example/listuser.jar fred
在这种情况下,类(即com.acme.example.ListUser)的名称和类路径在JAR文件的MANIFEST中指定。
IDEs
典型的Java IDE支持在IDE JVM本身或在子JVM中运行Java应用程序。一般来说可样可以避免你发生的这种错误,因为IDE使用它自己的机制来构造运行类路径,识别主类并创建java命令行。
但是,如果你打断了IDE的处理进程,仍然可能发生这种异常。例如,如果你以前在Eclipse中为Java应用程序设置了一个应用程序启动器,然后将包含“main”类的JAR文件移动到文件系统中的另一个位置,而不告诉Eclipse,Eclipse将无意中启动JVM中不正确的类路径。
总之,如果你在IDE中遇到这个问题,你可以进行一些检查,比如版本较老的IDE的状态,被破坏的项目引用或者是被破坏的启动程序配置。
其他参考文献
Oracle Java教程- Common Problems (and Their Solutions)(常见问题(及其解决方案))
Java文档:
Java文档:
- The Java Command - 'java' and 'javaw'(Java命令 - “java”和“javaw”)
- The Classpath(类路径)