作為嵌入式工程師,寫一個效率高效,思路清晰的C語言程序是我們的終極目標。那么,怎樣才能寫好這樣的程序呢?首先,我們要用C語言的思維方式來進行程序的構架構建;其次,要有良好的C語言算法基礎,以此來實現程序的邏輯構架;最后,靈活運用C語言的指針操作。雖然看起來以上的說法很抽象,給人如墜霧里的感覺,其實就是用C語言進行遇到問題、分析問題和解決問題的過程。那么,下文將給大家介紹一下如何耍這“三板斧”。嵌入式工程師在編寫C語言程序的時候,要針對遇到的問題進行程序構架構建。比如我們要處理“猴子選大王”的經典問題:一群猴子,手拉手排成一個圓,從任意一只猴子開始從1開始報數,當遇到要排除的數(預先設定)時該猴子退出該圈,從下一只猴子開始繼續從1報數。如此反復,最終剩下的猴子便是猴子的大王。那么,這“三板斧”該如何使用呢?第一板斧,用C語言進行程序構架構建程序分為三大部分:a、數據獲取,為了程序的運行,上面的問題要獲得猴子的總數,從那只猴子開始和剔除的個數;b、數據運算,需要從一堆數據中剔除相應的數據,注意邏輯的正確;c、提高程序的運行速率,少用循環多用指針。第二板斧,用C語言進行邏輯實現a、 數據獲取,通過printf和scanf進行參數的獲取。
同時注意異常時的處理,比如上面兩個if語句就是異常情況的判斷,每種異常情況對應不同的返回值,這樣便于程序過程的調試和數據的合法性。b、 /* 定義鏈表節點類型 *//* 讀入問題條件 */printf("input total num:");scanf("%d", &n);printf("from which num begin:");scanf("%d", &k);if(k>n||k==0){printf("please input the right begin num");return 1; }printf("input the out num:");scanf("%d", &m);if(m>n||m==0){ printf("please input the right del num");return 2; }
通過該步驟后,head和p(present)都成了一個“猴子圈”的鏈表。在該鏈表的構建過程中需要注意一下幾點:內存的開辟,此時遵守使用多少開辟多少的原則。如果一下開辟過多,會引起內存泄露的問題,但是,這個小程序是不會遇到這種問題了。其次是熟悉循環鏈表的構建方法:鏈表的尾巴指向鏈表的頭。這個時候有心的話還會聯想到雙向鏈表的情況。c、 /* 找到第 k 個節點 */typedef struct node{int data;struct node *next;}linklist;構建循環鏈表進行“猴子”的圓圈建設。/* 創建循環鏈表,頭節點也存信息 */head = (linklist*) malloc(sizeof(linklist));p = head;p->data = 1;p->next = p;/* 初始化循環鏈表 */for (i = 2; i <= n; i++){s = (linklist*) malloc(sizeof(linklist));s->data = i;s->next = p->next;p->next = s;p = p->next;}
找到從第幾個位置開始計數。此時,p指向開始的“猴子”。因為采用了鏈表方法,這個過程只需要關注p指針的next指向即可。a、 保存初始的“猴子”圓圈參數。p = head;for (i = 1; i <= k; i++){p = p->next;}
為什么要保留這個呢?首先要控制猴子數目,所以保留了全部的數目。其次用q(qurry)來保留剔除猴子前面的鏈表,并連接剔除猴子后的鏈表。這樣,完成了循環鏈表的元素刪除。b、 猴子查數。猴子查數是整個程序的關鍵,需要完成以下任務:a、找到開始的“猴子”數;b、刪除該“猴子”;c、將刪除掉的循環鏈表首尾連接起來。/* 保存節點總數 */total = n;printf("\nthe out num:");q = head;
通過以上數據運算,可以完成相應鏈表元素的刪除,這或許就是C語言程序的魅力所在。第三把斧,使用C語言的指針比如,本程序的鏈表指針的定義,p,s,q。/* 只剩一個節點時停止循環 */while (total != 1){/* 報數過程,p指向要刪除的節點 */for (i = 1; i < m; i++){p = p->next;}/* 打印要刪除的節點序號 */printf("[%d] ", p->data);/* q 指向 p 節點的前驅 */while (q->next != p){q = q->next;}/* 刪除 p 節點 */q->next = p->next;/* 保存被刪除節點指針 */s = p;/* p 指向被刪除節點的后繼 */p = p->next;/* 釋放被刪除的節點 */free(s);/* 節點個數減一 */total--;}/* 打印最后剩下的節點序號 */printf("\n\nthe last num:[%d] \n\n", p->data);free(p);}
linklist *head, *p, *s, *q;
我們知道,指針操作不但可以減少數據操作需要的內存,還可以提高程序的運行速度,這在另一方面達到了我們的“第三把斧”的目的。指針的優勢,或許在本程序中表現的不明顯,在大量數據和對操作速度要求比較敏感的情況下會很明顯,比如Linux內核中,就會有很好的體現。總之,對于嵌入式工程師,不但能設計出好的硬件電路,如果也能寫出好的軟件程序就會讓我們的生活更加美好。工程師們,耍起這“C語言的三把斧”!
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。
舉報投訴
-
C語言
+關注
關注
183文章
7644瀏覽量
145572
發布評論請先 登錄
相關推薦
熱點推薦
復合光纖電纜:破解“最后一公里”難題的“萬能鑰匙”
在智慧城市、工業互聯網與智能家居的浪潮中,如何高效解決設備供電與數據傳輸的“最后一公里”矛盾,成為行業痛點。復合光纖電纜憑借其“光電一體、一纜多用”的特性,正成為破解這一難題的“萬能鑰匙”。 園區
高精度力值測量的基石:電子萬能試驗機傳感器與信號調理電路技術
在電子萬能試驗機的力值測量體系中,傳感器與信號調理電路如同精密協作的“感知核心” 與 “信號管家”,共同構筑起高精度測量的堅實基礎。前者負責捕捉力的細微變化,后者則將原始信號打磨提純,二者的無縫配合
LabVIEW 變體:萬能數據容器的藝術
的使用方法
常規使用是這樣的:
)
讓我們的程序函數(方法)能夠“泛化”。
典型應用有如下兩個:
這個我前面分析
發表于 01-05 11:06
新品 | Chain Blank Chain Mount,Chain系列萬能板 結構拓展節點
節點。節點正面提供了一塊18x18mm的PCB萬能板,其內部預先焊接好了兩個互聯的HY2.0-4P接口,可直接串接到M5StackChain系列設備中且不影響設備原有功能。
PCB抄板打樣提速‘三板斧’:從掃描到交付的全鏈路優化
一站式PCBA加工廠家今天為大家講講電路板PCB抄板打樣怎么提速?電路板PCB抄板打樣提速秘籍。電路板抄板打樣提速可通過以下方法實現: ? 電路板PCB抄板打樣提速秘籍! 一、技術流程優化:縮短核心環節耗時 高精度掃描與智能圖像轉換 采用專業設備對電路板進行高分辨率掃描(精度達0.02mm),確保一次成像準確率,避免重復掃描。 通過智能軟件將掃描圖像快速轉換為可編輯的PCB文件格式,速度較傳統方式提升40%,減少人工繪制時間。 元器件識別與BOM清單
軟件的力量:玩轉電子萬能試驗機控制系統的高級技巧
電子萬能試驗機的效能發揮,不僅依賴硬件設備的性能,更離不開控制系統軟件的靈活運用。很多操作人員僅將軟件視為“參數輸入工具”,卻忽略了其隱藏的強大功能。實際上,熟練掌握軟件的高級技巧,能讓測試流程更高
HarmonyOSAI編程萬能卡片生成(一)
基于AI大模型理解開發者的卡片需求信息,通過對話式的交互智能生成HarmonyOS萬能卡片工程。
使用約束
建議從以下維度描述卡片需求:
當前不支持在生成卡片預覽圖后繼續描述需求進行增量修改。
萬能
發表于 09-08 17:09
廣州郵科三相逆變電源:從直流220V到交流380V,工業用電的“萬能轉換器”
在工業領域,電力問題就像一場“無聲的戰役”——設備突然停機、電壓不穩導致故障、臨時用電無處可接……這些問題不僅影響效率,還可能造成損失。而廣州郵科推出的三相逆變電源,正是為解決這些痛點而生。今天,我們就用“大白話”聊聊這款“電力轉換神器”,看看它如何成為工業場景的“萬能轉
米朗科技成功在“新三板”掛牌上市,股票代碼:874771
2025年5月9日正式在北交所“新三板”掛牌!股票代碼:874771,股票簡稱:米朗科技。這一里程碑事件標志著米朗科技在資本市場的新起點,也預示著企業將迎來更加廣闊的發展空間和機遇。米朗科技成立
儲能BMS通信“卡殼”?CAN轉EtherCAT讓電池數據“跑起來”
提升至±2%以內。
技術硬核:通信轉換的“三板斧”
1. 數據“翻譯”的門道
CAN的8字節數據幀如何適配EtherCAT的PDO?通過網關配置工具建立映射表,把電池溫度、電壓等信號按優先級“打包
發表于 07-18 15:32
DevEco CodeGenie 鴻蒙AI 輔助編程初次使用
上下文自動補全。 萬能卡片生成 :輔助創建 HarmonyOS 萬能卡片,提升開發效率。 二、插件獲取與安裝指南 獲取方式 訪問華為開發者聯盟??下載中心
湖北位移傳感器公司成功登陸“新三板”
5月9日,湖北米朗科技股份有限公司(簡稱:米朗科技,代碼:874771)在全國中小企業股份轉讓系統(“新三板”)成功掛牌,這是棗陽市第一家在“新三板”掛牌的本土企業。由此,該市資本市場建設實現新突破
深入理解C語言:C語言循環控制
在C語言編程中,循環結構是至關重要的,它可以讓程序重復執行特定的代碼塊,從而提高編程效率。然而,為了避免程序進入無限循環,C語言提供了多種循環控制語句,如break、continue和
突破工業接口壁壘!ARK(方舟微)DMZ42C10S讓PLC\\\"萬能適配\\\"成為現實!
突破工業接口壁壘!ARK(方舟微)DMZ42C10S讓PLC\"萬能適配\"成為現實!
發表于 03-27 15:20
萬能七彩充開關電源電器的制作
手機萬能七彩充電器的制作過程JC820型手機萬能充電器套件制成后,適合充容量為250~3000mA鋰離子、鎳氫電池;充電時,七彩燈閃爍,指示燈的顏色依次變化,發出絢麗多彩的七彩光芒,飽和后熄滅
發表于 03-26 14:17
C語言的萬能“三板斧”
評論