導航:首頁 > 編程語言 > java循環中創建對象

java循環中創建對象

發布時間:2023-04-06 03:00:04

① 在java中關於循環實例化類的對象問題

1,循環中創建了三個槐嫌握對象,開辟了三個內存空間,每次a都會鉛慶指向一個新內存地址!2,這肯定是不行的,對象名對都一樣!不符合Java規范者襲,不能通過編譯!

② java 在循環內new對象跟外面new 有什麼區別

首先,在循環內部new的每次執行的都是一個新的對象,而外面的不會變化,依然是同一個對象;
其次,循環內部的對象作用有效范圍就是在循環體內部,不能超出去,循環外面的就不一樣,范圍更大一些。

③ java在一個for循環中創建對象不會重復嗎

你好,這個你不用擔心,沒創建一個對象,都會在對內存中開辟一塊新的空間,他們都是獨立的,所以不會的,而且u出了沒for一次,前一個u的作用域就消失了。

④ java中為什麼不能在循環條件中創建String對象

每循環一次就要創建一個對象,就要給新創建的對象分配空間。
每次創建悉搏一個對象都會占跡毀用一定內存空間的。
所以姿陸備一般在循環外創建一次即可。

⑤ java創建對象有哪幾種方式

Java中創建對象的四種方法 收藏Java中創建對象的四種方式
1.用new語句創建對版象,這是最常見的創建對象的方權法。
2.運用反射手段,調用java.lang.Class或者java.lang.reflect.Constructor類的newInstance()實例方法。
3.調用對象的clone()方法。
4.運用反序列化手段,調用java.io.ObjectInputStream對象的 readObject()方法。
第一種最常見

⑥ Java創建對象的幾種方法

⑦ java面向對象如何創建對象

java作為互聯網編程中使用范圍最廣泛的編程語言之一,我們有許多的知識是需要掌握學習的,今天java課程培訓機構就給大家分析講解一下java面向對象的編程方法有哪些。



常用的創建對象的模式有以下幾種:


一斗轎.工廠模式


工廠模式抽象了具體對象的過程,用函數來封裝以特ing介面創建對象的細節。


如下:


functioncreateAnimal(name,age){


varo=newObject();


o.name=name;


o.age=age;


o.sayName=function(){


alert(this.name);


}


returno;


}


varcat=createAnimal("cat",12);


vardog=createAnimal("dog",3);


工廠模式雖然解決了創建多個相似兌現過的問題,但是卻沒有解決對象識別的問題。


二.構造函數模式


構造函數模式可以創建特定空瞎肆類型的對象。


functionAnimal(name,age){


this.name=name;


this.age=age;


this.sayName=function(){


alert(this.name);


}


}


varcat=newAnimal("cat",12);


vardog=newAnimal("dog",3);


可以使用對象的constructor屬性或instanceof操作符來標識對象類型。


cat.constructor==Animal//true


catinstanceofAnimal//true


三.原型模式


每個函數都有一個prototype(原型)屬性。神歷這個屬性是一個指針,指向一個對象,而這個對象的用途是包含可以由特定類型的所有實例共享的屬性和方法。


使用原型對象的好處是,可以讓所有對象實例共享它所包含的屬性和方法。


functionAnimal(){}


Animal.prototype.name="animal";


Animal.prototype.age=1;


Animal.prototype.sayName=function(){


alert(this.name);


}


vartest1=newAnimal();


test1.sayName();//"animal"


vartest2=newAnimal();


test2.sayName();//"animal"


alert(test1.sayName===test2.sayName);//true


或者:


functionAnimal(){}


Animal.prototype={


constructor:Animal,


name:"animal",


age:1,


sayName:function(){


alert(this.name);


}


};


原型中所有屬性是被很多實例共享的,通過在實例上添加一個同名屬性,可以隱藏原型中的對應屬性。但是,對於包含引用類型值的屬性來說,問題就比較明顯了。


⑧ Java循環創建多個對象後導致內存溢出!

在解決java內存溢出問題之前,需要對jvm(java虛擬機)的內存管理有一定的認識。jvm管理的內存大致包括三種不同類型的內存區域:Permanent Generation space(永久保存區域)、Heap space(堆區域)、Java Stacks(Java棧)。其中永久保存區域主要存放Class(類)和Meta的信息,Class第一次被Load的時候被放入PermGen space區域,Class需要存儲的內容主要包括方法和靜態屬性。堆區域用來存放Class的實例(即對象),對象需要存儲的內容主要是非靜態屬性。每次用new創建一個對象實例後,對象實例存儲在堆區域中,這部分空間也被jvm的垃圾回收機制管理。而Java棧跟大多數編程語言包括匯編語言的棧功能相似,主要基本類型變數以及方法的輸入輸出參數。Java程序的每個線程中都有一個獨立的堆棧。容易發生內存溢出問題的內存空間包括:Permanent Generation space和Heap space。
第一種OutOfMemoryError: PermGen space
發生這種問題的原意是程序中使用了大量的jar或class,使java虛擬機裝載類的空間不夠,與Permanent Generation space有關。解決這類問題有以下兩種辦法:
增加java虛擬機中的XX:PermSize和XX:MaxPermSize參數的大小,其中XX:PermSize是初始永久保存區域大小,XX:MaxPermSize是最大永久保存區域大小。如針對tomcat6.0,在catalina.sh 或catalina.bat文件中一系列環境變數名說明結束處(大約在70行左右) 增加一行: JAVA_OPTS=" -XX:PermSize=64M -XX:MaxPermSize=128m" 如果是windows伺服器還可以在系統環境變數中設置。感覺用tomcat發布sprint+struts+hibernate架構的程序時很容易發生這種內存溢出錯誤。使用上述方法,我成功解決了部署ssh項目的tomcat伺服器經常宕機的問題。
清理應用程序中web-inf/lib下的jar,如果tomcat部署了多個應用,很多應用都使用了相同的jar,可以將共同的jar移到tomcat共同的lib下,減少類的重復載入。這種方法是網上部分人推薦的,我沒試過,但感覺減少不了太大的空間,最靠譜的還是第一種方法。
第二種OutOfMemoryError: Java heap space
發生這種問題的原因是java虛擬機創建的對象太多,在進行垃圾回收之間,虛擬機分配的到堆內存空間已經用滿了,與Heap space有關。解決這類問題有兩種思路:
檢查程序,看是否有死循環或不必要地重復創建大量對象。找到原因後,修改程序和演算法。 我以前寫一個使用K-Means文本聚類演算法對幾萬條文本記錄(每條記錄的特徵向量大約10來個)進行文本聚類時,由於程序細節上有問題,就導致了Java heap space的內存溢出問題,後來通過修改程序得到了解決。
增加Java虛擬機中Xms(初始堆大小)和Xmx(最大堆大小)參數的大小。如:set JAVA_OPTS= -Xms256m -Xmx1024m
第三種OutOfMemoryError:unable to create new native thread
在java應用中,有時候會出現這樣的錯誤:OutOfMemoryError: unable to create new native thread.這種怪事是因為JVM已經被系統分配了大量的內存(比如1.5G),並且它至少要佔用可用內存的一半。有人發現,在線程個數很多的情況下,你分配給JVM的內存越多,那麼,上述錯誤發生的可能性就越大。
那麼是什麼原因造成這種問題呢?
每一個32位的進程最多可以使用2G的可用內存,因為另外2G被操作系統保留。這里假設使用1.5G給JVM,那麼還餘下500M可用內存。這500M內存中的一部分必須用於系統dll的載入,那麼真正剩下的也許只有400M,現在關鍵的地方出現了:當你使用Java創建一個線程,在JVM的內存里也會創建一個Thread對象,但是同時也會在操作系統里創建一個真正的物理線程(參考JVM規范),操作系統會在餘下的400兆內存里創建這個物理線程,而不是在JVM的1500M的內存堆里創建。在jdk1.4里頭,默認的棧大小是256KB,但是在jdk1.5里頭,默認的棧大小為1M每線程,因此,在餘下400M的可用內存里邊我們最多也只能創建400個可用線程。
這樣結論就出來了,要想創建更多的線程,你必須減少分配給JVM的最大內存。還有一種做法是讓JVM宿主在你的JNI代碼里邊。
給出一個有關能夠創建線程的最大個數的估算公式:
(MaxProcessMemory - JVMMemory - ReservedOsMemory) / (ThreadStackSize) = Number of threads

對於jdk1.5而言,假設操作系統保留120M內存:
1.5GB JVM: (2GB-1.5Gb-120MB)/(1MB) = ~380 threads
1.0GB JVM: (2GB-1.0Gb-120MB)/(1MB) = ~880 threads

對於棧大小為256KB的jdk1.4而言,
1.5GB allocated to JVM: ~1520 threads
1.0GB allocated to JVM: ~3520 threads

對於這個異常我們首先需要判斷下,發生內存溢出時進程中到底都有什麼樣的線程,這些線程是否是應該存在的,是否可以通過優化來降低線程數; 另外一方面默認情況下java為每個線程分配的棧內存大小是1M,通常情況下,這1M的棧內存空間是足足夠用了,因為在通常在棧上存放的只是基礎類型的數據或者對象的引用,這些東西都不會占據太大的內存, 我們可以通過調整jvm參數,降低為每個線程分配的棧內存大小來解決問題,例如在jvm參數中添加-Xss128k將線程棧內存大小設置為128k。

⑨ java想循環創建對象的問題。

剛開始學java的時候,我也有這樣的想法,一般不這樣做
你可以用個數組 User[] users
或者用List<User> users
這樣就可以

⑩ java創建對象時會不會一直創建對象

非常好的問題,我專門測試了一下,會報出一個錯誤: Exception in thread "main" javalangStackOverflowError 堆棧溢出,說明這是一個死循環,內對象在被一直不停容的創建。java創建對象時會不會一直創建對象?

閱讀全文

與java循環中創建對象相關的資料

熱點內容
maya粒子表達式教程 瀏覽:84
抖音小視頻如何掛app 瀏覽:283
cad怎麼設置替補文件 瀏覽:790
win10啟動文件是空的 瀏覽:397
jk網站有哪些 瀏覽:134
學編程和3d哪個更好 瀏覽:932
win10移動硬碟文件無法打開 瀏覽:385
文件名是亂碼還刪不掉 瀏覽:643
蘋果鍵盤怎麼打開任務管理器 瀏覽:437
手機桌面文件名字大全 瀏覽:334
tplink默認無線密碼是多少 瀏覽:33
ipaddgm文件 瀏覽:99
lua語言編程用哪個平台 瀏覽:272
政采雲如何導出pdf投標文件 瀏覽:529
php獲取postjson數據 瀏覽:551
javatimetask 瀏覽:16
編程的話要什麼證件 瀏覽:94
錢脈通微信多開 瀏覽:878
中學生學編程哪個培訓機構好 瀏覽:852
榮耀路由TV設置文件共享錯誤 瀏覽:525

友情鏈接