第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

如何從字節(jié)中獲取位的子集?

如何從字節(jié)中獲取位的子集?

Go
UYOU 2021-08-16 20:14:52
我有一個(gè)字節(jié) 0x38b:= 0x38 fmt.Printf("%b\n",b)二進(jìn)制是 00111000。我怎樣才能得到這個(gè)的一個(gè)子集作為一個(gè)新的int?例如,我想要位 7,6,5,在這種情況下將是 int(1)?;蛭?3,2,1 將是 int(4)
查看完整描述

2 回答

?
鳳凰求蠱

TA貢獻(xiàn)1825條經(jīng)驗(yàn) 獲得超4個(gè)贊

一種更通用的方法可以讓您選擇無序位,如下所示:


// subset has to go from lowest to highest

func bits(b uint, subset ...uint) (r uint) {

? ? i := uint(0)

? ? for _, v := range subset {

? ? ? ? if b&(1<<v) > 0 {

? ? ? ? ? ? r = r | 1<<uint(i)

? ? ? ? }

? ? ? ? i++

? ? }

? ? return

}


func main() {

? ? fmt.Println(bits(0x38, 5, 6, 7), "x", 0x38>>5)

? ? fmt.Println(bits(0x38, 2, 4, 5))

? ? fmt.Println(bits(0x38, 1, 2, 3), "x", (0x38>>1)&7)

}


查看完整回答
反對(duì) 回復(fù) 2021-08-16
?
富國滬深

TA貢獻(xiàn)1790條經(jīng)驗(yàn) 獲得超9個(gè)贊

要獲得高位,您可以將值向右移動(dòng)

bits765 := b >> 5

要獲得中間的位,您可以移動(dòng)它們?nèi)缓笃帘尾恍枰奈唬?/p>

bits321 := (b >> 1) & 7


查看完整回答
反對(duì) 回復(fù) 2021-08-16
  • 2 回答
  • 0 關(guān)注
  • 209 瀏覽

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)