静态方法,系统会为静态方法分配一个固定的内存空间。而普通方法,会随着对象的调用而加载,当使用完毕,会自动释放掉空间。普通方法的好处是,动态规划了内存空间的使用,节省内存资源。静态方法,方便,运行快,而如果全部方法都用静态方法,那么每个方法都要有一个固定的空间,这样的话太占内存。
因而也就解释了,为什么静态方法可以直接被类名调用,而不需要用对象调用, 因为他有固定空间,随类的加载而加载。
静态方法不需要对象,它在你定义对向前就有了,因此就可以方便地直接类名调用。不需要实例化对象。
静态方法的使用范围:
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); //报错 i为jtff私有,B中不能用
}
}?
静态方法可以通过类名直接调用,而不需要实例化类的对象。这样一些工具类里声明静态方法,用起来就比较方便。