chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

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

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

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

應(yīng)用開發(fā)中結(jié)構(gòu)體和鏈表的關(guān)系是怎樣的

玩轉(zhuǎn)單片機(jī) ? 來源:玩轉(zhuǎn)單片機(jī) ? 作者:玩轉(zhuǎn)單片機(jī) ? 2022-12-12 10:57 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

不知道各位讀者是怎么理解鏈表的,還有就是鏈表和結(jié)構(gòu)體的關(guān)系?最近開發(fā)的項(xiàng)目資源不是很緊湊,就用了面向?qū)ο缶帉?,就大量的使用到結(jié)構(gòu)體,有時還會配合共同體嵌套使用,順便回顧了一些結(jié)構(gòu)體的使用,這里主要簡單回顧結(jié)構(gòu)體和鏈表的關(guān)系;

鏈表在RTOS上比較常見,這里會把復(fù)雜的東西簡單化,這也是為啥有些推文的文字很少的原因,碼農(nóng)的產(chǎn)出就是代碼,核心就是看相關(guān)代碼;鏈表分單鏈表和雙鏈表,核心都差不多的,就用單鏈表做展示;

| 定義節(jié)點(diǎn)

鏈表的最小單位就是節(jié)點(diǎn),節(jié)點(diǎn)的定義就是鏈表的基礎(chǔ),下面展示一些定義的小案例:

//正確定義方式之一
struct node
{
    unsigned char data;
    struct node *next;
};


//錯誤定義方式之一
typrder struct node
{
    unsigned char data;
    node_t *next;
}node_t;

代碼都是一行一行執(zhí)行的,如果沒有提前聲明調(diào)用的話,代碼編譯階段就會報錯,同樣的,類型定義比類型調(diào)用使用晚也會報錯;有些初學(xué)者會對結(jié)構(gòu)體使用同名結(jié)構(gòu)體會有疑問,其實(shí)把同名的結(jié)構(gòu)體換個思路,上面的第二行是不是定義了一個struct node類型的數(shù)據(jù),結(jié)構(gòu)體成員是不是變量類型+變量名,是不是符合結(jié)構(gòu)體的基本使用,所有這樣的用法是合法的;

| 鏈接成表

鏈表的最小單位就是節(jié)點(diǎn),那么多定義幾個節(jié)點(diǎn),然后就讓它們鏈接起來,那么就形成了鏈表,那么這條“鏈”是啥呢,有時怎么把它們關(guān)聯(lián)起來的呢?學(xué)過鏈表的同學(xué)就很清楚,就是節(jié)點(diǎn)中的同名結(jié)構(gòu)體指針,這個指針就像電話號碼,直接通過電話號碼就能找到對應(yīng)的人,同理也可以通過指針找到對應(yīng)的節(jié)點(diǎn);

申請內(nèi)存的坑,申請的內(nèi)存一定要強(qiáng)制轉(zhuǎn)換類型,不強(qiáng)制轉(zhuǎn)換默認(rèn)是返回一個任意類型的指針(void *),不強(qiáng)制轉(zhuǎn)換類型編譯也會出錯:

int main()
{
inttemp=10;
// 沒有強(qiáng)制轉(zhuǎn)換類型,編譯報錯
  int *p = malloc(siezof(temp))
}

列個完整的小程序,看完基本就學(xué)會了鏈表:

#include "stdio.h"
#include "stdlib.h"


typedef struct node
{
    unsigned char data;
    struct node *next;
}node_t;


int main()
{
  // 創(chuàng)建幾個節(jié)點(diǎn)
  node_t* node1=(node_t*)malloc(sizeof(node_t));
  node_t* node2=(node_t*)malloc(sizeof(node_t));
  node_t* node3=(node_t*)malloc(sizeof(node_t));
  
  // 初始數(shù)據(jù)
  node1->data = 1;
  node2->data = 2;
  node3->data = 3;
  
  // 鏈接成表
  node1->next =  node2;
  node2->next =  node3;
  node3->next =  node1;
  
  // 打印數(shù)據(jù)
  printf("data:%d
", node1->data);          // 節(jié)點(diǎn)1的數(shù)據(jù) 
  printf("data:%d
", node1->next->data);        // 節(jié)點(diǎn)2的數(shù)據(jù)
  printf("data:%d
", node1->next->next->data);    // 節(jié)點(diǎn)3的數(shù)據(jù)
  printf("data:%d
", node1->next->next->next->data);  // 節(jié)點(diǎn)1的數(shù)據(jù)
  
  // 釋放內(nèi)存 
  free(node1); 
  free(node2);
  free(node3);
}

鏈表的增刪改查本質(zhì)就是對節(jié)點(diǎn)中的指針操作,以及節(jié)點(diǎn)的創(chuàng)建和釋放,基本不是什么大問題;看到這應(yīng)該對鏈表基礎(chǔ)知識沒有疑問了吧,覺得有收獲的同學(xué)動動小手指點(diǎn)個贊吧,我是Noah,我們下篇推文再見!

審核編輯:郭婷

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

    關(guān)注

    25

    文章

    865

    瀏覽量

    122749
  • 代碼
    +關(guān)注

    關(guān)注

    30

    文章

    4956

    瀏覽量

    73506

原文標(biāo)題:通俗|結(jié)構(gòu)體與鏈表

文章出處:【微信號:玩轉(zhuǎn)單片機(jī),微信公眾號:玩轉(zhuǎn)單片機(jī)】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點(diǎn)推薦

    10個例子代碼,C語言結(jié)構(gòu)的高級

    (\"Flag 3: %dn\", f.flag3); return 0; } 在這個例子,我們使用了位字段來定義一個結(jié)構(gòu),其中每個成員變量都指定了所占用的位數(shù)。這樣
    發(fā)表于 01-05 06:32

    一個經(jīng)典的結(jié)構(gòu)和聯(lián)合體共用的實(shí)例

    結(jié)構(gòu) 結(jié)構(gòu)占用的內(nèi)存大小,首先和編譯器的系統(tǒng)位數(shù)有關(guān)系,類似于CPU是 64 bits 還是 32 bits 的情形;其次,
    發(fā)表于 12-16 07:14

    結(jié)構(gòu)聲明與定義

    int year;//入學(xué)年份,用無符號整數(shù)表示 unsigned int years;//學(xué)制,用無符號整數(shù)表示 }; int main(void) { /** *在main函數(shù)聲明結(jié)構(gòu)
    發(fā)表于 12-11 07:52

    無數(shù)據(jù)域雙向鏈表的代碼

    ); return 0; } 在這個示例,我們定義了一個包含指向前一個節(jié)點(diǎn)和后一個節(jié)點(diǎn)的結(jié)構(gòu) Node,以及一個包含整數(shù)數(shù)據(jù)和 Node 結(jié)構(gòu)
    發(fā)表于 12-11 06:56

    typedef結(jié)構(gòu)使用

    雖然結(jié)構(gòu)的出現(xiàn)能夠讓我們有一個更科學(xué)的數(shù)據(jù)結(jié)構(gòu)來管理數(shù)據(jù),但是每次使用結(jié)構(gòu)都需要struct...,未免顯得有些冗長和麻煩。有了type
    發(fā)表于 12-08 07:04

    為什么不建議用匿名結(jié)構(gòu)

    bit_1:1 ;uint8_t bit_2:1 ; }; uint8_t value; }info2; }info_t; 在這個例子,下面這個就是所謂的匿名結(jié)構(gòu),因?yàn)檫@個 struct 沒有
    發(fā)表于 12-04 07:39

    C語言結(jié)構(gòu)使用

    有時候需要將不同類型的數(shù)據(jù)組合為一個整體,以便于引用。例如,一名學(xué)生有學(xué)號、姓名、性別、年齡等屬性,如果針對每個屬性都單獨(dú)定義一個變量,那么當(dāng)有多名學(xué)生時變量就難以分清。結(jié)構(gòu)就是用來管理不同類
    發(fā)表于 11-12 08:30

    定義IO初始化結(jié)構(gòu)

    由上述IOPORT相關(guān)功能的枚舉類型我們可以知道,在對IOPORT模塊進(jìn)行初始化時需要根據(jù)情況配置它們。因此我們定義一個IOPORT初始化的結(jié)構(gòu)類型IOPORT_Init_t,它的成員包括了由上述所有枚舉類型所聲明的變量,因此該結(jié)構(gòu)
    的頭像 發(fā)表于 07-16 16:26 ?1278次閱讀

    晶體結(jié)構(gòu)晶面和晶向的關(guān)系

    晶面和晶向是晶體學(xué)兩個核心的概念,它們與硅基集成電路工藝的晶體結(jié)構(gòu)有密切的關(guān)系。
    的頭像 發(fā)表于 06-05 16:58 ?3550次閱讀
    晶體<b class='flag-5'>結(jié)構(gòu)</b><b class='flag-5'>中</b>晶面和晶向的<b class='flag-5'>關(guān)系</b>

    滲壓計在混凝土結(jié)構(gòu)的安裝指南

    在現(xiàn)代土木工程和巖土工程,滲壓計是監(jiān)測混凝土結(jié)構(gòu)體內(nèi)孔隙水壓力變化的重要工具。南京峟思公司生產(chǎn)的滲壓計因其高精度和可靠性而被廣泛應(yīng)用于各種工程監(jiān)測項(xiàng)目中。一、滲壓計在混凝土結(jié)構(gòu)
    的頭像 發(fā)表于 05-28 10:55 ?488次閱讀
    滲壓計在混凝土<b class='flag-5'>結(jié)構(gòu)</b><b class='flag-5'>體</b><b class='flag-5'>中</b>的安裝指南

    GLAD應(yīng)用:全息光柵模擬

    用于模擬全息記錄介質(zhì)形成的梯度折射率分布。全息結(jié)構(gòu)一旦形成,就可以在傳輸過程中將一束入射光波逐漸轉(zhuǎn)換成形成體全息結(jié)構(gòu)的另一束光波。兩束光波之間的能量傳遞轉(zhuǎn)換效率與
    發(fā)表于 05-15 09:32

    程序設(shè)計與數(shù)據(jù)結(jié)構(gòu)

    《程序設(shè)計與數(shù)據(jù)結(jié)構(gòu)》重點(diǎn)闡述了三大方向內(nèi)容: 1. C語言學(xué)習(xí)的痛點(diǎn):針對當(dāng)前工程師在C語言學(xué)習(xí)的痛點(diǎn),如指針函數(shù)與函數(shù)指針,如何靈活應(yīng)用結(jié)構(gòu)
    發(fā)表于 05-13 16:45

    學(xué)習(xí)智能開發(fā)

    智能是大模型的應(yīng)用落地,正在學(xué)習(xí),這本書太及時了,非常想看看。
    發(fā)表于 03-27 15:48

    軟國際Lumi智能開發(fā)平臺支持DeepSeek

    作為大模型領(lǐng)域的一顆璀璨新星,DeepSeek從模型結(jié)構(gòu)到訓(xùn)推流程進(jìn)行了全面優(yōu)化,并完全開源,打破了算力依賴路徑,推動行業(yè)從 “規(guī)模至上” 邁向 “效率優(yōu)先”。軟國際Lumi智能開發(fā)
    的頭像 發(fā)表于 02-28 15:46 ?1014次閱讀

    噪聲與ADC的范圍和位數(shù)是什么關(guān)系呢?怎樣選用和匹配?

    以上三者是什么關(guān)系呢?怎樣選用和匹配?ADC的動態(tài)輸入范圍一般都有多大的?謝謝
    發(fā)表于 02-08 07:14