`

静态域 和 静态方法

阅读更多
1.静态域
如果将域定义为static,每个类只有一个这样的域。而每一个对象对于所有的实例域都有自己的一份拷贝。
例如,假定需要给每一个记雇员赋予惟一的标识
码。这里给Employee类添加一个实例域id和一个静态域nextId:
class Employee{
private int id;
private static int nextId = 1;
}

现在,每一个雇员对象都有一个自己的id域,但这个类的所有实例将共享一个nextId域。

换句话说,如果有1000个Employee对象,则有1000个实例域id。
但是,只有一个静态nextId。即使没有一个雇员对象,静态域nextId也是存在的。

它属于类,而不属于任何独立的对象.

2.静态常量
静态常量使用的地方比较少,但静态常量却使用得比较多,例如,在Math类中定义了一个静态常量:
public class Math{

public static final double PI = 3.14159265358979323846;

}

在程序中,可以采用Math.PI的形式获得这个常量.
如果关键字static被省略,PI就变成了Math类的一个实例域。需要通过Math类的对象访问PI,

并且每一个Math对象都有它自己的一份PI拷贝。
另一个多次使用的静态常量是System.out。它在System类中声明:
public class System{
public static final PrintStream out = ...;
}

前面曾经提到过,由于每个类对象都可以对公有域进行修改,所以,最好不要将域设计为public。然而,

公有常量(即final域)却没有问题。因为out被声明为final,所以,不允许再将其他打印流赋给它:
System.out = new PrintStream(...); //Error --out is final

注:如果查看一下System类,就会发现有一个setOut方法,它可以将System.out设置为不同的流。

读者可能会感到奇怪,为什么这个方法可以修改final变量的值。原因在于,setOut方法是一个本地方法,

而不是用Java语言实现的。本地方法可以绕过Java语言的存取控制机制。

这是一种特殊的方法,在自己编写程序时,不应该这样处理。

3.静态方法
静态方法是一种不能向对象实施操作的方法。例如,Math类的pow方法就是一个静态方法。
Math.pow(x,a)计算x的a次幂。在计算时,不使用任何Math对象。换句话说,没有隐式的参数。
可以认为静态方法是没有this参数的方法(在一个非静态的方法中,this参数表示这个方法的隐式参数)。
因为静态方法不能操作对象,所以不能在静态方法中访问实例域。但是,静态方法可以访问自身类中的静态域。
下面是使用这种静态方法的一个示例:
public static int getNextId(){
return nextId;//return static field
}

可以通过类名调用这个方法:
int n = Employee.getNextId();
这个方法可以省略关键字static吗?答案是肯定的。但是,需要通过Employee类的对象的引用调用这个方法.

注:可以使用对象调用静态方法。例如,如果harry是一个Employee类对象,

可以harry.getNextId()代替Employee.getNextId()。不过,这种方式很容易造成混淆,

其原因是getNextId方法计算的结果与harry毫无关系。我们建议使用类名,
而不是使用对象来调用静态的方法.

在下面两种情况使用静态方法:
●一个方法不需要访问对象的状态,其所需参数都是通过显示参数来提供(例如:Math.pow())。
●一个方法只需要访问类的静态域(例如:Employee.getNextId)。

注:Java中的静态域与静态方法在功能上与C++相同。但是,语法书写有点不同。
C++,使用::操作符访问自身作用域外的静态和静态方法,如果Math::PI。在C++中术语“static”有一段不寻常的历史.
I:起初,C引入关键字static是为了表示退出一个块后依然存在的局部变量。在这种情况下,

术语”static“是有意义的:变量一直存在,当再次进入该块仍然存在。
II:随后,static在C中有了第二种含义,表示不能被其他文件访问的全局变量和函数。为了避免引入一个新的关键字,

关键字static被重用了。
III:最后,C++第三次重用了这个关键字,与前面赋予的含义完全不一样,这里将其解释为:

属于类且不属于类对象的变量和函数。这个含义与Java相同

4.Factory方法
静态方法还有一种常用的用途。NumberFormat类使用factory方法产生不同风格的格式对象。
NumberFormat currencyFormatter = NumberFormat.getCurrencyInstance();
NumberFormat percentFormatter = NumberFormat.getPercentInstance();
double x=0.1;
System.out.println(currentcyFormatter.format(x));//prints $0.10
System.out.println(percentFormatter.format(x));//prints 10%

为什么NumberFormat类不利用构造哭完成这些操作呢?这主要有两个原因:
●无法命名构造器。构造器的名字必须与类名相同。但是,这里希望将得到的货币实例和百分比实例采用不同的名字。
●当使用构造器时,无法改变所构造的对象类型。而Factory方法将返回一个DecimalFormat类对象,这里NumberFormat的子类。

5.Main方法
需要注意,不需要使用对象调用静态方法。例如,不需要构造Math类对象就可以调用Math.pow。
同理,main方法也是一个静态方法.
public class Application{
//construct objects here
}

main方法不对任何对象进行操作。事实上,在启动程序时还没有任何一个对象。

静态的main方法将执行并创建程序需要的对象.

提示:每一个类可以有一个main方法。这是一个常用于对类进行单元测试的技巧。

6.静态导入
一般写法:
public class Test {
public static void main(String[] args) {
  System.out.println("可以省略静态类名直接调用方法");
  System.out.println(Math.pow(2, 4));
}
}

静态导入:
import static java.lang.System.*;
import static java.lang.Math.*;

public class Test {

public static void main(String[] args) {
  out.println("可以省略静态类名直接调用方法");
  out.println(pow(2, 4));
}
}

总结:
静态域:域定义为static,那么每个类只有一个这样的域(每一个对象对于所有的实例域都有自己的一份拷贝),
并且它属于类,而不属于任何一个实例对象
静态方法:静态方法是一种不能向对象实施操作的方法


本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/wenjjing2lianee/archive/2010/02/01/5276345.aspx
分享到:
评论

相关推荐

    java的静态域实例域

    在Java编程中,类的域...总之,理解和熟练运用Java的静态域和实例域以及它们与构造方法的关系是Java程序员的基本技能。通过合理的设计和使用,可以有效地组织和管理类的状态,为代码的健壮性和可维护性打下坚实基础。

    java类中静态域、块,非静态域、块,构造函数的初始化顺序

    6. **主函数执行**:在 `main` 方法中,首先打印了静态域 `s_a` 和 `s_b` 的初始值,然后创建了一个 `TestStaticBlock` 对象,并打印了其属性的最终值。 通过这个示例,我们可以清楚地看到 Java 类中静态域、块,非...

    静态(static)方法重写(override)

    - **作用域限制**:静态方法只能访问静态变量和调用其他静态方法。 2. **静态方法的隐藏** - **隐藏而非重写**:当子类中声明了一个与父类中相同的静态方法时,实际上是在子类中定义了一个新的方法,这个新方法会...

    JDK新特性之静态导入

    从JDK5.0之后,import语句不仅可以导入类,还增加了导入静态方法和静态域的功能。例如,如果在源文件的顶部,添加一条指令:  Java代码  import java.lang.System.*;  那么就可以使用System类的静态方法和...

    java对象和类

    1面向对象程序设计概述 2类和对象 4静态域和静态方法 5方法参数 6对象构造 7包

    基于Java中对域和静态方法的访问不具有多态性(实例讲解)

    Java 中的多态性是通过方法重写和方法重载来实现的。方法重写是指子类提供了与父类相同的方法签名,但具有不同的实现。方法重载是指多个方法具有相同的方法名,但具有不同的参数列表。 然而,对域和静态方法的访问...

    Java成员变量局部变量静态变量成员方法全局方法等概念的区

    在Java编程语言中,了解和区分不同类型的变量和方法是至关重要的...合理地使用静态和非静态成员,可以帮助优化内存使用,同时保持代码的整洁和高效。在实际编程中,需要根据需求和性能考虑来选择合适的变量和方法类型。

    第5天static静态关键字和单例模式.pptx

    #### 四、静态属性和方法的内存结构 1. **对象属性**: - 存储在堆内存中与每个对象实例相关联。 - 每个对象实例有一份自己的拷贝。 2. **类属性**: - 存储在方法区的静态域中。 - 所有对象共享同一份拷贝。 ...

    linux下,添加静态路由的方法.zip

    "杠16"和"24"通常代表CIDR(无类别域间路由)记法中的网络掩码位数。在IPv4中,如"16"表示/16的网络前缀,对应255.255.0.0的子网掩码,适合大型网络;"24"则表示/24的网络前缀,对应255.255.255.0的子网掩码,适用...

    C#基础知识 静态

    首先,静态类(Static Class)是不能被实例化的,它们只能包含静态成员,如静态方法和静态字段。创建静态类的主要目的是为了提供全局唯一的共享资源或服务,例如`System.Math`类提供了各种数学计算函数。静态类在...

    不确定条件下提高静态电压稳定性的优化方法

    以最小化静态电压失稳概率为优化目标,基于概率空间中静态电压稳定域边界及其关于控制变量的灵敏度,提出了不确定条件下提高电力系统静态电压稳定性的优化方法。为求得静态电压稳定域边界的显式逼近表达式及其灵敏度,...

    局部静态变量有效域的验证

    c++例程:对局部静态变量有效域进行验证

    C++类中的静态成员变量和静态成员函数的作用

    在C++编程语言中,类是面向对象编程的基础,它允许程序员定义包含数据成员(变量)和成员函数(方法)的复合数据类型。其中,静态成员变量和静态成员函数具有特殊的特性,它们在类的整个生命周期内共享单一实例,...

    .NET :静态类的理解

    这种设计使得静态类成为存储类级别数据和方法的理想选择,这些数据和方法不依赖于特定的对象实例。它们在程序加载时由 .NET Framework 的公共语言运行库(CLR)自动加载,因此它们的生命周期与应用程序域的生命周期...

    php面向对象中static静态属性和静态方法的调用

    静态属性和方法提供了一种在不依赖实例化对象的情况下,存储和处理数据以及执行类级别的操作的方法。然而,应谨慎使用,因为过度依赖静态成员可能导致代码难以测试和维护。在适当的时候使用它们,可以提高代码的灵活...

    静态链表和动态链表详细讲解教程

    静态链表和动态链表详细讲解教程 本资源讲解了链表的基本概念和实现方式,着重介绍了静态链表和动态链表的区别和应用场景。链表是一种常见的数据结构,它由多个节点组成,每个节点都包含一个数据域和一个指向下一个...

    C#中静态变量的使用

    C# 中静态变量的使用是指在 C# 语言中使用静态变量的方法和技术。本文将详细介绍静态变量与非静态变量的区别、静态变量的使用方式、静态构造函数的使用等方面的知识点。 一、静态变量与非静态变量的区别 静态变量...

    C++静态成员函数与静态成员变量小结

    1. 静态数据成员的定义:静态数据成员主要用在各个对象都有相同的某项属性的时候,静态数据成员实际上是类域中的全局变量。因此,静态数据成员的定义(初始化)不应被放在头文件中。 2. 静态数据成员被类的所有对象...

    C语言中静态和全局的区别

    其中,全局变量和静态变量是两种常见的存储类型,它们在内存的存储位置、初始化和作用域方面存在一些区别。 首先,我们来了解一下C程序的内存布局。一个典型的C程序可以被划分为几个不同的部分,包括正文段、初始化...

Global site tag (gtag.js) - Google Analytics