今天涉及到一个表需要加字段来关联另一张表的需求,考虑到项目已经上线,这个表又跟很多表联系,就想到了使用静态代码块去new一个Map来存放关联的字段,当然这是少量数据的表,大表的话还得考虑创建字典表了。
public static Map<String,Integer> map = new HashMap<>(); { map.put("V19",226); map.put("V18",227); map.put("V20",228); map.put("V09",209); }
首先,肯定不能写个非静态的,不然每次调用这个接口都要去new一个map,这肯定是不现实的,一般new的对象都放到堆里面,这又是一个频繁调用的接口,所以考虑到使用单例或者静态代码块。
既然用到了,就在复习一下,之前的笔记都还在
首先,静态代码块是随着jvm加载类时候执行的,并且只执行一次,这就是我这次需求考虑到的一点。
然后就是大家都熟悉的面试题,静态代码块的实行顺序:
静态代码块——>非静态代码块——>构造函数
故意写反一下测试一下:
class StaticTest { { System.out.println("父类非静态代码块执行了!!!!"); } public StaticTest(){ System.out.println("父类构造函数执行了!!!!"); } static { System.out.println("父类静态代码块执行了!!!!"); } public static void main(String[] args) { StaticTest one = new StaticTest(); } }
结果:
看到这里已经很明显了,首先!!再次提一下,静态代码块是加载类时候就执行的,跟new不new没关系!!
class StaticTest { { System.out.println("父类非静态代码块执行了!!!!"); } public StaticTest(){ System.out.println("父类构造函数执行了!!!!"); } static { System.out.println("父类静态代码块执行了!!!!"); } } class StaticTestSon extends StaticTest{ { System.out.println("子类非静态代码块执行了!!!!"); } public StaticTestSon(){ System.out.println("子类构造函数执行了!!!!"); } static { System.out.println("子类静态代码块执行了!!!!"); } public static void main(String[] args) { } }
结果:
然后就是大家了解的,new子类时候,会先调用父类的构造方法,但是因为非静态代码块执行顺序大于构造方法,所以执行顺序就是 下面的结果
class StaticTest { { System.out.println("父类非静态代码块执行了!!!!"); } public StaticTest(){ System.out.println("父类构造函数执行了!!!!"); } static { System.out.println("父类静态代码块执行了!!!!"); } } class StaticTestSon extends StaticTest{ { System.out.println("子类非静态代码块执行了!!!!"); } public StaticTestSon(){ System.out.println("子类构造函数执行了!!!!"); } static { System.out.println("子类静态代码块执行了!!!!"); } public static void main(String[] args) { StaticTestSon staticTestSon1 = new StaticTestSon(); StaticTestSon staticTestSon2 = new StaticTestSon(); } }
结果: