静态方法java
㈠ java中为什么要有静态方法 和非静态方法之分
站在“面向对象”的角度,static,也就是你说的静态,是为了保持共性,大家伙都用一个,而非静态就是为了保持个性,这个个性需要使用实例来完成。例如
class Dog{
private static String color;
public static String getColor(){
return color;
}
}
这时候,Dog的color就只有共性,都是某种颜色,你想现实中Dog的颜色可能会有多种,要更加符合现实的话,这个修饰color的static最好是去掉,方法也是如此。在java中方法有一个更好的取名——行为,字段也叫——属性。使用静态方法更多的用的是共性,她不需要个性,就像工具类中的对外提供的方法(API)一样都是静态的,而我们的一般类,都是为了保持个性而使用非静态方法的。C语言中的确不需要这么考虑。
㈡ java中的静态方法有什么作用
作用:
静态属于类内存必须配内存空间,空间直由静态占用内存管理器。由于静态没调用,静态存储空间收所都声明静态,占用量内存空间系统变慢普通,象调用内存并直起配内存调用候,才其配存储空间其没调用,存储空间内存管理;其收释放没用空间提高系统运行速率。
㈢ Java中的静态方法有修饰符吗,静态方法属于成员方法吗
在Java中,静态方法是用static修饰的,同时可以选择加上public或protected或private访问修饰符,如果不加也是默认具有包访问性。 静态方法是属于类的静态成员方法,通常是通过类来调用,通过类的实例也可以调用。
如:
class A
{
public static void f()
{
System.out.println("类A的静态方法f");
}
}
则以下方法都可以调用静态方法f:
1、通过类来调用
A.f();
2、通过类A的引用变量来调用
A obj;
obj.f();
㈣ Java中的静态方法是什么
静态方法是在类中使用staitc修饰的方法,在类定义的时候已经被装载和分配。
静态方法为类所有,可以通过对象来使用,也可以通过类来使用。
我们之前一直写的mian方法仔细看看,它就是一个静态方法,静态方法使用如下:
㈤ java中,什么是静态方法
首先静态方法是用static来修饰的
静态方法就是可以不通过生成类的实例直接来调用的
举个简单的例子:
class
A
{
public
static
void
a()
{
System.out.println("A被调用");
}
public
void
b()
{
System.out.println("B被调用");
}
}
假设你要调用方法a和方法b
如果调用方法a可以直接A.a();就可以了
不需要先
A
aa
=
new
A();aa.a();
但是调用b则必须A
aa
=
new
A();aa.b();
还有在继承里面要注意:
如果B继承自A
而且B中和A中都包含相同的函数
如果是实例方法则是被B覆盖掉的
如果是静态方法则是被B隐藏掉的
这一点
在上溯机制中可能遇到
最后还有一点静态方法调用的方法一定也要是静态的
㈥ Java中静态方法与非静态方法的区别
静态方法和实例方法的区别主要体现在两个方面:
在外部调用静态方法时,可以使用"类名.方法名"的方式,也可以使用"对象名.方法名"的方式。而实例方法只有后面这种方式。也就是说,调用静态方法可以无需创建对象。
静态方法在访问本类的成员时,只允许访问静态成员(即静态成员变量和静态方法),而不允许访问实例成员变量和实例方法;实例方法则无此限制。
下面几个例子展示了这一区别。
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()方法是一个典型的静态方法,它同样遵循一般静态方法的规则,所以它可以由系统在创建对象之前就调用。
㈦ java 静态方法可以重载吗重写呢
可以被重载,不可以被重写。
静态方法是类在加载时就被加载到内存中的方法,在整个运行过程中保持不变,因而不能重写。但非静态方法是在对象实例化时才单独申请内存空间,为每一个实例分配独立的运行内存,因而可以重写。
所谓静态就是在运行时,虚拟机已经认定此方法属于哪个类。 专业术语有严格的含义,用语要准确,重写只能适用于实例方法。不能用于静态方法,对于静态方法,只能隐藏,重载,继承。
(7)静态方法java扩展阅读:
如果子类中定义的静态方法(类方法)与父类中静态方法(类方法)具有相同的返回值类型、方法名、方法参数的类型和个数完全相同,则称子类中的该方法“隐藏”了父类中的该方法。当子类创建的对象调用该隐藏方法时,默认调用的是子类中的方法。
方法重写是要注意权限的问题,子类中的权限不能小于父类的权限,当父类的权限为private时,子类无法继承。也就无法产生所谓的重写。(修饰符高低:private < 默认修饰符 < public)
㈧ java中什么是静态方法
若类的方法前加了static关键字,则该方法称为静态方法,反之为实例方法。静态方法为类所有,可以通过对象来使用,也可以通过类来使用。但一般提倡通过类名来使用,因为静态方法只要定义了类,不必建立类的实例就可使用。静态方法只能调用静态变量。
㈨ java里静态方法在什么情况下使用,好处是什
静态方法也称为类的方法,可以在不创建对象的情况下直接调用,
好处就是调用方便,而且其在内存中只有一份,无论多个线程调用该方法,都只有一个,所以间接上来说省了一部分内存开销,但其实也有不好就是类在加载时就为其分配内存空间而且不会回收,也就是这部分内存一直被占有。
㈩ java中静态方法与非静态方法的区别
在外部调用静态方法时,可以使用"类名.方法名"的方式,也可以使用"对象名.方法名"的方式。而实例方法只有后面这种方式。也就是说,调用静态方法可以无需创建对象。
静态方法在访问本类的成员时,只允许访问静态成员(即静态成员变量和静态方法),而不允许访问实例成员变量和实例方法;实例方法则无此限制。