java下static关键字用法详解

静态的, 那么首先, 我们先来看一下static可以修饰什么:

从以下测试可以看出, static 可以修饰:

1. 语句块

2. 成员变量(但是不能修饰局部变量)

3. 方法

4. 接口(内部接口)

5. 类(只能修饰在类中的类, 即静态内部类)

6. jdk 1.5 中新增的静态导入

那么static 修饰的表示什么呢? 当创建一个类时, 就是在创建一个新类型,描述这个类的对象的外观和行为,除非用new创建出那个类的对象, 数据存储空间才被分配, 其方法才供外界调用.

那么当声明一个事物为static时,就意味着这个域或者方法不会与包含它的那个类的任何对象关联在一起, 也就是说, 它不依赖类特定的实例, 被类的所有实例共享, 只要这个类被加载,  Java虚拟机就能根据类名在运行时数据区的方法区内定找到他们. 因此, static对象可以在它的任何对象创建之前访问, 无需引用任何对象…

1. static 修饰语句块:

static{}  可以有多处, 执行顺序按照他们的声明顺序.  当JVM加载这个类的时候, 就会执行此语句块, 并且只执行一次.

2. static 变量:

static的变量, 可以被类的对象共享, 并且它只有一份存储空间,JVM只为静态分配一次内存,在加载类的过程中完成静态变量的内存分配  那么在引用static变量的时候, 使用类名.变量名是首选的方式,  因为他不仅强调它是static结构, 而且在某些情况下会为编译器进行优化提供更好的机会.

使用类名直接引用static变量是我们力荐的,这样就很明确的告诉大家该变量或属性是static结构的或是static修饰的。
但是我想说一个更重要的知识点。static 在类中当变量的重要使用方法,首先楼主先运行一下下面代码试试:

 代码如下 复制代码
public class Person {
 static int[] arr=new int[3];
 public static void main(String[] args){
  Person per1=new Person();
  Person per2=new Person();
  Person per3=new Person();
  System.out.println("----改变之前-----");
  System.out.print("per1-->");
  per1.show();
  System.out.print("per2-->");
  per2.show();
  System.out.print("per3-->");
  per3.show();
  //现在我改变它的值
  Person.arr[2]=10;//这种方法是建议的
  per1.arr[0]=1;//一般不用这种方法
  System.out.println("----改变之后-----");
  System.out.print("per1-->");
  per1.show();
  System.out.print("per2-->");
  per2.show();
  System.out.print("per3-->");
  per3.show();
  
 }
 //为了方便,封装一个方法,来解释
 public  void show(){
  for(int i=0;i<arr.length;i++){
   System.out.print(arr[i] + "t");
  }
  System.out.println("");
 }
}

如果是不加static的arr[]我们应该很好理解吧。就是per1如果改变的话不会影响到per2的值。

 

   类似的形式同样应用在使用static修饰的方法上面(称为静态方法)。它可以像普通方法一样使用对象来引用,也可以通过特殊的语法形式来调用如:“类名”+“ . ”+“方法”,();   定义静态方法的方式与定义静态变量一样:

 

  

 代码如下 复制代码

public class StaticTest2 {

 

      static void method(){ ("这是静态方法"); }

 

   }

 

   普通的调用方法:StaticTest2 st = new StaticTest2();   ();

 

   因为method是static修饰的(静态方法),所以可以这样调用:();

 

3. static方法:

static的方法与非static的方法的区别在于: 可以用类名直接访问.在static方法内部, 不能引用非static的变量或者方法,但是你可以通过传递参数的方式传递一个引用,让这个引用去调用非静态数据

4. static 接口:

内部接口(inner interface)本身就默认是static,所以static关键词加与不加都是一样的, 如此例中的接口:TestInInterface , TestInClass 实现此接口, 以下语句

 代码如下 复制代码
StaticDescription.TestInInterface a = new StaticDescription.TestInClass();  
a.print();

我们去掉static关键字也是一样的, 但还是受访问权限控制TestInterface和FF。

5. static 修饰类:(后部分会详细说明)

表示他是一个静态内部类, 他在引用外部类的事物时, 必须也是static的                而且, 静态内部类在创建自己的对象时, 是不需要外围类的存在. 就好像下面的部分:

实例

 代码如下 复制代码

class Member {

 static int classVar = 0; //类变量

 int instanceVar;  //实例变量

 Member(int instanceVar) {

 this.instanceVar = instanceVar;

 }

 static void setClassVar(int i) {

  classVar=i;

  instanceVar=i;    // 类方法不能访问实例变量,只能访问类变量

 }

 static int getClassVar() //类方法
 { return classVar; }

 void setInstanceVar(int i){

  classVar=i;     //实例方法不但可以访问类变量,也可以实例变量

     instanceVar=i;

 }

 int getInstanceVar( )
 { return instanceVar; }

    Member未实例化:                                                                                                              Member实例化之后:

对于非静态数据成员,每个类对象都有自己的拷贝。而静态数据成员被当作是类的成员。无论这个类的对象被定义了多少个,静态数据成员在程序中也只有一份拷贝,由该类型的所有对象共享访问。也就是说,静态数据成员是该类的所有对象所共有的。对该类的多个对象来说,静态数据成员只分配一次内存,供所有对象共用。所以,静态数据成员的值对每个对象都是一样的,它的值可以更新;

 代码如下 复制代码

Member m1 = new Member();

Member m2 = new Member();

内存分配

引用static变量有两种方法。如前例所示,可以通过一个对象去定位它,如m1.classVar;

也可以通过其类名直接引用,如Member.classVar,而对于非静态成员则不行。

尽管当static作用于某个字段市,肯定会改变数据的创建方式(因为一个static字段对每个类来说都只有一份存储空间,而非static字段则是对每个对象都有一个存储空间),但是如果static用于某个方法,差别却没有那么大。static方法的一个重要用法就是在不创建任何对象的前提下就可以调用它。这一点,对定义main()方法很重要,这个方法是运行一个应用时的入口点。

static方法就是没有this的方法。在static方法的内部不能调用非静态方法,反过来倒是可以的。而且可以在没有创建任何对象的前提下,仅仅通过类本身来调用static方法。这实际上正是static方法的主要用途。它很像全局方法。Java中禁止使用全局方法,但你在类中置入static方法就可以访问其他static方法和static域。

和其他任何方法一样,static方法可以创建或使用与其类型相同的被命名对象,因此,static方法通常拿来做“牧羊人”的角色,负责看护与其奴隶同一类型的实例群。

不过,要是在代码中出现大量的static方法,就该重新考虑自己的设计了

 

 

时间: 2024-09-29 03:40:52

java下static关键字用法详解的相关文章

Java 中 synchronized的用法详解(四种用法)_java

Java语言的关键字,当它用来修饰一个方法或者一个代码块的时候,能够保证在同一时刻最多只有一个线程执行该段代码.  1.方法声明时使用,放在范围操作符(public等)之后,返回类型声明(void等)之前.这时,线程获得的是成员锁,即一次只能有一个线程进入该方法,其他线程要想在此时调用该方法,只能排队等候,当前线程(就是在synchronized方法内部的线程)执行完该方法后,别的线程才能进入. 例如: public synchronized void synMethod() { //方法体 }

浅析java 的 static 关键字用法_java

本篇浅析java中static的用法,主要五个方面:静态成员变量,静态方法,静态块,静态内部类,静态导包. 首先还是一张表格说一下静态对象和非静态对象的区别: 静态对象 非静态对象 归属 类共同具有 类的各个实例独立拥有 内存分配 内存空间上固定的 附属类分配 分配空间顺序 优先分配静态对象空间 优先分配静态对象空间,初始化也一样 1 静态变量,静态方法,静态块 静态对象,静态方法都是在原对象和方法上加上static关键字修饰,表示类可以直接调用这些,而不需要实例化后再调用.具有的好处是: 1-

java之static关键字用法实例解析_java

本文实例讲述了java中static关键字用法,分享给大家供大家参考.具体分析如下: 一.介绍: 1.在类中,用static声明的成员变量为静态成员变量,它为该类的公用变量,在第一次使用时被初始化,对于该类的所有对象来说,static成员变量只有一份. 2.用static声明的方法为静态方法,在调用该方法时,不会将对象的引用传递给它,所以在static方法中不可访问非static成员.(静态方法不再是针对于某个对象调用,所以不能访问非静态成员) 3.可以通过对象引用或类名(不需要实例化)访问静态

Java 中Map 的用法详解_java

Map简介 将键映射到值的对象.一个映射不能包含重复的键:每个键最多只能映射到一个值.此接口取代 Dictionary 类,后者完全是一个抽象类,而不是一个接口. Map 接口提供三种collection 视图,允许以键集.值集或键-值映射关系集的形式查看某个映射的内容.映射顺序 定义为迭代器在映射的 collection 视图上返回其元素的顺序.某些映射实现可明确保证其顺序,如 TreeMap 类:另一些映射实现则不保证顺序,如HashMap 类. 注:将可变对象用作映射键时必须格外小心.当对

Delphi常用关键字用法详解_Delphi

本文详细介绍了Delphi中常用的各个关键字名称及用法,供大家在编程过程中借鉴参考之用.详情如下: absolute: //它使得你能够创建一个新变量, 并且该变量的起始地址与另一个变量相同. var Str: string[32]; StrLen: Byte absoluteStr; //这个声明指定了变量StrLen起始地址与Str相同. //由于字符串的第0个位置保存了字符串的长度, 所以StrLen的值即字符串长度. begin Str := 'abc'; Edit1.Text := I

Java中Timer的用法详解_jquery

现在项目中用到需要定时去检查文件是否更新的功能.timer正好用于此处. 用法很简单,new一个timer,然后写一个timertask的子类即可. 代码如下: package comz.autoupdatefile; import java.util.Timer; import java.util.TimerTask; public class M { public static void main(String[] args) { // TODO todo.generated by zoer

c#中static的用法详解

C# static的全部用法收集整理 static的全部用法 要理解static,就必须要先理解另一个与之相对的关键字,很多人可能都还不知道有这个关键字,那就是auto,其实我们通常声明的不用static修饰的变量,都是auto的,因为它是默认的,就象short和long总是默认为int一样:我们通常声明一个变量: int a; string s; 其实就是: auto int a; auto string s; 而static变量的声明是: static int a; static strin

Java下使用Oracle存储过程(详解)第1/3页_JSP编程

任何转载,请尊重版权.(作者:iihero on csdn) 一.如何创建java存储过程? 通常有三种方法来创建java存储过程. 1. 使用oracle的sql语句来创建: e.g. 使用create or replace and compile java source named "<name>" as 后边跟上java源程序.要求类的方法必须是public static的,才能用于存储过程. 复制代码 代码如下: SQL> create or replace

linux系统下pwd命令用法详解

  Linux中用 pwd 命令来查看"当前工作目录"的完整路径. 简单得说,每当你在终端进行操作时,你都会有一个当前工作目录. 在不太确定当前位置时,就会使用pwd来判定当前目录在文件系统内的确切位置. 1.命令格式: pwd [选项] 2.命令功能: 查看"当前工作目录"的完整路径 3.常用参数: 一般情况下不带任何参数 如果目录是链接时: 格式:pwd -P 显示出实际路径,而非使用连接(link)路径. 4.常用实例: 实例1:用 pwd 命令查看默认工作目