凡是,我们建设类时会指出谁人类的工具的外观与行为。除非用new建设谁人类的一个工具,不然实际上并未获得任何对象。只有执行了new后,才会正式生成数据存储空间,并可利用相应的要领。
但在两种非凡的景象下,上述要领并不堪用。一种景象是只想用一个存储区域来生存一个特定的数据——无论要建设几多个工具,甚至基础不建设工具。另一种景象是我们需要一个非凡的要领,它没有与这个类的任何工具关联。也就是说,纵然没有建设工具,也需要一个能挪用的要领。为满意这两方面的要求,可利用static(静态)要害字。一旦将什么对象设为static,数据或要领就不会同谁人类的任何工具实例接洽到一起。所以尽量从未建设谁人类的一个工具,仍能挪用一个static要领,或会见一些static数据。而在这之前,对付非static数据和要领,我们必需建设一个工具,并用谁人工具会见数据或要领。这是由于非static数据和要领必需知道它们操纵的详细工具。虽然,在正式利用前,由于static要领不需要建设任何工具,所以它们不行简朴地挪用其他那些成员,同时不引用一个已定名的工具,从而直接会见非static成员或要领(因为非static成员和要领必需同一个特定的工具关联到一起)。
有些面向工具的语言利用了“类数据”和“类要领”这两个术语。它们意味着数据和要领只是为作为一个整体的类而存在的,并不是为谁人类的任何特定工具。有时,您会在其他一些Java书刊里发明这样的称号。
为了将数据成员或要领设为static,只需在界说前置和这个要害字即可。譬喻,下述代码能生成一个static数据成员,并对其初始化:
class StaticTest {
Static int i = 47;
}
此刻,尽量我们建造了两个StaticTest工具,但它们仍然只占据StaticTest.i的一个存储空间。这两个工具都共享同样的i。请考查下述代码:
StaticTest st1 = new StaticTest();
StaticTest st2 = new StaticTest();
此时,无论st1.i照旧st2.i都有同样的值47,因为它们引用的是同样的内存区域。
有两个步伐可引用一个static变量。正如上面展示的那样,可通过一个工具定名它,如st2.i。亦可直接用它的类名引用,而这在非静态成员里是行不通的(最好用这个步伐引用static变量,因为它强调了谁人变量的“静态”本质)。
StaticTest.i++;
个中,++运算符会使变量增值。此时,无论st1.i照旧st2.i的值都是48。
雷同的逻辑也合用于静态要领。既可象对其他任何要领那样通过一个工具引用静态要领,亦可用非凡的语法名目“类名.要领()”加以引用。静态要领的界说是雷同的:
class StaticFun {
static void incr() { StaticTest.i++; }
}
从中可看出,StaticFun的要领incr()使静态数据i增值。通过工具,可用典范的要领挪用incr():
StaticFun sf = new StaticFun();
sf.incr();
可能,由于incr()是一种静态要领,所以可通过它的类直接挪用:
StaticFun.incr();
尽量是“静态”的,但只要应用于一个数据成员,就会明晰改变数据的建设方法(一个类一个成员,以及每个工具一个非静态成员)。若应用于一个要领,就没有那么戏剧化了。对要领来说,static一项重要的用途就是辅佐我们在不必建设工具的前提下挪用谁人要领。正如今后会看到的那样,这一点是至关重要的——出格是在界说措施运行进口要领main()的时候。
和其他任何要领一样,static要领也能建设本身范例的定名工具。所以常常把static要领作为一个“领头羊”利用,用它生成一系列本身范例的“实例”。