静态方法,系统会为静态方法分配一个固定的内存空间。而普通方法,会随着对象的调用而加载,当使用完毕,会自动释放掉空间。普通方法的好处是,动态规划了内存空间的使用,节省内存资源。静态方法,方便,运行快,而如果全部方法都用静态方法,那么每个方法都要有一个固定的空间,这样的话太占内存。

 

因而也就解释了,为什么静态方法可以直接被类名调用,而不需要用对象调用, 因为他有固定空间,随类的加载而加载。

 

静态方法不需要对象,它在你定义对向前就有了,因此就可以方便地直接类名调用。不需要实例化对象。

 

静态方法的使用范围:

 

 

package jintaiff;

 

public class jtff {

    static private int i;

 

    int j;

 

    public static void main(String[] args) {

        // TODO Auto-generated method stub

        jtff.f(); // 类名调用静态方法

 

        jtff jj = new jtff();

 

        jj.ff();

    }

 

    public static void f() {

        System.out.println("正确 类名调用静态方法");

 

        // System.out.println(j+""); //报错 静态方法调用非静态变量j

    }

 

    public void ff() {

        System.out.println(i + " 正确 非静态方法调用静态变量i");

    }

}?

 

静态方法可以通过类名调用(当然对象也可以,因为对象比静态方法晚出现,因此对象出现的时候静态方法一定存在),但是依旧受到权限修饰符的限制:

 

?

 

class B {

    public void gg() {

        // System.out.println(jtff.i); //报错 ijtff私有,B中不能用

    }

}?

 

静态方法可以通过类名直接调用,而不需要实例化类的对象。这样一些工具类里声明静态方法,用起来就比较方便。

posted on 2019-06-10 15:54  技术创造奇迹  阅读(322)  评论(0编辑  收藏  举报