一、引言
说实话,此部分知识是在当初学C#基础的时候学到的,起初就记得有这么回事,后来学Java的时候对于基础跳过去很多,最近项目上遇到了一个问题,最终问题当然解决了,解决后想到了类中各模块加载顺序这个知识点,当结果与理论此时相互印证一番后,对此知识豁然开朗,也更清晰。
二、问题由来
一个类Test交给Spring进行管理,但是此类通过XML的形式进行配置的,在Test类中利用@Autowired注入了使用@Service注解的Call,private Call call,我在Test类的构造函数中使用了call的某个方法,结果报 空指针问题,起初我的想法是通过XML配置的类不能使用使用注解的类,但是后来想想又觉得肯定不会这样啊,2种方式肯定可以共同使用啊,调试后发现原因:构造函数是一个类中除开静态资源部分最先执行的模块。其他非静态模块肯定在他之后进行初始化,所以在构造函数中调用其他非静态资源,肯定会报空指针异常。
三、举例说明
下面是我简化问题后写的一个小demo,以此相互印证:
1. 一个普通的java类Person,Animal类
public class Person { public Person() { System.out.println("初始化了Peron类"); } }
public class Animal { public Animal() { System.out.println("Animao run..."); } }
2. 一个Man类,引用了Person。
public class Man { static { System.out.println("静态方法运行了。。。"); } private Person person = new Person(); private static Animal animal = new Animal(); public Man() { System.out.println("3. Man构造函数运行了。。。"); } }
其中包含:静态方法块(同C#的静态构造函数)、全局变量、构造函数。
3. 调用Man的类
public class MyTest { public static void main(String[] args) { Man man=new Man(); } }
四、结果与结论
想想执行结果会是神马?
思路:
1. 静态的变量因为是全局的,所以肯定是最早进行初始化的,其次才是非静态的。
2. 构造函数优先全局变量。
所以执行后的顺序应该是
1. 静态方法块 2. 静态全局变量 3. 构造函数 4. 非静态全局变量
时间: 2024-10-12 18:45:54