0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Redis基本數(shù)據(jù)類型有哪些

數(shù)據(jù)分析與開發(fā) ? 來源:科技繆繆 ? 作者:科技繆繆 ? 2021-11-02 11:46 ? 次閱讀

說說Redis基本數(shù)據(jù)類型有哪些吧

字符串:redis沒有直接使用C語言傳統(tǒng)的字符串表示,而是自己實現(xiàn)的叫做簡單動態(tài)字符串SDS的抽象類型。C語言的字符串不記錄自身的長度信息,而SDS則保存了長度信息,這樣將獲取字符串長度的時間由O(N)降低到了O(1),同時可以避免緩沖區(qū)溢出和減少修改字符串長度時所需的內(nèi)存重分配次數(shù)。

鏈表linkedlist:redis鏈表是一個雙向無環(huán)鏈表結(jié)構(gòu),很多發(fā)布訂閱、慢查詢、監(jiān)視器功能都是使用到了鏈表來實現(xiàn),每個鏈表的節(jié)點由一個listNode結(jié)構(gòu)來表示,每個節(jié)點都有指向前置節(jié)點和后置節(jié)點的指針,同時表頭節(jié)點的前置和后置節(jié)點都指向NULL。

字典hashtable:用于保存鍵值對的抽象數(shù)據(jù)結(jié)構(gòu)。redis使用hash表作為底層實現(xiàn),每個字典帶有兩個hash表,供平時使用和rehash時使用,hash表使用鏈地址法來解決鍵沖突,被分配到同一個索引位置的多個鍵值對會形成一個單向鏈表,在對hash表進行擴容或者縮容的時候,為了服務(wù)的可用性,rehash的過程不是一次性完成的,而是漸進式的。

跳躍表skiplist:跳躍表是有序集合的底層實現(xiàn)之一,redis中在實現(xiàn)有序集合鍵和集群節(jié)點的內(nèi)部結(jié)構(gòu)中都是用到了跳躍表。redis跳躍表由zskiplist和zskiplistNode組成,zskiplist用于保存跳躍表信息(表頭、表尾節(jié)點、長度等),zskiplistNode用于表示表跳躍節(jié)點,每個跳躍表的層高都是1-32的隨機數(shù),在同一個跳躍表中,多個節(jié)點可以包含相同的分值,但是每個節(jié)點的成員對象必須是唯一的,節(jié)點按照分值大小排序,如果分值相同,則按照成員對象的大小排序。

整數(shù)集合intset:用于保存整數(shù)值的集合抽象數(shù)據(jù)結(jié)構(gòu),不會出現(xiàn)重復(fù)元素,底層實現(xiàn)為數(shù)組。

壓縮列表ziplist:壓縮列表是為節(jié)約內(nèi)存而開發(fā)的順序性數(shù)據(jù)結(jié)構(gòu),他可以包含多個節(jié)點,每個節(jié)點可以保存一個字節(jié)數(shù)組或者整數(shù)值。

基于這些基礎(chǔ)的數(shù)據(jù)結(jié)構(gòu),redis封裝了自己的對象系統(tǒng),包含字符串對象string、列表對象list、哈希對象hash、集合對象set、有序集合對象zset,每種對象都用到了至少一種基礎(chǔ)的數(shù)據(jù)結(jié)構(gòu)。

redis通過encoding屬性設(shè)置對象的編碼形式來提升靈活性和效率,基于不同的場景redis會自動做出優(yōu)化。不同對象的編碼如下:

字符串對象string:int整數(shù)、embstr編碼的簡單動態(tài)字符串、raw簡單動態(tài)字符串

列表對象list:ziplist、linkedlist

哈希對象hash:ziplist、hashtable

集合對象set:intset、hashtable

有序集合對象zset:ziplist、skiplist

Redis為什么快呢?

redis的速度非常的快,單機的redis就可以支撐每秒10幾萬的并發(fā),相對于mysql來說,性能是mysql的幾十倍。速度快的原因主要有幾點:

完全基于內(nèi)存操作

C語言實現(xiàn),優(yōu)化過的數(shù)據(jù)結(jié)構(gòu),基于幾種基礎(chǔ)的數(shù)據(jù)結(jié)構(gòu),redis做了大量的優(yōu)化,性能極高

使用單線程,無上下文的切換成本

基于非阻塞的IO多路復(fù)用機制

那為什么Redis6.0之后又改用多線程呢?

redis使用多線程并非是完全摒棄單線程,redis還是使用單線程模型來處理客戶端的請求,只是使用多線程來處理數(shù)據(jù)的讀寫和協(xié)議解析,執(zhí)行命令還是使用單線程。

這樣做的目的是因為redis的性能瓶頸在于網(wǎng)絡(luò)IO而非CPU,使用多線程能提升IO讀寫的效率,從而整體提高redis的性能。

知道什么是熱key嗎?熱key問題怎么解決?

所謂熱key問題就是,突然有幾十萬的請求去訪問redis上的某個特定key,那么這樣會造成流量過于集中,達到物理網(wǎng)卡上限,從而導(dǎo)致這臺redis的服務(wù)器宕機引發(fā)雪崩。

針對熱key的解決方案:

提前把熱key打散到不同的服務(wù)器,降低壓力

加入二級緩存,提前加載熱key數(shù)據(jù)到內(nèi)存中,如果redis宕機,走內(nèi)存查詢

什么是緩存擊穿、緩存穿透、緩存雪崩?

緩存擊穿

緩存擊穿的概念就是單個key并發(fā)訪問過高,過期時導(dǎo)致所有請求直接打到db上,這個和熱key的問題比較類似,只是說的點在于過期導(dǎo)致請求全部打到DB上而已。

解決方案:

加鎖更新,比如請求查詢A,發(fā)現(xiàn)緩存中沒有,對A這個key加鎖,同時去數(shù)據(jù)庫查詢數(shù)據(jù),寫入緩存,再返回給用戶,這樣后面的請求就可以從緩存中拿到數(shù)據(jù)了。

將過期時間組合寫在value中,通過異步的方式不斷的刷新過期時間,防止此類現(xiàn)象。

緩存穿透

緩存穿透是指查詢不存在緩存中的數(shù)據(jù),每次請求都會打到DB,就像緩存不存在一樣。

針對這個問題,加一層布隆過濾器。布隆過濾器的原理是在你存入數(shù)據(jù)的時候,會通過散列函數(shù)將它映射為一個位數(shù)組中的K個點,同時把他們置為1。

這樣當(dāng)用戶再次來查詢A,而A在布隆過濾器值為0,直接返回,就不會產(chǎn)生擊穿請求打到DB了。

顯然,使用布隆過濾器之后會有一個問題就是誤判,因為它本身是一個數(shù)組,可能會有多個值落到同一個位置,那么理論上來說只要我們的數(shù)組長度夠長,誤判的概率就會越低,這種問題就根據(jù)實際情況來就好了。

緩存雪崩

當(dāng)某一時刻發(fā)生大規(guī)模的緩存失效的情況,比如你的緩存服務(wù)宕機了,會有大量的請求進來直接打到DB上,這樣可能導(dǎo)致整個系統(tǒng)的崩潰,稱為雪崩。雪崩和擊穿、熱key的問題不太一樣的是,他是指大規(guī)模的緩存都過期失效了。

針對雪崩幾個解決方案:

針對不同key設(shè)置不同的過期時間,避免同時過期

限流,如果redis宕機,可以限流,避免同時刻大量請求打崩DB

二級緩存,同熱key的方案。

Redis的過期策略有哪些?

redis主要有2種過期刪除策略

惰性刪除

惰性刪除指的是當(dāng)我們查詢key的時候才對key進行檢測,如果已經(jīng)達到過期時間,則刪除。顯然,他有一個缺點就是如果這些過期的key沒有被訪問,那么他就一直無法被刪除,而且一直占用內(nèi)存。

定期刪除

定期刪除指的是redis每隔一段時間對數(shù)據(jù)庫做一次檢查,刪除里面的過期key。由于不可能對所有key去做輪詢來刪除,所以redis會每次隨機取一些key去做檢查和刪除。

那么定期+惰性都沒有刪除過期的key怎么辦?

假設(shè)redis每次定期隨機查詢key的時候沒有刪掉,這些key也沒有做查詢的話,就會導(dǎo)致這些key一直保存在redis里面無法被刪除,這時候就會走到redis的內(nèi)存淘汰機制。

volatile-lru:從已設(shè)置過期時間的key中,移除最近最少使用的key進行淘汰

volatile-ttl:從已設(shè)置過期時間的key中,移除將要過期的key

volatile-random:從已設(shè)置過期時間的key中隨機選擇key淘汰

allkeys-lru:從key中選擇最近最少使用的進行淘汰

allkeys-random:從key中隨機選擇key進行淘汰

noeviction:當(dāng)內(nèi)存達到閾值的時候,新寫入操作報錯

持久化方式有哪些?有什么區(qū)別?

redis持久化方案分為RDB和AOF兩種。

RDB

RDB持久化可以手動執(zhí)行也可以根據(jù)配置定期執(zhí)行,它的作用是將某個時間點上的數(shù)據(jù)庫狀態(tài)保存到RDB文件中,RDB文件是一個壓縮的二進制文件,通過它可以還原某個時刻數(shù)據(jù)庫的狀態(tài)。由于RDB文件是保存在硬盤上的,所以即使redis崩潰或者退出,只要RDB文件存在,就可以用它來恢復(fù)還原數(shù)據(jù)庫的狀態(tài)。

可以通過SAVE或者BGSAVE來生成RDB文件。

SAVE命令會阻塞redis進程,直到RDB文件生成完畢,在進程阻塞期間,redis不能處理任何命令請求,這顯然是不合適的。

BGSAVE則是會fork出一個子進程,然后由子進程去負責(zé)生成RDB文件,父進程還可以繼續(xù)處理命令請求,不會阻塞進程。

AOF

AOF和RDB不同,AOF是通過保存redis服務(wù)器所執(zhí)行的寫命令來記錄數(shù)據(jù)庫狀態(tài)的。

AOF通過追加、寫入、同步三個步驟來實現(xiàn)持久化機制。

當(dāng)AOF持久化處于激活狀態(tài),服務(wù)器執(zhí)行完寫命令之后,寫命令將會被追加append到aof_buf緩沖區(qū)的末尾

在服務(wù)器每結(jié)束一個事件循環(huán)之前,將會調(diào)用flushAppendOnlyFile函數(shù)決定是否要將aof_buf的內(nèi)容保存到AOF文件中,可以通過配置appendfsync來決定。

always ##aof_buf內(nèi)容寫入并同步到AOF文件

everysec ##將aof_buf中內(nèi)容寫入到AOF文件,如果上次同步AOF文件時間距離現(xiàn)在超過1秒,則再次對AOF文件進行同步

no ##將aof_buf內(nèi)容寫入AOF文件,但是并不對AOF文件進行同步,同步時間由操作系統(tǒng)決定

如果不設(shè)置,默認選項將會是everysec,因為always來說雖然最安全(只會丟失一次事件循環(huán)的寫命令),但是性能較差,而everysec模式只不過會可能丟失1秒鐘的數(shù)據(jù),而no模式的效率和everysec相仿,但是會丟失上次同步AOF文件之后的所有寫命令數(shù)據(jù)。

怎么實現(xiàn)Redis的高可用?

要想實現(xiàn)高可用,一臺機器肯定是不夠的,而redis要保證高可用,有2個可選方案。

主從架構(gòu)

主從模式是最簡單的實現(xiàn)高可用的方案,核心就是主從同步。主從同步的原理如下:

slave發(fā)送sync命令到master

master收到sync之后,執(zhí)行bgsave,生成RDB全量文件

master把slave的寫命令記錄到緩存

bgsave執(zhí)行完畢之后,發(fā)送RDB文件到slave,slave執(zhí)行

master發(fā)送緩存中的寫命令到slave,slave執(zhí)行

這里我寫的這個命令是sync,但是在redis2.8版本之后已經(jīng)使用psync來替代sync了,原因是sync命令非常消耗系統(tǒng)資源,而psync的效率更高。

哨兵

基于主從方案的缺點還是很明顯的,假設(shè)master宕機,那么就不能寫入數(shù)據(jù),那么slave也就失去了作用,整個架構(gòu)就不可用了,除非你手動切換,主要原因就是因為沒有自動故障轉(zhuǎn)移機制。而哨兵(sentinel)的功能比單純的主從架構(gòu)全面的多了,它具備自動故障轉(zhuǎn)移、集群監(jiān)控、消息通知等功能。

哨兵可以同時監(jiān)視多個主從服務(wù)器,并且在被監(jiān)視的master下線時,自動將某個slave提升為master,然后由新的master繼續(xù)接收命令。整個過程如下:

初始化sentinel,將普通的redis代碼替換成sentinel專用代碼

初始化masters字典和服務(wù)器信息,服務(wù)器信息主要保存ip:port,并記錄實例的地址和ID

創(chuàng)建和master的兩個連接,命令連接和訂閱連接,并且訂閱sentinel:hello頻道

每隔10秒向master發(fā)送info命令,獲取master和它下面所有slave的當(dāng)前信息

當(dāng)發(fā)現(xiàn)master有新的slave之后,sentinel和新的slave同樣建立兩個連接,同時每個10秒發(fā)送info命令,更新master信息

sentinel每隔1秒向所有服務(wù)器發(fā)送ping命令,如果某臺服務(wù)器在配置的響應(yīng)時間內(nèi)連續(xù)返回?zé)o效回復(fù),將會被標記為下線狀態(tài)

選舉出領(lǐng)頭sentinel,領(lǐng)頭sentinel需要半數(shù)以上的sentinel同意

領(lǐng)頭sentinel從已下線的的master所有slave中挑選一個,將其轉(zhuǎn)換為master

讓所有的slave改為從新的master復(fù)制數(shù)據(jù)

將原來的master設(shè)置為新的master的從服務(wù)器,當(dāng)原來master重新回復(fù)連接時,就變成了新master的從服務(wù)器

sentinel會每隔1秒向所有實例(包括主從服務(wù)器和其他sentinel)發(fā)送ping命令,并且根據(jù)回復(fù)判斷是否已經(jīng)下線,這種方式叫做主觀下線。當(dāng)判斷為主觀下線時,就會向其他監(jiān)視的sentinel詢問,如果超過半數(shù)的投票認為已經(jīng)是下線狀態(tài),則會標記為客觀下線狀態(tài),同時觸發(fā)故障轉(zhuǎn)移。

能說說redis集群的原理嗎?

如果說依靠哨兵可以實現(xiàn)redis的高可用,如果還想在支持高并發(fā)同時容納海量的數(shù)據(jù),那就需要redis集群。redis集群是redis提供的分布式數(shù)據(jù)存儲方案,集群通過數(shù)據(jù)分片sharding來進行數(shù)據(jù)的共享,同時提供復(fù)制和故障轉(zhuǎn)移的功能。

節(jié)點

一個redis集群由多個節(jié)點node組成,而多個node之間通過cluster meet命令來進行連接,節(jié)點的握手過程:

節(jié)點A收到客戶端的cluster meet命令

A根據(jù)收到的IP地址和端口號,向B發(fā)送一條meet消息

節(jié)點B收到meet消息返回pong

A知道B收到了meet消息,返回一條ping消息,握手成功

最后,節(jié)點A將會通過gossip協(xié)議把節(jié)點B的信息傳播給集群中的其他節(jié)點,其他節(jié)點也將和B進行握手

槽slot

redis通過集群分片的形式來保存數(shù)據(jù),整個集群數(shù)據(jù)庫被分為16384個slot,集群中的每個節(jié)點可以處理0-16383個slot,當(dāng)數(shù)據(jù)庫16384個slot都有節(jié)點在處理時,集群處于上線狀態(tài),反之只要有一個slot沒有得到處理都會處理下線狀態(tài)。通過cluster addslots命令可以將slot指派給對應(yīng)節(jié)點處理。

slot是一個位數(shù)組,數(shù)組的長度是16384/8=2048,而數(shù)組的每一位用1表示被節(jié)點處理,0表示不處理,如圖所示的話表示A節(jié)點處理0-7的slot。

當(dāng)客戶端向節(jié)點發(fā)送命令,如果剛好找到slot屬于當(dāng)前節(jié)點,那么節(jié)點就執(zhí)行命令,反之,則會返回一個MOVED命令到客戶端指引客戶端轉(zhuǎn)向正確的節(jié)點。(MOVED過程是自動的)

如果增加或者移出節(jié)點,對于slot的重新分配也是非常方便的,redis提供了工具幫助實現(xiàn)slot的遷移,整個過程是完全在線的,不需要停止服務(wù)。

故障轉(zhuǎn)移

如果節(jié)點A向節(jié)點B發(fā)送ping消息,節(jié)點B沒有在規(guī)定的時間內(nèi)響應(yīng)pong,那么節(jié)點A會標記節(jié)點B為pfail疑似下線狀態(tài),同時把B的狀態(tài)通過消息的形式發(fā)送給其他節(jié)點,如果超過半數(shù)以上的節(jié)點都標記B為pfail狀態(tài),B就會被標記為fail下線狀態(tài),此時將會發(fā)生故障轉(zhuǎn)移,優(yōu)先從復(fù)制數(shù)據(jù)較多的從節(jié)點選擇一個成為主節(jié)點,并且接管下線節(jié)點的slot,整個過程和哨兵非常類似,都是基于Raft協(xié)議做選舉。

了解Redis事務(wù)機制嗎?

redis通過MULTI、EXEC、WATCH等命令來實現(xiàn)事務(wù)機制,事務(wù)執(zhí)行過程將一系列多個命令按照順序一次性執(zhí)行,并且在執(zhí)行期間,事務(wù)不會被中斷,也不會去執(zhí)行客戶端的其他請求,直到所有命令執(zhí)行完畢。事務(wù)的執(zhí)行過程如下:

服務(wù)端收到客戶端請求,事務(wù)以MULTI開始

如果客戶端正處于事務(wù)狀態(tài),則會把事務(wù)放入隊列同時返回給客戶端QUEUED,反之則直接執(zhí)行這個命令

當(dāng)收到客戶端EXEC命令時,WATCH命令監(jiān)視整個事務(wù)中的key是否有被修改,如果有則返回空回復(fù)到客戶端表示失敗,否則redis會遍歷整個事務(wù)隊列,執(zhí)行隊列中保存的所有命令,最后返回結(jié)果給客戶端

WATCH的機制本身是一個CAS的機制,被監(jiān)視的key會被保存到一個鏈表中,如果某個key被修改,那么REDIS_DIRTY_CAS標志將會被打開,這時服務(wù)器會拒絕執(zhí)行事務(wù)。

責(zé)任編輯:haq

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 數(shù)據(jù)
    +關(guān)注

    關(guān)注

    8

    文章

    6808

    瀏覽量

    88743
  • C語音
    +關(guān)注

    關(guān)注

    0

    文章

    12

    瀏覽量

    12633
  • Redis
    +關(guān)注

    關(guān)注

    0

    文章

    370

    瀏覽量

    10830

原文標題:Redis 奪命連環(huán) 11 問

文章出處:【微信號:DBDevs,微信公眾號:數(shù)據(jù)分析與開發(fā)】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    labview數(shù)據(jù)類型的取值范圍是多少

    LabVIEW的數(shù)據(jù)類型豐富多樣,涵蓋了整數(shù)、小數(shù)(浮點數(shù))、復(fù)數(shù)等多種類型,每種類型都有其特定的取值范圍。以下是對LabVIEW中常見數(shù)據(jù)類型取值范圍的說明: 整數(shù)
    的頭像 發(fā)表于 09-04 17:33 ?648次閱讀

    常見的遙感數(shù)據(jù)類型哪些

    遙感技術(shù)是一種通過遙感器在遠離目標的位置獲取目標地物的電磁波信息,并進行分析的技術(shù)。遙感數(shù)據(jù)類型繁多,涵蓋了從可見光到紅外、微波等多個波段,以及不同的數(shù)據(jù)格式和分辨率。 光學(xué)遙感數(shù)據(jù) : 全色影像
    的頭像 發(fā)表于 09-04 14:30 ?927次閱讀

    技術(shù)干貨驛站 ▏深入理解C語言:基本數(shù)據(jù)類型和變量

    在C語言中,數(shù)據(jù)類型和變量是編程的基礎(chǔ),也是理解更復(fù)雜概念的關(guān)鍵。數(shù)據(jù)類型決定了變量的內(nèi)存分配、存儲范圍和操作方式,而變量則是存儲數(shù)據(jù)的容器。本篇文章將從基本數(shù)據(jù)類型和變量兩個方面,帶
    的頭像 發(fā)表于 07-26 17:53 ?1856次閱讀
    技術(shù)干貨驛站 ▏深入理解C語言:基<b class='flag-5'>本數(shù)據(jù)類型</b>和變量

    C語言數(shù)據(jù)類型哪些

    在 C 語言中,數(shù)據(jù)類型指的是用于聲明不同類型的變量或函數(shù)的一個廣泛的系統(tǒng)。變量的類型決定了變量存儲占用的空間,以及如何解釋存儲的位模式。
    發(fā)表于 03-20 10:56 ?423次閱讀
    C語言<b class='flag-5'>數(shù)據(jù)類型</b><b class='flag-5'>有</b>哪些

    plc數(shù)據(jù)類型怎么理解和應(yīng)用

    PLC(可編程邏輯控制器)是一種工業(yè)自動化設(shè)備,用于控制機械和工業(yè)過程。在PLC編程中,數(shù)據(jù)類型是非常重要的概念,因為它決定了程序中數(shù)據(jù)的存儲和處理方式。正確理解和應(yīng)用PLC數(shù)據(jù)類型是編寫有效、可靠
    的頭像 發(fā)表于 12-19 11:39 ?3899次閱讀

    oracle的數(shù)據(jù)類型哪些

    Oracle數(shù)據(jù)庫中有許多數(shù)據(jù)類型可供選擇,每種數(shù)據(jù)類型都有其各自的特點和適用場景。下面是對Oracle數(shù)據(jù)庫中最常用的數(shù)據(jù)類型的詳盡說明,
    的頭像 發(fā)表于 12-05 16:45 ?2231次閱讀

    byte屬于java基本類型

    是的,byte屬于Java的基本數(shù)據(jù)類型之一。Java中共有8種基本數(shù)據(jù)類型,分別是byte、short、int、long、float、double、char和boolean。byte類型用于表示8
    的頭像 發(fā)表于 12-05 10:40 ?804次閱讀

    redis的主要方法

    ,包括字符串操作、哈希操作、列表操作、集合操作以及有序集合操作等,同時還會對每個方法進行實例演示。 一、字符串操作 Redis的字符串是最基本的數(shù)據(jù)類型,可以存儲任意類型數(shù)據(jù),包括二
    的頭像 發(fā)表于 12-05 09:59 ?763次閱讀

    php的數(shù)據(jù)類型主要有哪幾種

    PHP是一種強類型編程語言,它支持多種數(shù)據(jù)類型。以下是PHP的主要數(shù)據(jù)類型: 字符串(String): 表示文本數(shù)據(jù),可以使用單引號或雙引號來定義字符串。例如:$str = "Hell
    的頭像 發(fā)表于 12-04 16:05 ?660次閱讀

    javascript的typeof返回哪些數(shù)據(jù)類型?

    JavaScript的typeof操作符用于確定一個值的數(shù)據(jù)類型,可能的返回值包括以下幾種: "undefined":當(dāng)一個變量被聲明但未被賦值時,其類型為undefined。 "boolean
    的頭像 發(fā)表于 12-03 11:41 ?752次閱讀

    javascript的基本數(shù)據(jù)類型哪些

    JavaScript 是一種動態(tài)的、面向?qū)ο蟮木幊陶Z言,廣泛應(yīng)用于 Web 開發(fā)中。在 JavaScript 中,七種基本數(shù)據(jù)類型(Primitive Types),它們分別是 Undefined
    的頭像 發(fā)表于 12-03 11:17 ?718次閱讀

    C語言里的整數(shù)數(shù)據(jù)類型

    1. 整型數(shù)據(jù)類型 C語言里面的整數(shù)數(shù)據(jù)類型 類型名稱 C語言中的關(guān)鍵字 注釋 字符型 char 表示一個很小的整數(shù) 短整型 short 表示一個不怎么大的整數(shù) 整型 int 生活中一般的整數(shù)都可以
    的頭像 發(fā)表于 11-24 16:09 ?893次閱讀
    C語言里的整數(shù)<b class='flag-5'>數(shù)據(jù)類型</b>

    redis的五種數(shù)據(jù)類型底層數(shù)據(jù)結(jié)構(gòu)

    Redis是一種內(nèi)存數(shù)據(jù)存儲系統(tǒng),支持多種數(shù)據(jù)結(jié)構(gòu)。這些數(shù)據(jù)結(jié)構(gòu)不僅可以滿足常見的存儲需求,還能夠通過其底層數(shù)據(jù)結(jié)構(gòu)提供高效的操作和查詢。以
    的頭像 發(fā)表于 11-16 11:18 ?672次閱讀

    redis的五種數(shù)據(jù)類型

    Redis是一種高性能的內(nèi)存數(shù)據(jù)庫,常用于緩存、任務(wù)隊列、分布式鎖等場景。它提供了多種數(shù)據(jù)類型來滿足各種不同的需求,包括字符串(string)、哈希(hash)、列表(list)、集合(set
    的頭像 發(fā)表于 11-16 11:06 ?590次閱讀

    如何將ROS數(shù)據(jù)類型轉(zhuǎn)換為MATLAB數(shù)據(jù)類型

    。 例如,四元數(shù)消息包含w、x、y和z屬性,但該消息并不強制四元數(shù)作為一個整體是有效的。所以可能在單獨修改一個四元數(shù)信息后,這個四元數(shù)是不符合模型的。 同時消息屬性還可以具有各種數(shù)據(jù)類型。MATLAB使用ROS設(shè)置的規(guī)則來確定這些數(shù)據(jù)
    的頭像 發(fā)表于 11-15 15:24 ?536次閱讀
    如何將ROS<b class='flag-5'>數(shù)據(jù)類型</b>轉(zhuǎn)換為MATLAB<b class='flag-5'>數(shù)據(jù)類型</b>