<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                ThinkChat2.0新版上線,更智能更精彩,支持會話、畫圖、視頻、閱讀、搜索等,送10W Token,即刻開啟你的AI之旅 廣告
                一,字符串 1.#### String的三種編碼 * int,存儲8個字節的長整型(long,2^63-1) * embstr,embstr格式的SDS(Simple Dynamic String) * raw,SDS,存儲大于44個字節的字符串 2.String的三種編碼轉換 * 當 value 的值為整型時,編碼為 int * 當 value 值為字符時,存儲的編碼為 embstr,連續的內存空間,只需要分配一次 * 當 value 值字符長度超過 44 時,存儲的編碼為 raw,不是連續的內存空間,需要分配兩次 * 如果 value 的值為 int 或者 embstr ,然后通過 append 添加字符的時候,也會轉化為 raw 類型(因為 embstr 設計的是只讀的,如果發生變化只能再開辟一塊空間),而且這個過程是不可逆的。 3.數據結構 ![](https://img.kancloud.cn/f8/ac/f8ac4543c410c7efdc4654de25ce3824_449x188.png) 3.**redis 為什么要自己寫一個SDS的數據類型** ①、常數復雜度獲取字符串長度   由于 len 屬性的存在,我們獲取 SDS 字符串的長度只需要讀取 len 屬性,時間復雜度為 O(1)。而對于 C 語言,獲取字符串的長度通常是經過遍歷計數來實現的,時間復雜度為 O(n)。通過 strlen key 命令可以獲取 key 的字符串長度。   ②、杜絕緩沖區溢出   我們知道在 C 語言中使用 strcat 函數來進行兩個字符串的拼接,一旦沒有分配足夠長度的內存空間,就會造成緩沖區溢出。而對于 SDS 數據類型,在進行字符修改的時候,會首先根據記錄的 len 屬性檢查內存空間是否滿足需求,如果不滿足,會進行相應的空間擴展,然后在進行修改操作,所以不會出現緩沖區溢出。   ③、減少修改字符串的內存重新分配次數   C語言由于不記錄字符串的長度,所以如果要修改字符串,必須要重新分配內存(先釋放再申請),因為如果沒有重新分配,字符串長度增大時會造成內存緩沖區溢出,字符串長度減小時會造成內存泄露。   而對于SDS,由于len屬性和free屬性的存在,對于修改字符串SDS實現了空間預分配和惰性空間釋放兩種策略:   1、空間預分配:對字符串進行空間擴展的時候,擴展的內存比實際需要的多,這樣可以減少連續執行字符串增長操作所需的內存重分配次數。   2、惰性空間釋放:對字符串進行縮短操作時,程序不立即使用內存重新分配來回收縮短后多余的字節,而是使用 free 屬性將這些字節的數量記錄下來,等待后續使用。(當然SDS也提供了相應的API,當我們有需要時,也可以手動釋放這些未使用的空間。)   ④、二進制安全   因為C字符串以空字符作為字符串結束的標識,而對于一些二進制文件(如圖片等),內容可能包括空字符串,因此C字符串無法正確存取;而所有 SDS 的API 都是以處理二進制的方式來處理 buf 里面的元素,并且 SDS 不是以空字符串來判斷是否結束,而是以 len 屬性表示的長度來判斷字符串是否結束。   ⑤、兼容部分 C 字符串函數   雖然 SDS 是二進制安全的,但是一樣遵從每個字符串都是以空字符串結尾的慣例,這樣可以重用 C 語言庫<string.h> 中的一部分函數。
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看