什么时候用静态变量 静态方法?为什么要使用静态变量 、静态方法?

如题所述

静态方法和实例方法的区别主要体现在两个方面:

在外部调用静态方法时,可以使用"类名.方法名"的方式,也可以使用"对象名.方法名"的方式。而实例方法只有后面这种方式。也就是说,调用静态方法可以无需创建对象。

静态方法在访问本类的成员时,只允许访问静态成员(即静态成员变量和静态方法),而不允许访问实例成员变量和实例方法;实例方法则无此限制。

下面几个例子展示了这一区别。

1、调用静态方法示例。

//-----------文件名hasStaticMethod.java,程序编号1-----------------public class hasStaticMethod{//定义一个静态方法public static void callMe(){System.out.println("This is a static method.");}}

下面这个程序使用两种形式来调用静态方法。
//-----------文件名invokeStaticMethod.java,2-----------------public class invokeStaticMethod{public static void main(String args[]){hasStaticMethod.callMe(); //不创建对象,直接调用静态方法 hasStaticMethod oa = new hasStaticMethod(); //创建一个对象oa.callMe(); //利用对象来调用静态方法}}
程序3.36两次调用静态方法,都是允许的,程序的输出如下:
This is a static method.This is a static method.

允许不创建对象而调用静态方法,是Java为了减少程序员调用某些常用方法时的麻烦,而允许程序员按照传统的C语言中使用函数的方式来使用方法。典型的例子是前面某些程序中使用"Math.ramdon()"来获取随机数。

2、静态方法访问成员变量示例。

//-----------文件名accessMember.java,程序编号3.37-----------------class accessMember{private static int sa; //定义一个静态成员变量private int ia; //定义一个实例成员变量//下面定义一个静态方法static void statMethod(){int i = 0; //正确,可以有自己的局部变量sa = 10; //正确,静态方法可以使用静态变量otherStat(); //正确,可以调用静态方法ia = 20; //错误,不能使用实例变量insMethod(); //错误,不能调用实例方法}static void otherStat(){} //下面定义一个实例方法 void insMethod(){int i = 0; //正确,可以有自己的局部变量sa = 15; //正确,可以使用静态变量ia = 30; //正确,可以使用实例变量statMethod(); //正确,可以调用静态方法}}

本例其实可以概括成一句话:静态方法只能访问静态成员,实例方法可以访问静态和实例成员。之所以不允许静态方法访问实例成员变量,是因为实例成员变量是属于某个对象的,而静态方法在执行时,并不一定存在对象。同样,因为实例方法可以访问实例成员变量,如果允许静态方法调用实例方法,将间接地允许它使用实例成员变量,所以它也不能调用实例方法。基于同样的道理,静态方法中也不能使用关键字this。

main()方法是一个典型的静态方法,它同样遵循一般静态方法的规则,所以它可以由系统在创建对象之前就调用。

静态变量作为一个局部变量是很合适的,它在函数退出后不会失去其本身的值。例如,有一个要被调用很多次的函数,它的一部分功能就是计算自己被调用的次数。你不能用一个简单的局部变量来实现这部分功能,因为每次进入该函数时,这个变量都没有被初始化。如果把这个计数变量说明为静态的,那么它就会象一个全局变量那样保留自己的当前值。
那么为什么不直接使用一个全局变量呢?你可以使用一个全局变量,而且这样做没有错误。问题是使用了大量全局变量的程序维护起来很麻烦,尤其是有许多函数都各自访问一个全局变量的程序。再说一遍,这样做没有错误,这只是一个程序设计和可读性是否好的问题。如果你把这样的变量说明为静态的,你就可以提醒自己(或者其它可能读你的程序的人)它是局部变量,但要象全局变量那样被处理(保留自己的值)。如果你把它说明为全局的,那么读这个程序的人一定会认为有很多地方要引用它,尽管实际上并不是这样。
总而言之,当你需要一个能保持自己的值的局部变量时,使用静态变量是一种好的编程习惯。
静态方法就不再多解释了,道理差不多
温馨提示:答案为网友推荐,仅供参考
第1个回答  2011-06-24
在统计某个类的对象的个数可以使用静态变量,因为理论上讲这个变量不属于任何具体的对象。

class person{
static int count = 0;
......//其他信息
public static int c()
{
count++;
return count;
}
}
在实例化出一个对象后就调用c()将对象总数加一并得到对象的数目本回答被网友采纳
第2个回答  2011-06-14
当我在某项目中需要调用其他项目中某个类的方法时,我可以不用实例化这个类,可直接调用类名访问该方法,这个方法就必须声明为静态方法,通常用做工厂方法。静态变量只能被静态方法调用,静态变量是属于整个类。
第3个回答  2011-06-14
在一个类里声明一个静态方法和静态变量,那么是全局的,而且是类方法和类变量,直接可以用类名称.类方法或变量来使用,很简单。追问

能不能只给我简单的讲下,为什么会有静态类,静态方法?我们是为了什么而引出它 的。。。

追答

呵呵,你看过main方法没有,它本身就是个静态方法。
而且静态方法只能调用静态方法,和静态变量。
如果要调用非静态的方法和变量,那么就需要我们类的一个实例化对象。方法或者变量

那么为什么会要有静态变量,静态方法呢?
一个他们是全局的,那么走到哪里都可以使用。
,而是使用很方便。

本回答被提问者采纳
第4个回答  2011-06-14
静态变量静态方法可以全局使用,可以通过类名.方法名/类名.属性名直接调用追问

能不能只给我简单的讲下,为什么会有静态类,静态方法?我们是为了什么而引出它 的。。。
而不是要您帮我回答,如何使用。

相似回答