这个要从java的内存机制去分析,首先当你New一个对象的时候,并不是先在堆中为对象开辟内存空间,而是先将类中的静态方法(带有static修饰的静态函数)的代码加载到一个叫做方法区的地方,然后再在堆内存中创建对象。所以说静态方法会随着类的加载而被加载。当你new一个对象时,该对象存在于堆内存中,this关键字一般指该对象,但是如果没有new对象,而是通过类名调用该类的静态方法也可以。
程序最终都是在内存中执行,变量只有在内存中占有一席之地时才会被访问,类的静态成员(静态和方法)属于类本身,在类加载的时候就会分配内存,可以通过类名直接去访问,非静态成员(变量和方法)属于类的对象,所以只有在类的对象禅师(创建实例)的时候才会分配内存,然后通过类的对象去访问。
在一个类的静态成员中去访问非静态成员之所以会出错是因为在类的非静态成员不存在的时候静态成员就已经存在了,访问一个内存中不存在的东西当然会出错。
假如静态方法可以访问非静态方法:首先静态方法是你在new一个对象的时候首先将静态方法随着class文件一起,被放入到堆中的方法区。然后才会在堆中创建一个对象。也就是说静态方法已经存在类,非静态方法还没有,如果你静态方法调用的非静态方法一直没有被创建,那么就会报错。。。。。jvm肯定不会冒这个风险,让你调用一个可能不存在的方法,所以就索性在你调用的时候就报错。。。。避免以后不必要的麻烦。