我正在查看 Go 語言源代碼,模塊math/rand。我在那里發(fā)現(xiàn)了一條有趣的線if n&(n-1) == 0 { // n is power of two, can mask我只是好奇,什么n&(n-1)意思?我會(huì)明白的n && (n-1)。它將是AND2 個(gè)布爾表達(dá)式之間的運(yùn)算符。我會(huì)明白的&n。它是n變量的地址。但n&(n-1)我無法弄清楚是什么。完整方法代碼:// Int63n returns, as an int64, a non-negative pseudo-random number in [0,n).// It panics if n <= 0.func (r *Rand) Int63n(n int64) int64 { if n <= 0 { panic("invalid argument to Int63n") } if n&(n-1) == 0 { // n is power of two, can mask return r.Int63() & (n - 1) } max := int64((1 << 63) - 1 - (1<<63)%uint64(n)) v := r.Int63() for v > max { v = r.Int63() } return v % n}
兩個(gè)表達(dá)式之間的單個(gè)和號(hào)
寶慕林4294392
2021-10-11 18:51:11