静态方法、变量和类

静态方法的意义和运用问题:http://topic.csdn.net/u/20090528/19/ed87949a-3a44-4a70-aca6-58757035fb51.html

 

7.4. 静态变量,方法和类 
静态变量
Static int data语句说明data为类变量,为一个类的共享变量,属于整个类。
例:
Class M{
static int data;
}
M m1=new M(); M m2=new M();
m1.data=0;
m1.data++的结果为1,此时m2.data的结果也为1。
Static定义的是一块为整个类共有的一块存储区域。
其变量可以通过类名去访问:类名.变量名。与通过对象引用访问变量是等价的。
 

2) 静态方法
Public static void printData(){}
表明此类方法为类方法(静态方法)
静态方法不需要有对象,可以使用类名调用。
静态方法中不允许访问类的非静态成员,包括成员的变量和方法,因为此时是通过类调用的,没有对象的概念。方法中this.data和super.data是不可用的。(我测试过了,的确如此)
原因:从根本来说,是静态变量不管类是否实例化都会存在,而实例变量只有类实例化了才存在。直接调用静态方法时并不确定实例变量是否存在。
静态方法使用起来很方便,所以一般而言如果该类是作为工具类(如Math)该类中的方法可以声明为静态。由于该类在编译时内存中开辟了空间(应该是这样的),所以性能会好些,但如果太多的方法都是static的话,会导致应用程序占用空间过大。


一般情况下,主方法是静态方法,所以JVM可以直接调用它,主方法为静态方法是因为它是整个软件系统的入口,而进入入口时系统中没有任何对象,只能使用类调用。
猜想:JVM在代码中有这样的语句:
ClassName.main(arg); ClassName 通过命令行的”java 类名”取得,所以类名不用加.class 扩展名

*覆盖不适用于静态方法。
静态方法不可被覆盖。
如果子类中有和父类重名的静态方法,虽然编译通过,但它并不能实现多态,所以不能称作覆盖。

public class Test {
  public static void main(String[] arg) {
  Super s = new Sub();
  s.show();
   
  }
}
class Super
{
  static public void show(){System.out.println("in Super");}
}
class Sub extends Super
{
  static public void show(){System.out.println("in Sub");}
}

执行结果是: in Super

3) 静态内部类----只能是成员内部类
class Out{
public static class Inner{}
}
4) 初始化块 
1. 只被执行一次; 
  2. 初始化块在类被加载后首先被运行,不管类是否实例化
3.一般用来初始化静态变量
Public static void main(String[] args){
System.out.println(Car.name);//这时加载Car Class进入JVM并执行静态代//码块 
}

你可能感兴趣的:(java,Math,jvm,String,Class,扩展)