本文目錄一覽:
java新手為什麼java類中要有static靜態方法?
1。靜態方法的特點: 直接調用類名+方法名,不需要實例化類對象。\x0d\x0a如: Hello.P();\x0d\x0a非靜態方法則必須實例化一個對象出來,再通過對象調用該方法如: Hello hello=new Hello(參數1~n); hello.P();\x0d\x0a\x0d\x0a2。程序被打包成.jar文件後(相當於.exe文件),給外界唯一的介面就是main方法。使用者雙擊.jar文件,其實就是讓虛擬機執行main方法。\x0d\x0a\x0d\x0a3。main方法不是提供給程序員的,而是提供給虛擬機和使用客戶的。 一個軟體你沒法讓客戶知道你內部的詳情,當然客戶也就沒辦法知道怎麼去實例化對象,更不知道實例化對象時需要輸入什麼參數了。所以只能採用靜態方法。
java中什麼是靜態方法
若類的方法前加了static關鍵字,則該方法稱為靜態方法,反之為實例方法。靜態方法為類所有,可以通過對象來使用,也可以通過類來使用。但一般提倡通過類名來使用,因為靜態方法只要定義了類,不必建立類的實例就可使用。靜態方法只能調用靜態變數。
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.靜態的方法在整個應用程序其間存儲在內存中,速度快,但佔用內存. \x0d\x0a class A\x0d\x0a {\x0d\x0a public static string b()\x0d\x0a {\x0d\x0a return “Hello”;\x0d\x0a }\x0d\x0a\x0d\x0a } \x0d\x0a\x0d\x0a用法: A.b(); //調用方便 \x0d\x0a靜態方法可以通過類名直接調用,\x0d\x0a2.動態的方法在先聲明類實例才能調用類中的方法. \x0d\x0a\x0d\x0a class A\x0d\x0a {\x0d\x0a public string b()\x0d\x0a {\x0d\x0a return “Hello”;\x0d\x0a }\x0d\x0a } \x0d\x0a用法: A a = new a(); a.b(); \x0d\x0a3.一般使用頻繁的方法用靜態方法,用的少的方法用動態的。靜態的速度快,占內存。動態的速度相對慢些,但調用完後,立即釋放類,可以節省內存,可以根據自己的需要選擇是用動態方法還是靜態方法。\x0d\x0a4.靜態方法主要的問題就是數據同步的問題。如果你的靜態方法的類中不保存私有變數那麼什麼問題都不會有的。最好是包要操作的數據全部以參數的方式傳到方法中去\x0d\x0a5. 靜態方法是類方法,調用時不需要創建類實例。\x0d\x0a6. 靜態方法是靜態綁定到子類,不是被繼承。
java 靜態方法
有時你希望定義一個類成員,使它的使用完全獨立於該類的任何對象。通常情況下,類成員必須通過它的類的對象訪問,但是可以創建這樣一個成員,它能夠被它自己使用,而不必引用特定的實例。在成員的聲明前面加上關鍵字static(靜態的)就能創建這樣的成員。如果一個成員被聲明為static,它就能夠在它的類的任何對象創建之前被訪問,而不必引用任何對象。你可以將方法和變數都聲明為static。static 成員的最常見的例子是main( ) 。因為在程序開始執行時必須調用main() ,所以它被聲明為static。
聲明為static的變數實質上就是全局變數。當聲明一個對象時,並不產生static變數的拷貝,而是該類所有的實例變數共用同一個static變數。聲明為static的方法有以下幾條限制:
·
它們僅能調用其他的static 方法。
·
它們只能訪問static數據。
·
它們不能以任何方式引用this 或super(關鍵字super 與繼承有關,在下一章中描述)。
如果你需要通過計算來初始化你的static變數,你可以聲明一個static塊,Static 塊僅在該類被載入時執行一次。下面的例子顯示的類有一個static方法,一些static變數,以及一個static 初始化塊:
// Demonstrate static variables,methods,and blocks.
class UseStatic {
static int a = 3;
static int b;
static void meth(int x) {
System.out.println(“x = ” + x);
System.out.println(“a = ” + a);
System.out.println(“b = ” + b);
}
static {
System.out.println(“Static block initialized.”);
b = a * 4;
}
public static void main(String args[]) {
meth(42);
}
}
一旦UseStatic 類被裝載,所有的static語句被運行。首先,a被設置為3,接著static 塊執行(列印一條消息),最後,b被初始化為a*4 或12。然後調用main(),main() 調用meth() ,把值42傳遞給x。3個println ( ) 語句引用兩個static變數a和b,以及局部變數x 。
注意:在一個static 方法中引用任何實例變數都是非法的。
下面是該程序的輸出:
Static block initialized.
x = 42
a = 3
b = 12
在定義它們的類的外面,static 方法和變數能獨立於任何對象而被使用。這樣,你只要在類的名字後面加點號運算符即可。例如,如果你希望從類外面調用一個static方法,你可以使用下面通用的格式:
classname.method( )
這裡,classname 是類的名字,在該類中定義static方法。可以看到,這種格式與通過對象引用變數調用非static方法的格式類似。一個static變數可以以同樣的格式來訪問——類名加點號運算符。這就是Java 如何實現全局功能和全局變數的一個控制版本。
下面是一個例子。在main() 中,static方法callme() 和static 變數b在它們的類之外被訪問。
class StaticDemo {
static int a = 42;
static int b = 99;
static void callme() {
System.out.println(“a = ” + a);
}
}
class StaticByName {
public static void main(String args[]) {
StaticDemo.callme();
System.out.println(“b = ” + StaticDemo.b);
}
}
下面是該程序的輸出:
a = 42
b = 99
原創文章,作者:YVEP,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/143520.html