1.什么是静态方法
所谓静态方法,就是方法前面加上static关键字,调用静态方法时一般用类名.方法名,当然也可以用对象名、方法名;
一般Java中工具类里面的工具方法都用static修饰,作为静态方法;
比如:String类里面的将字符串类型变成整形的方法:int b=Integer.parseInt(s),可以将字符串类型的s变成整型b;
如用一段代码来表示一下:
public class Test {
void fun(){
System.out.println("这是一个普通方法");
}
static void fun1(){
System.out.println("这是一个静态方法");
}
public static void main(String[] args) {
Test test=new Test();
//调用普通方法
test.fun();
//调用静态方法
Test.fun1();
//调用静态方法
test.fun1();
}
}
2.那么静态方法的作用是什么呢?
准确来说就是静态方法,系统会为静态方法分配一个固定的内存空间。而普通方法,会随着对象的调用而加载,当使用完毕,会自动释放掉空间。普通方法的好处是,动态规划了内存空间的使用,节省内存资源。静态方法,方便,运行快,而如果全部方法都用静态方法,那么每个方法都要有一个固定的空间,这样的话太占内存。
因而也就解释了,为什么静态方法可以直接被类名调用,而不需要用对象调用, 因为他有固定空间,随类的加载而加载。
静态方法不需要对象,它在你定义对向前就有了,因此就可以方便地直接类名调用。不需要实例化对象。
用代码来说就是:
public class Test {
static private int i;
int j;
public static void main(String[] args) {
// TODO Auto-generated method stub
Test.f(); //类名调用静态方法
Test jj = new Test();
jj.ff();
}
public static void f()
{
System.out.println("正确 类名调用静态方法");
//System.out.println(j+""); //报错 静态方法调用非静态变量j
}
public void ff()
{
System.out.println(i+" 正确 对象调用静态变量i");
}
}
所以静态方法可以通过类名直接调用,而不需要实例化类的对象。这样一些工具类里声明静态方法,用起来就比较方便。