Java隨機(jī)生成一個(gè) int的整數(shù)數(shù)據(jù),這個(gè)int轉(zhuǎn)換為二進(jìn)制昵慌,快速獲取有多少個(gè)1

1.首先想到的就是通過(guò)與運(yùn)算獲取

public static int bitCount(long i) {
        // HD, Figure 5-14
        i = i - ((i >>> 1) & 0x5555555555555555L);
        i = (i & 0x3333333333333333L) + ((i >>> 2) & 0x3333333333333333L);
        i = (i + (i >>> 4)) & 0x0f0f0f0f0f0f0f0fL;
        i = i + (i >>> 8);
        i = i + (i >>> 16);
        i = i + (i >>> 32);
        return (int)i & 0x7f;
     }

這個(gè)方法是java提供的一個(gè)計(jì)算的方式假夺。

那么問(wèn)題來(lái)了。這樣計(jì)算是可以的斋攀,也很快已卷。但是我想更快怎么?

2.通過(guò)緩存的方式來(lái)出來(lái)

為了更快的速度淳蔼,那我們可以犧牲一部分存儲(chǔ)空間侧蘸。就是最典型的 空間換時(shí)間
我們可以生成一個(gè)key-value的接口對(duì)應(yīng)起來(lái)

1 ->   1   -> 1
2 ->   10   -> 1
3 ->   11   -> 2
4 ->   100   -> 1
5 ->   101   -> 2
6 ->   110   -> 2
7 ->   111   -> 3
8 ->   1000   -> 1

我們稍微計(jì)算一下啊
int 有4字節(jié),32位范圍
-2147483648—2147483647(2^31-1)
我們只要計(jì)算一下大概有多少
先算正整數(shù)鹉梨。
我們只要計(jì)算一下大概有多少
我們估算位2^32這些數(shù)據(jù)
共占有2^34個(gè)字節(jié)
1個(gè)int 占用2^2個(gè)字節(jié)
1Gb = 2^30 B
大概約等于4G的空間這是key讳癌,要是K-V的方式存放,遠(yuǎn)遠(yuǎn)大于額8G
有沒(méi)有方式優(yōu)化存儲(chǔ)方式存皂?

1.對(duì)數(shù)據(jù)進(jìn)行降維打擊

我們可以吧K-V的方式轉(zhuǎn)換成二維平面晌坤,對(duì)k-v求解向量。我們就得到的了一個(gè)點(diǎn)旦袋。這樣存的數(shù)據(jù)遠(yuǎn)遠(yuǎn)小于4G
骤菠。甚至也就只有1G左右。但是不夠我還想更小疤孕。

2.考慮拆分法

int :4個(gè)字節(jié) 32位
可以拆成 16位 + 16位
拿的key的存放應(yīng)該是2^5MB
那么肯定有小伙伴會(huì)問(wèn)如果我們分成
8位 + 8位 + 8位 + 8位
是不是更小娩怎。
我們?nèi)绾闻袛嗄莻€(gè)一更好?是16位還是8位胰柑?

這就涉及到CPU的寄存器截亦。

最好的方式就是分的位數(shù)和寄存器的位數(shù)一樣大爬泥。這樣速度是最快的。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末崩瓤,一起剝皮案震驚了整個(gè)濱河市袍啡,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌却桶,老刑警劉巖境输,帶你破解...
    沈念sama閱讀 221,548評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異颖系,居然都是意外死亡嗅剖,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,497評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門(mén)嘁扼,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)信粮,“玉大人,你說(shuō)我怎么就攤上這事趁啸∏吭担” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 167,990評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵不傅,是天一觀的道長(zhǎng)旅掂。 經(jīng)常有香客問(wèn)我,道長(zhǎng)访娶,這世上最難降的妖魔是什么商虐? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 59,618評(píng)論 1 296
  • 正文 為了忘掉前任,我火速辦了婚禮崖疤,結(jié)果婚禮上称龙,老公的妹妹穿的比我還像新娘。我一直安慰自己戳晌,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,618評(píng)論 6 397
  • 文/花漫 我一把揭開(kāi)白布痴柔。 她就那樣靜靜地躺著沦偎,像睡著了一般。 火紅的嫁衣襯著肌膚如雪咳蔚。 梳的紋絲不亂的頭發(fā)上豪嚎,一...
    開(kāi)封第一講書(shū)人閱讀 52,246評(píng)論 1 308
  • 那天,我揣著相機(jī)與錄音谈火,去河邊找鬼侈询。 笑死,一個(gè)胖子當(dāng)著我的面吹牛糯耍,可吹牛的內(nèi)容都是我干的扔字。 我是一名探鬼主播囊嘉,決...
    沈念sama閱讀 40,819評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼革为!你這毒婦竟也來(lái)了扭粱?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 39,725評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤震檩,失蹤者是張志新(化名)和其女友劉穎琢蛤,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體抛虏,經(jīng)...
    沈念sama閱讀 46,268評(píng)論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡博其,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,356評(píng)論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了迂猴。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片慕淡。...
    茶點(diǎn)故事閱讀 40,488評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖错忱,靈堂內(nèi)的尸體忽然破棺而出儡率,到底是詐尸還是另有隱情,我是刑警寧澤以清,帶...
    沈念sama閱讀 36,181評(píng)論 5 350
  • 正文 年R本政府宣布儿普,位于F島的核電站,受9級(jí)特大地震影響掷倔,放射性物質(zhì)發(fā)生泄漏眉孩。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,862評(píng)論 3 333
  • 文/蒙蒙 一勒葱、第九天 我趴在偏房一處隱蔽的房頂上張望浪汪。 院中可真熱鬧,春花似錦凛虽、人聲如沸死遭。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,331評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)呀潭。三九已至,卻和暖如春至非,著一層夾襖步出監(jiān)牢的瞬間钠署,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,445評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工荒椭, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留谐鼎,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,897評(píng)論 3 376
  • 正文 我出身青樓趣惠,卻偏偏與公主長(zhǎng)得像狸棍,于是被迫代替她去往敵國(guó)和親身害。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,500評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容