卖逼视频免费看片|狼人就干网中文字慕|成人av影院导航|人妻少妇精品无码专区二区妖婧|亚洲丝袜视频玖玖|一区二区免费中文|日本高清无码一区|国产91无码小说|国产黄片子视频91sese日韩|免费高清无码成人网站入口

java中l(wèi)ist的用法 一道java面試題,20億數(shù)字的文本排序,如何取前100?

一道java面試題,20億數(shù)字的文本排序,如何取前100?因?yàn)檫@是一個(gè)Java問題,所以這是典型的TOPK問題。首先取前100個(gè)數(shù)字構(gòu)建一個(gè)最小堆,然后依次從堆的頂部插入剩余的數(shù)字,同時(shí)調(diào)整堆。堆中最

一道java面試題,20億數(shù)字的文本排序,如何取前100?

因?yàn)檫@是一個(gè)Java問題,所以這是典型的TOPK問題。首先取前100個(gè)數(shù)字構(gòu)建一個(gè)最小堆,然后依次從堆的頂部插入剩余的數(shù)字,同時(shí)調(diào)整堆。堆中最后100個(gè)元素就是結(jié)果??臻g復(fù)雜度是k,時(shí)間復(fù)雜度是nlogk

我們知道,在編程中,如果你想讓一個(gè)業(yè)務(wù)重復(fù)執(zhí)行,一般有兩種實(shí)現(xiàn)方法:遞歸和循環(huán)。在實(shí)際的編碼過程中,我們不建議使用遞歸,而是建議使用循環(huán)。為什么?

事實(shí)上,不僅僅是Java,任何編程語言,如果遞歸寫入錯(cuò)誤,都可能導(dǎo)致內(nèi)存溢出

!學(xué)習(xí)過Java的朋友一定或多或少聽說過并理解了堆棧內(nèi)存和堆內(nèi)存。程序運(yùn)行時(shí),計(jì)算機(jī)操作系統(tǒng)會給每個(gè)進(jìn)程分配堆內(nèi)存和堆棧內(nèi)存,分配的堆棧內(nèi)存有一個(gè)上限。一旦超過上限,就會導(dǎo)致內(nèi)存溢出。

為什么遞歸操作容易導(dǎo)致內(nèi)存溢出?主要原因如下:

在遞歸方法中,如果終止遞歸的條件寫得不正確,可能導(dǎo)致無限遞歸,最終導(dǎo)致內(nèi)存溢出;

即使遞歸方法和退出遞歸條件正常,如果遞歸深度太深(遞歸次數(shù)太多),也會導(dǎo)致堆棧內(nèi)存溢出!因?yàn)闂H霔3龅囊?guī)則是先入后出(先入后出),如果遞歸次數(shù)過多,就會導(dǎo)致只入不出棧,最后導(dǎo)致棧內(nèi)存溢出。

將遞歸寫入方式改為循環(huán)寫入方式的優(yōu)點(diǎn)是不會在短時(shí)間內(nèi)出現(xiàn)只進(jìn)不出棧的現(xiàn)象,避免了棧內(nèi)存溢出的現(xiàn)象。

java遞歸改為循環(huán)后為什么不會導(dǎo)致棧內(nèi)存溢出?

實(shí)際上,JVM堆棧是以“堆棧幀”為單位的順序訪問結(jié)構(gòu)。在JVM中,方法調(diào)用將在JVM堆棧上分配(put)和取消(put)相應(yīng)的堆棧幀。當(dāng)方法離開(正常返回或異常)時(shí),撤消堆棧幀(即堆棧外)。

關(guān)于java堆棧的問題,在編譯的時(shí)候入棧的順序是怎么樣的?

方法區(qū)域(非堆):它是所有線程共享的內(nèi)存區(qū)域,用于存儲類信息、常量、靜態(tài)變量、編譯器編譯的代碼以及虛擬機(jī)加載的其他數(shù)據(jù)。Java堆:它是虛擬機(jī)管理的最大內(nèi)存區(qū)域,也是所有線程共享的內(nèi)存區(qū)域。它是在虛擬機(jī)啟動(dòng)時(shí)創(chuàng)建的。這個(gè)內(nèi)存區(qū)域的唯一用途是存儲對象實(shí)例,幾乎所有的對象實(shí)例都分配內(nèi)存。Java堆是垃圾收集器管理的主要領(lǐng)域。Java虛擬機(jī)棧:線程是私有的,其生命周期與線程相同。在執(zhí)行每個(gè)方法時(shí),將同時(shí)創(chuàng)建一個(gè)堆棧幀來存儲局部變量表、操作數(shù)堆棧、動(dòng)態(tài)鏈接和方法出口等信息。每個(gè)方法都會被調(diào)用,直到執(zhí)行完成,這與虛擬機(jī)中從堆棧到堆棧輸出進(jìn)程的堆棧幀相對應(yīng)。