redis的setbit這個bit怎麼理解,配合bitcount使用?

時間 2021-05-05 17:31:22

1樓:bthuntergg

舉例下面的第四行

於'1',offset 6 等於'1' 應該是offset 6 等於'0'

2樓:

這個是SETBIT使用方法的簡單說明

在redis中,儲存的字串都是以二級制的進行存在的。

舉例:設定乙個 key-value ,鍵的名字叫「andy」 值為字元'a'

我們知道 'a' 的ASCII碼是 97。轉換為二進位制是:01100001。

offset的學名叫做「偏移」 。二進位制中的每一位就是offset值啦,比如在這裡 offset 0 等於 『0』 ,offset 1等於'1' ,offset2等於'1',offset 7 等於'1' ,沒錯,offset是從左往右計數的,也就是從高位往低位。

我們通過SETBIT 命令將 andy中的 'a' 變成 'b' 應該怎麼變呢?

也就是將 01100001 變成 01100010 (b的ASCII碼是98),這個很簡單啦,也就是將'a'中的offset 6從0變成1,將offset 7 從1變成0 。

大家可能也發現了,每次SETBIT完畢之後,有乙個(integer) 0或者(integer)1的返回值,這個是在你進行SETBIT 之前,該offset位的位元值。

這個時候,我們再get andy 一下,看看結果:

果然,就從'a' 變成 'b'了。

這就是redis 中 「SETBIT」 的基本用法。

BITCOUNT 就是統計字串的二級製碼中,有多少個'1'。 所以在這裡,

BITCOUNT andy 得到的結果就是 3 啦。以上。

3樓:梁巨集昊

$str

="www "

;for($i

=0;$i

($str

);$i++)

echo

($bin);#

echo

array_sum

(str_split

($bin,1

));#61

每乙個字元都用來儲存8個Bit

A 是 B 的前提 A 比 B 重要 這個邏輯成立嗎?

dtclzy 這只是詞語的 多義性 問題 x有中國國籍 x是中中國人 x有中國血統 x是中中國人 這種例子,與其說是 推論 不如說是 定義 在 中,中中國人 的定義不超出 中國國籍 在 中,中中國人 的定義不超出 中國血統 所以 A是B的基礎 前提 A比B重要 是完全可以的但是要注意,此處 重要 的...

SSDB 和 Redis 的優缺點各有哪些?

Baristas 看了看ssdb儲存引擎的原理,發現ssdb還是比較適合讀取少寫入多的場景的,底層用的levedb儲存引擎,寫入時候第一步記錄到日誌中,就可以保證資料不丟失,也可以算作寫入成功,儲存方式使用LSM樹,以memtab為儲存單位,內部使用skiplist的資料結構,在memtab達到條件...

如何高效深入的閱讀Redis的原始碼?

為啥國內的程式設計師都這麼喜歡這種深入研究底層呀,核心呀,看原始碼這些,國外程式設計師很少這種學習方式,都是上來寫個框架就好了,難道是為了寫給中國程式設計師研究的? 齊小白 redis開發與維護,這本書可以看一下。不是搞c,和linux的,沒必要太深入,會用就行了,再學個lua已經到頭了。你要是寫模...