javanew對象
『壹』 java中如果是在當前類的方法里new當前類的對象,可以直接new嗎解釋下機理,謝謝哦
可以直接new的,當你把這樣的類new出來並調用方法時,實際產生了該類的兩個實例,實例調用另一個實例當然是可以的啊。 但是這樣用要多注意,比如寫成這樣
public class A {
new A().;
public void moon();{}
}
這樣就會報錯了,這里造成了類的遞歸定義,會造成棧溢出。
『貳』 java中用new定義對象有幾種寫法
java中用new定義對象有3種寫法。
1.使用new關鍵字
通過這種方式,我們可以調用任意的構造函數(無參的和帶參數的)。
<span style="color: #ff0000;">Employee emp1 = newEmployee();</span> 0: new#19// class org/programming/mitra/exercises/Employee: p: invokespecial #21// Method org/programming/mitra/exercises/Employee."":()V
2.使用Class類的newInstance方法
我們也可以使用Class類的newInstance方法創建對象。這個newInstance方法調用無參的構造函數創建對象。
我們可以通過下面方式調用newInstance方法創建對象:
<span style="color: #ff0000;">Employee emp2 = (Employee) Class.forName("org.programming.mitra.exercises.Employee").newInstance();</span>
3.使用反序列化
當我們序列化和反序列化一個對象,jvm會給我們創建一個單獨的對象。在反序列化時,jvm創建對象並不會調用任何構造函數。為了反序列化一個對象,我們需要讓我們的類實現Serializable介面 。
<span style="color: #ff0000;">ObjectInputStream in = newObjectInputStream(newFileInputStream("data.obj"));Employee emp5 = (Employee) in.readObject();</span>『叄』 java的方法中new的對象存儲在內存中那個區域
這個對象存在堆中,還是棧中?
答:堆,new一個對象,一定是在堆中
方法內部new出來的對象,在哪裡存著?
答:堆,new出來對象的實例變數都存在堆上面。
棧,這個東西,需要理解為:線程運行時,才會創建,執行完,就沒了。
Person p = new Person();
上面這段代碼,在執行時,p壓入棧,通過局部變數表,找到對應的【實例數據】,執行完畢後釋放。
『肆』 java直接返回一個new對象好還是用變數保存再返回好
首先,第一種比第二種少一步
第一種返回的是已經存在的值,第二種相當於創建一遍再返回
然後,第二種完全沒用
因為第二種是返回一個全新的對象,而如果要對其進行操作的話,操作的結果 根本得不到,所以一般情況下都用第一種,第二種就相當於這個式子: Student student = new Student();
使用這個式子直接new一個對象就行了,而如果要用第二種的話,還得創建一個方法,指定方法的返回類型,然後再返回值,這樣非常麻煩,反正我是沒這么用過
最後,總結
第一種返回的是保存的值,也就是可以將對其操作的結果保存下來,比如一個集合,你添加了一些值,它返回的就是添加後的集合
第二種則是一個全新的值,相當於你有創建了一遍對象,跟原來的完全沒關系
『伍』 Java裡面的實例對象new了是什麼意思
new中文意思是:新的
在JAVA里表示新建實例或者是新建對象。
『陸』 北大青鳥java培訓:創建新對象的兩種方式
隨著互聯網編程開發技術的發展,編程開發語言已經由面向程序發展成為了面向對象的編程。
今天,我們就從兩個方面來了解一下,java編程語言中如何創建新對象的。
java在new一個對象的時候,會先查看對象所屬的類有沒有被載入到內存,如果沒有的話,就會先通過類的全限定名來載入。
載入並初始化類完成後,再進行對象的創建工作。
我們先假設是一次使用該類,這樣的話new一個對象就可以分為兩個過程:載入並初始化類和創建對象。
一、類載入過程(一次使用該類)java是使用雙親委派模型來進行類的載入的,所以在描述類載入過程前,我們先看一下它的工作過程:雙親委託模型的工作過程是:如果一個類載入器(ClassLoader)收到了類載入的請求,它先不會自己去嘗試載入這個類,而是把這個請求委託給父類載入器去完成,每一個層次的類載入器都是如此,因此所有的載入請求終都應該傳送到頂層的啟動類載入器中,只有當父類加搏源載器反饋自己無法完成這個載入請求(它的搜索范圍中沒有找到所需要載入的類)時,子載入器才會嘗試自己去載入。
使用雙親委託機制的基襲態好處是:能夠有效確保一個類的全局性,當程序中出現多個限定名相同的類時,類載入器在執行載入時,始終只會載入其中的某一個類。
1、載入由類載入器負責根據一個類的全限定名來讀取此類的二進制位元組流到JVM內部,並存儲在運行時內存區的方法區,然後將其轉換為一個與目標類型對應的java.lang.Class對象實例2、驗證格式驗證:驗證是否符合class文件規范語義驗證:檢查一個被標記為final的類型是否包含子類;檢查一個類中的final方法是否被子類進行重寫;確保父類和子類之間沒有不兼容的一些方法聲明(比如方法簽名相同,但方法的返回值不同)操作驗證:在操作數棧中的數據必須進行正確的操作,對常量池中的各種符號引用執行驗證(通常在解析階段執行,檢查是否可以通過符號引用中描述的全限定名定位到指定類型上,以及類成員信息的訪問修飾符是否允許訪問等)3、准備為類中的所有靜態變數分配內存空間,並為其設置一個初始值(由於還沒有產生對象,實例變數不在此操作范圍內)被final修飾的static變數(常量),會直接賦值;4、解析將常量池中的符號引用轉為直接引用(得到類或者欄位、方法在禪廳內存中的指針或者偏移量,以便直接調用該方法),這個可以在初始化之後再執行。
解析需要靜態綁定的內容。
//所有不會被重寫的方法和域都會被靜態綁定以上2、3、4三個階段又合稱為鏈接階段,鏈接階段要做的是將載入到JVM中的二進制位元組流的類數據信息合並到JVM的運行時狀態中。
5、初始化(先父後子)4.1為靜態變數賦值4.2執行static代碼塊注意:static代碼塊只有jvm能夠調用如果是多線程需要同時初始化一個類,僅僅只能允許其中一個線程對其執行初始化操作,其餘線程必須等待,只有在活動線程執行完對類的初始化操作之後,才會通知正在等待的其他線程。
因為子類存在對父類的依賴,所以類的載入順序是先載入父類後載入子類,初始化也一樣。
不過,父類初始化時,子類靜態變數的值也有有的,是默認值。
終,方法區會存儲當前類類信息,包括類的靜態變數、類初始化代碼(定義靜態變數時的賦值語句和靜態初始化代碼塊)、實例變數定義、實例初始化代碼(定義實例變數時的賦值語句實例代碼塊和構造方法)和實例方法,還有父類的類信息引用。
二、創建對象1、在堆區分配對象需要的內存分配的內存包括本類和父類的所有實例變數,但不包括任何靜態變數2、對所有實例變數賦默認值將方法區內對實例變數的定義拷貝一份到堆區,然後賦默認值3、執行實例初始化代碼初始化順序是先初始化父類再初始化子類,初始化時先執行實例代碼塊然後是構造方法4、如果有類似於Childc=newChild()形式的c引用的話,在棧區定義Child類型引用變數c,然後將堆區對象的地址賦值給它需要注意的是,福建IT培訓http://www.kmbdqn.cn/發現每個子類對象持有父類對象的引用,可在內部通過super關鍵字來調用父類對象,但在外部不可訪問