基于Java class對(duì)象說(shuō)明、Java 靜態(tài)變量聲明和賦值說(shuō)明(詳解)
先看下JDK中的說(shuō)明:
java.lang.Object
java.lang.Class<T>
Instances of the class Class represent classes and interfaces in a running Java application. An enum is a kind of class and an annotation is a kind of interface. Every array also belongs to a class that is reflected as a Class object that is shared by all arrays with the same element type and number of dimensions. The primitive Java types (boolean, byte, char, short, int, long, float, and double), and the keyword void are also represented as Class objects.
Class has no public constructor. Instead Class objects are constructed automatically by the Java Virtual Machine as classes are loaded and by calls to the defineClass method in the class loader.
The following example uses a Class object to print the class name of an object:
void printClassName(Object obj) {
System.out.println("The class of " + obj +
" is " + obj.getClass().getName());
}
It is also possible to get the Class object for a named type (or for void) using a class literal.
System.out.println("The name of class Foo is: "+Foo.class.getName());
在一個(gè)運(yùn)行著的JAVA應(yīng)用中,類的任何實(shí)例都可以用Class對(duì)象來(lái)指代,Class可以指代所有的類和接口。枚舉屬于類,注解屬于接口,均可以用Class指代。每個(gè)數(shù)組均屬于反射的Class對(duì)象,數(shù)組中的每個(gè)元素和維度也同樣擁有Class對(duì)象。Java基本類型(boolean, byte, char, short, int, long, float, and double)以及關(guān)鍵字void也都可以用Class指代。
Class類不存在構(gòu)造函數(shù),當(dāng)類被加載過(guò)程中由JVM通過(guò)調(diào)用類加載器中的defineClass方法自動(dòng)構(gòu)造。
下面的例子是將一個(gè)對(duì)象通過(guò)Class對(duì)象打印出類名。
void printClassName(Object obj) {
System.out.println("The class of " + obj +
" is " + obj.getClass().getName());
}
通過(guò)class關(guān)鍵字指定類型也是可以得到Class對(duì)象的
System.out.println("The name of class Foo is: "+Foo.class.getName());
上面內(nèi)容總結(jié)下,就是Java中所有的對(duì)象以及基本類型都是可以用Class指代的。接下來(lái)看一個(gè)Demo。
/**
*
* 旨在測(cè)試Class對(duì)象和Instance之間的關(guān)系;
* 旨在測(cè)試靜態(tài)變量的聲明和賦值過(guò)程;
* @author zzy
*
*/
public class ObjClass {
private enum tmpEnum {A, B, C};
public static void main(String[] args){
int[] tmpArray = {1,2,3};
Class classType;
try {
// 通過(guò)類名直接獲取Class對(duì)象,JVM中沒(méi)有加載。
classType = InClass.class;
System.out.println(".class: " + classType);
System.out.println(".class finish.");
// Java加載類
classType = Class.forName("InClass");
System.out.println("Class.forName: " + classType);
System.out.println("Class.forName: finish.");
// 創(chuàng)建實(shí)例
InClass newClassType = new InClass();
classType = newClassType.getClass();
System.out.println("new Object.getClass: " + classType);
System.out.println("new Object.getClass: finish.");
// 數(shù)組對(duì)象
classType = tmpArray.getClass();
System.out.println("Array.getClass:" + classType.getSimpleName());
System.out.println("Array.getClass: finish.");
// 枚舉對(duì)象
classType = tmpEnum.class;
System.out.println("enum.class:" + classType);
System.out.println("enum.class: finish.");
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
class InClass{
// 對(duì)靜態(tài)變量聲明之前賦值
{
staticPara = 10;
}
public static int staticPara;
// 構(gòu)造函數(shù)
public InClass(){
System.out.println("construction...");
}
// 靜態(tài)代碼塊
static {
System.out.println("static function...");
}
// 靜態(tài)變量賦值
{
staticPara = 20;
}
{
System.out.println("normal function, staticPara:" + staticPara);
}
// 靜態(tài)變量賦值
{
staticPara = 30;
}
}
輸出結(jié)果:
.class: class InClass .class finish. static function... Class.forName: class InClass Class.forName: finish. normal function, staticPara:20 construction... new Object.getClass: class InClass new Object.getClass: finish. Array.getClass:int[] Array.getClass: finish. enum.class:class ObjClass$tmpEnum enum.class: finish.
說(shuō)明:
1. .class方式獲取類文件的Class對(duì)象,并不需要加載JVM中。
2. Class.forName的方式JVM會(huì)加載類,同時(shí)會(huì)編譯。 如此,類中的靜態(tài)代碼塊就會(huì)被執(zhí)行。
3. 創(chuàng)建實(shí)例過(guò)程中(已經(jīng)加載至JVM中,也就是說(shuō)編譯過(guò)了),調(diào)用構(gòu)造函數(shù),并執(zhí)行非靜態(tài)代碼塊。
4. 靜態(tài)代碼對(duì)于變量的聲明和賦值順序是沒(méi)有影響的(編譯過(guò)程處理),所以結(jié)果是20。
5. 數(shù)據(jù)對(duì)象和枚舉對(duì)象也是可以被Class對(duì)象指定的。
以上這篇基于Java class對(duì)象說(shuō)明、Java 靜態(tài)變量聲明和賦值說(shuō)明(詳解)就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
淺談spring-boot的單元測(cè)試中,@Before不被執(zhí)行的原因
這篇文章主要介紹了淺談spring-boot的單元測(cè)試中,@Before不被執(zhí)行的原因,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-04-04
如何利用Spring把元素解析成BeanDefinition對(duì)象
這篇文章主要介紹了如何利用Spring把元素解析成BeanDefinition對(duì)象,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-08-08
Spring+Vue整合UEditor富文本實(shí)現(xiàn)圖片附件上傳的方法
這篇文章主要介紹了Spring+Vue整合UEditor富文本實(shí)現(xiàn)圖片附件上傳的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07
ConcurrentHashMap?存儲(chǔ)結(jié)構(gòu)源碼解析
這篇文章主要為大家介紹了ConcurrentHashMap?存儲(chǔ)結(jié)構(gòu)源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-10-10
通過(guò)反射注解批量插入數(shù)據(jù)到DB的實(shí)現(xiàn)方法
今天小編就為大家分享一篇關(guān)于通過(guò)反射注解批量插入數(shù)據(jù)到DB的實(shí)現(xiàn)方法,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2019-03-03

