- public class Word {
- static{
- System.out.println(“Word Init….”);
- }
- }
- public class Test {
- public static void main(String[] args) {
- try{
- Class cls = Class.forName(“Word”,false,ClassLoader.getSystemClassLoader());
- }catch(Exception e){
- e.printStackTrace();
- }
- }
- }
- public class Test1 {
- public static void main(String[] args) {
- try{
- Class cls = Class.forName(“Word”,true,ClassLoader.getSystemClassLoader());
- }catch(Exception e){
- e.printStackTrace();
- }
- }
- }
Class.forName用法
原创
©著作权归作者所有:来自51CTO博客作者神相的原创作品,如需转载,请与作者联系,否则将追究法律责任
反射机制必定用到Class.forName 这个方法。上周有个同事在分享这块的时候延展的谈到了Class.forName的一些用法。
1、Class.forName(String className);
2、Class.forName(String name,boolean initialize,ClassLoader loader);
通常大家都会认为,某个类中的static初始化区块都是在类加载 的时候就被调用到唯一的一次。真的是这样么?带着这个问题,我们来看看Class.forName这个方法。
Java代码
类Test和Test1运行的结果不一样:
Test:
Test1:Word Init…
为什么会这样?
Class.forName中的第二个参数在发生着作用。
不管用new还是class.forName来产生实例都隐含着两个部分:类加载+静态初始化区块调用;
静态初始化区块是在newInstance()的时候才被真正调用,所以Class.forName的第二个参数“false”的时候,定义不需要调用静态初始化区块,这就是为什么产生如上结果的原因了。
给一些应聘来工程师问这个问题,大家的回答多为静态初始化区块在类加载的时候被调用的。真正的是:静态初始区块并不是类加载的时候就调用,而是在第一次实例化的时候真正被调用 。
下一篇:淘宝一个月
提问和评论都可以,用心的回复会被更多人看到
评论
发布评论
相关文章
-
cocos creator 打开场景错误 [Scene] Missing class
本文给出cocos creator打开github上开源工程遭遇错误时遇到的一种可能问题的解决方案。
cocos creator 打开场景错误 missing class -
Artemis 命令用法
Artemis高级用法
读取文件 shell脚本 批量删除 mq artemis -
关于Class.forName
前言相信大家在使用反射操作时多多少少能用到这个方法。如果你使用了mysql数据库并且使用了原生
class.forname 类加载机制 初始化 sql mysql -
Class.forName详解
Class.forName详解
初始化 加载 类装载器 -
Java: Class.forName
java
java 开发语言 初始化 加载 静态代码块