public class StaticTest{
      static{
            System.out.println("Hi there");
    }
   public void print(){
          System.out.println("Hello");
      }
    public static void main (String[] args)  {
       StaticTest st1=new StaticTest();
       st1.print();
       StaticTest st2=new StaticTest();
        st2.print();
      }
}
为什么会输出:Hi there 啊
    

解决方案 »

  1.   

    public static void main ,  因为  static 在main前面, 而且 这个静态块先放进去的,所以先执行它呗
      

  2.   

    类 -- 为启动类 ,主动使用此类,类 :加载 -准备(验证、连接、初始化)--初始化就是执行static变量和static代码块 
      

  3.   

    类从加载到虚拟机到卸载,它的整个生命周期包括:加载(Loading),验证(Validation),准备(Preparation),解析 (Resolution),初始化(Initialization),使用(Using)和卸载(Unloading)。其中,验证、准备和解析部分被称 为连接(Linking)。 加载:        在加载阶段,虚拟机主要完成三件事:1.通过一个类的全限定名来获取定义此类的二进制字节流。2.将这个字节流所代表的静态存储结构转化为方法区域的运行时数据结构。3.在Java堆中生成一个代表这个类的java.lang.Class对象,作为方法区域数据的访问入口。验证:        验证阶段作用是保证Class文件的字节流包含的信息符合JVM规范,不会给JVM造成危害。如果验证失败,就会抛出一个java.lang.VerifyError异常或其子类异常。验证过程分为四个阶段:1.文件格式验证:验证字节流文件是否符合Class文件格式的规范,并且能被当前虚拟机正确的处理。2.元数据验证:是对字节码描述的信息进行语义分析,以保证其描述的信息符合Java语言的规范。3.字节码验证:主要是进行数据流和控制流的分析,保证被校验类的方法在运行时不会危害虚拟机。4.符号引用验证:符号引用验证发生在虚拟机将符号引用转化为直接引用的时候,这个转化动作将在解析阶段中发生。准备:        准备阶段为变量分配内存并设置类变量的初始化。在这个阶段分配的仅为类的变量(static修饰的变量),而不包括类的实例变量。对已非final的变量,JVM会将其设置成“零值”,而不是其赋值语句的值:pirvate static int size = 12;        那么在这个阶段,size的值为0,而不是12。 final修饰的类变量将会赋值成真实的值。解析:        解析过程是将常量池内的符号引用替换成直接引用。主要包括四种类型引用的解析。类或接口的解析、字段解析、方法解析、接口方法解析。初始化:        在准备阶段,类变量已经经过一次初始化了,在这个阶段,则是根据程序员通过程序制定的计划去初始化类的变量和其他资源。这些资源有static{}块,构造函数,父类的初始化等。        至于使用和卸载阶段阶段,这里不再过多说明,使用过程就是根据程序定义的行为执行,卸载由GC完成。
    html
      

  4.   

     static{
      System.out.println("Hi there");
      }
    有方法这样写的吗?是不是写的本身有问题?
      

  5.   

    是不是可以这么理解,
    static变量,是在 内存刚加载程序的时候,static就已经被实例化。即:有一段内存是装载 系统代码 用的,没有被任何其他应用实例化过。但是这段没有被实例化的程序,自己就开辟内存,为static变量进行实例化。
    而且这段被实例化的static变量,将不能被其他代码实例化,所以他就是唯一的。唯一存在于装 系统代码 的那段内存当中。能不能这么理解?如果有不对的地方,请指出来!