java編程 java的try catch語(yǔ)句在循環(huán)里執(zhí)行,如果拋出異常,還繼續(xù)循環(huán)嗎?謝謝了?
java的try catch語(yǔ)句在循環(huán)里執(zhí)行,如果拋出異常,還繼續(xù)循環(huán)嗎?謝謝了?如果異常的位置在try代碼塊中,那么如果在catch中沒(méi)有主動(dòng)拋出異常,并且catch代碼沒(méi)有異常,則循環(huán)將繼續(xù)。如果
java的try catch語(yǔ)句在循環(huán)里執(zhí)行,如果拋出異常,還繼續(xù)循環(huán)嗎?謝謝了?
如果異常的位置在try代碼塊中,那么如果在catch中沒(méi)有主動(dòng)拋出異常,并且catch代碼沒(méi)有異常,則循環(huán)將繼續(xù)。如果異常發(fā)生在catch代碼塊中,并且程序沒(méi)有嘗試在catch中捕獲異常,則循環(huán)將被中斷??傊?,循環(huán)是否中斷取決于代碼本身是否處理異常。如果程序處理異常并且沒(méi)有將其拋出到JVM,則循環(huán)不會(huì)終止。此外,您應(yīng)該注意catch代碼塊是否也可能有異常。
java遞歸改為循環(huán)后為什么不會(huì)導(dǎo)致棧內(nèi)存溢出?
我們知道,在編程中,如果您希望業(yè)務(wù)被重復(fù)執(zhí)行,通常有兩種方法來(lái)實(shí)現(xiàn)它:遞歸和循環(huán)。在實(shí)際的編碼過(guò)程中,我們不建議使用遞歸,而是建議使用循環(huán)。為什么?
事實(shí)上,不僅僅是Java,任何編程語(yǔ)言,如果遞歸寫入錯(cuò)誤,都可能導(dǎo)致內(nèi)存溢出
!學(xué)習(xí)過(guò)Java的朋友一定或多或少聽說(shuō)過(guò)并理解了堆棧內(nèi)存和堆內(nèi)存。程序運(yùn)行時(shí),計(jì)算機(jī)操作系統(tǒng)會(huì)給每個(gè)進(jìn)程分配堆內(nèi)存和堆棧內(nèi)存,分配的堆棧內(nèi)存有一個(gè)上限。一旦超過(guò)上限,就會(huì)導(dǎo)致內(nèi)存溢出。
為什么遞歸操作容易導(dǎo)致內(nèi)存溢出?主要原因如下:
在遞歸方法中,如果終止遞歸的條件寫得不正確,可能導(dǎo)致無(wú)限遞歸,最終導(dǎo)致內(nèi)存溢出;
即使遞歸方法和退出遞歸條件正常,如果遞歸深度太深(遞歸次數(shù)太多),也會(huì)導(dǎo)致堆棧內(nèi)存溢出!因?yàn)闂H霔3龅囊?guī)則是先入后出(先入后出),如果遞歸次數(shù)過(guò)多,就會(huì)導(dǎo)致只入不出棧,最后導(dǎo)致棧內(nèi)存溢出。
將遞歸寫入方式改為循環(huán)寫入方式的優(yōu)點(diǎn)是不會(huì)在短時(shí)間內(nèi)出現(xiàn)只進(jìn)不出棧的現(xiàn)象,避免了棧內(nèi)存溢出的現(xiàn)象。
java循環(huán)中不改變循環(huán)變量是規(guī)范嗎?
您好,我不知道您的意思是foreach循環(huán)變量的名稱不能更改還是for循環(huán)中集合中的元素不能更改。
如果它是第一個(gè),我認(rèn)為它應(yīng)該被視為一個(gè)語(yǔ)言規(guī)范,特別是在foreach循環(huán)中。實(shí)際上,變量名通常是不變的,因?yàn)槲覀儾粫?huì)對(duì)變量名做太多處理。它實(shí)際上是中間的一個(gè)臨時(shí)變量,類似于我們有一個(gè)數(shù)組,數(shù)組的每個(gè)元素在參與邏輯處理時(shí)都會(huì)先得到,當(dāng)涉及到這個(gè)元素時(shí),比如array[i],我們可以直接用它來(lái)處理業(yè)務(wù)邏輯。但是,由于在foreach循環(huán)中不能以這種方式獲得臨時(shí)變量,因此會(huì)給出一個(gè)臨時(shí)變量,并且每個(gè)循環(huán)的變量名是相同的。
如果是第二個(gè),我認(rèn)為它肯定不是一個(gè)規(guī)范。在很多業(yè)務(wù)中,我們會(huì)修改相應(yīng)的變量,包括更新或刪除。當(dāng)然,我們?cè)谔幚磉@些業(yè)務(wù)時(shí)需要使用迭代器,但是循環(huán)變量肯定可以修改。