更新時間:2021-04-02 來源:黑馬程序員 瀏覽量:
(1)問題分析
考官主要想考察應聘者對Redis數據的理解和拓展,有沒有深入的去理解過數據庫。
(2)核心問題講解
列表對象的編碼可以是ziplist或者linkedlist。
ziplist是一種壓縮鏈表,它的好處是更能節(jié)省內存空間,因為它所存儲的內容都是在連續(xù)的內存區(qū)域當中的。當列表對象元素不大,每個元素也不大的時候,就采用ziplist存儲。但當數據量過大時就ziplist就不是那么好用了。因為為了保證他存儲內容在內存中的連續(xù)性,插入的復雜度是O(N),即每次插入都會重新進行realloc。對象結構中ptr所指向的就是一個ziplist。整個ziplist只需要malloc一次,它們在內存中是一塊連續(xù)的區(qū)域。
linkedlist是一種雙向鏈表。它的結構比較簡單,節(jié)點中存放pre和next兩個指針,還有節(jié)點相關的信息。當每增加一個node的時候,就需要重新malloc一塊內存。
(3)問題擴展
獲取當前同時還會問Redis數據庫有幾種數據類型,然后深入去問比如有沒有深入了解過Redis,說說Redis里面list的底層實現(xiàn),說說set數據類型為何支持去重等等,是一類拓展的問題。
(4)結合項目中使用
說說你做過的項目里哪些地方用到了Redis數據庫。
為什么要在項目中使用Redis數據庫。
猜你喜歡: