package com.lhb.rc;
public class DateTest {
public static void main(String[] args) throws Exception{
System.out.println("test");
}
}
"C:\Program Files\Java\jdk1.8.0_221\bin\java.exe" "-javaagent:D:\IEDINS\jetbains2021\jetbrains2021Ins\IntelliJ IDEA 2021.1.3\lib\idea_rt.jar=57033:D:\IEDINS\jetbains2021\jetbrains2021Ins\IntelliJ IDEA 2021.1.3\bin" -Dfile.encoding=UTF-8 -classpath "C:\Program Files\Java\jdk1.8.0_221\jre\lib\charsets.jar;C:\Program Files\Java\jdk1.8.0_221\jre\lib\deploy.jar;C:\Program Files\Java\jdk1.8.0_221\jre\lib\ext\access-bridge-64.jar;C:\Program Files\Java\jdk1.8.0_221\jre\lib\ext\cldrdata.jar;C:\Program Files\Java\jdk1.8.0_221\jre\lib\ext\dnsns.jar;C:\Program Files\Java\jdk1.8.0_221\jre\lib\ext\jaccess.jar;C:\Program Files\Java\jdk1.8.0_221\jre\lib\ext\jfxrt.jar;C:\Program Files\Java\jdk1.8.0_221\jre\lib\ext\localedata.jar;C:\Program Files\Java\jdk1.8.0_221\jre\lib\ext\nashorn.jar;C:\Program Files\Java\jdk1.8.0_221\jre\lib\ext\sunec.jar;C:\Program Files\Java\jdk1.8.0_221\jre\lib\ext\sunjce_provider.jar;C:\Program Files\Java\jdk1.8.0_221\jre\lib\ext\sunmscapi.jar;C:\Program Files\Java\jdk1.8.0_221\jre\lib\ext\sunpkcs11.jar;C:\Program Files\Java\jdk1.8.0_221\jre\lib\ext\zipfs.jar;C:\Program Files\Java\jdk1.8.0_221\jre\lib\javaws.jar;C:\Program Files\Java\jdk1.8.0_221\jre\lib\jce.jar;C:\Program Files\Java\jdk1.8.0_221\jre\lib\jfr.jar;C:\Program Files\Java\jdk1.8.0_221\jre\lib\jfxswt.jar;C:\Program Files\Java\jdk1.8.0_221\jre\lib\jsse.jar;C:\Program Files\Java\jdk1.8.0_221\jre\lib\management-agent.jar;C:\Program Files\Java\jdk1.8.0_221\jre\lib\plugin.jar;C:\Program Files\Java\jdk1.8.0_221\jre\lib\resources.jar;C:\Program Files\Java\jdk1.8.0_221\jre\lib\rt.jar;D:\2022\myMavenApp\target\classes" com.lhb.rc.DateTest
"C:\Program Files\Java\jdk1.8.0_221\bin\java.exe" -classpath "D:\2022\myMavenApp\target\classes" com.lhb.rc.DateTest
我们发现,执行这个命令也会正确输出结果。
- 我们本项目的classes目录如下,该目录会作为一个classpath
这个命令带了一个-classpath参数,告诉JVM将-classpath参数后的路径作为类路径,而这个路径就是我们maven项目编译输出后的classes目录。而且,除了这个目录,我们上一条命令带的其他的jar包也算作了classpath,也就是说,classpath是有很多个。我们解压C:\Program Files\Java\jdk1.8.0_221\jre\lib\rt.jar看一下
也就是说,rt.jar下的根目录,也会作为一个classpath。
验证一下多个classpath
- 然后将这个项目打包发布到本地仓库,并在myBoot项目中引入该依赖
<dependencies>
<dependency>
<groupId>com.lhb.tc</groupId>
<artifactId>fastDate</artifactId>
<version>1.0</version>
</dependency>
</dependencies>
- 然后我们尝试用类加载器去获取一下这个FastDate
package com.lhb.rc;
public class DateTest {
public static void main(String[] args) throws Exception{
System.out.println("test");
System.out.println(DateTest.class.getClassLoader().loadClass("com.lhb.rc.utils.FastDate").newInstance());
}
}
打印成功。
为什么当前项目也能使用类加载器加载其他包的类?是因为在执行java.exe 命令时也将fastdate这个jar包作为了classpath一部分。而Classloader默认就是从classpath下寻找类的。
测试加载classpath下的资源
- 再myboot项目resource下新建一个user.properties
- 尝试使用classloader加载该资源
package com.lhb.rc;
import com.lhb.rc.utils.FastDate;
import java.io.InputStream;
import java.util.Properties;
public class DateTest {
public static void main(String[] args) throws Exception{
System.out.println("test");
System.out.println(DateTest.class.getClassLoader().loadClass("com.lhb.rc.utils.FastDate").newInstance());
InputStream resourceAsStream = DateTest.class.getClassLoader().getResourceAsStream("user.properties");
Properties properties = new Properties();
properties.load(resourceAsStream);
System.out.println(properties.getProperty("user"));
System.out.println(properties.getProperty("age"));
}
}
控制台输出也没问题。
- 此时,我们在fastdate项目下新建一个userbk.properties文件,然后重新发布项目
- 然后我们此时尝试读取classpath下userbk.properties,注意这个文件是在fastdate包下的哦。
package com.lhb.rc;
import com.lhb.rc.utils.FastDate;
import java.io.InputStream;
import java.util.Properties;
public class DateTest {
public static void main(String[] args) throws Exception{
System.out.println("test");
System.out.println(DateTest.class.getClassLoader().loadClass("com.lhb.rc.utils.FastDate").newInstance());
InputStream resourceAsStream = DateTest.class.getClassLoader().getResourceAsStream("userbk.properties");
Properties properties = new Properties();
properties.load(resourceAsStream);
System.out.println(properties.getProperty("user"));
System.out.println(properties.getProperty("age"));
}
}
我们发现确实也能读取到其他classpath下的文件。 当多个classpath有相同的文件名会怎么样?
- 将myboot项目的user.properties改名为userbk.properties
那么此时,多个classpath下相同的文件了,我门看看java读取的是哪一个。
我们发现,是读取的myboot项目下的userbk.properties
我们查看完成的java命令,发现是myboot项目的classpath在前,fastdate项目的classpath在后。
将这两个路径换一下再执行
我们发现,如果将fastdate包的classpath指定在前,那么该classpath下的userbk.properties。这个与先后加载的顺序有关。
|