Java中4种代码块:普通代码块,静态代码块,同步代码块,构造代码块

普通代码块:定义:在方法、循环、判断等语句中出现的代码块修饰:只能用标签修饰位置:普通代码块可以出现在方法体内除"()"外的任何地方,包括 方法体,代码块中(即可以嵌套在代码块中)执行:普通代码依赖方法的执行而执行,按照正常的先后顺序执行作用:将多行代码封装在一起,实现特定的功能。(有点废话)注意:无静态代码块 定义:在类中定义使用static修饰的代码块 修饰:使用static修饰 位置:它不能出现在方法体或者代码块内 执行:在加载类时会先执行静态代码块,且只执行一次,如果有多个静态代码块则按照先后顺序执行 作用:一般用于静态变量的初始化,创建对象前的环境的加载 注意:静态代码块中不能直接访问非静态变量和方法,需要通过类的实例对象来访问同步代码块定义:可以简单地认为同步代码块是使用 synchronized 修饰的普通代码块位置:同普通代码块执行:同普通代码块作用:用于多线程环境的同步保护注意:注意同步代码块使用不当可能会造成“死锁”构造代码块定义:在类中定义且没有加任何修饰的代码块位置:它不能出现在方法体或者其他代码块内执行:依赖于构造函数的调用而执行作用:初始化实例变量和实例环境,一般用于提取类构造函数中的公共代码注意:构造代码块不是在构造函数之前执行的!!!编译器在编译的时候会把构造代码块插入到每个构造函数的最前面!! 构造代码块随着构造函数的执行而执行!! 如果某个构造函数调用了其他的构造函数,那么构造代码块不会插入到该构造函数中以免构造代码块执行多次!执行案例:复制代码public class CodeAreaExecuteDemo{

static{

System.out.println("static code block!"); } {

System.out.println("construct code block!"); public CodeAreaExecuteDemo(){

System.out.println("Constructor() "); public static void main(String[] args) {

new CodeAreaExecuteDemo();}

//代码效果参考:http://0791zd.com/bx/art_7823.html

执行结果:static code block!construct code block!Constructor()反编译结果:CodeExecuteDemo.png我们发现构造代码块确实被插入到了构造函数最前面中构造代码块与构造函数关系的案例public class ConstructorDemo{

public ConstructorDemo(){} public ConstructorDemo(int num){

this();}反编译结果如下:ConstructorDemo.png