當(dāng)前位置:首頁 > 公眾號精選 > 嵌入式微處理器
[導(dǎo)讀]C語言字符串操作知識!

#字符串倒序輸出

實(shí)現(xiàn)邏輯,通過strlen獲取字符串長度,然后通過 len/2 進(jìn)行交叉賦值,這里需要注意,不需要考慮len是奇數(shù)還是偶數(shù)的問題。

如果len是奇數(shù),最后一個(gè)字符就不需要倒序,如果是偶數(shù),最后兩個(gè)字符就倒序。

#include?"stdio.h"

void?rechange_str(char?*str)
{
?int?i,?len;
?char?tmp;
?if?(NULL?==?str)?{
??return?;
?}
?len?=?strlen(str);
?for?(i?=?0;?i???tmp?=?str[i];
??str[i]?=?str[len-i-1];
??str[len-i-1]?=?tmp;
?}
}

int?main(void)
{
?char?str[20]?=?"hello,world";
?printf("%s\n",str);
?rechange_str(str);
?printf("%s\n",str);
?return?(0);
}?

程序輸出

hello,world
dlrow,olleh

--------------------------------
Process?exited?after?0.02841?seconds?with?return?value?0
請按任意鍵繼續(xù).?.?.

#整型轉(zhuǎn)字符串

實(shí)現(xiàn)邏輯,每個(gè)整數(shù)看其轉(zhuǎn)換進(jìn)制,從個(gè)位到十位百位都可以通過%操作加上/操作獲得,再用一個(gè)字符數(shù)組保存0-F。

用個(gè)位數(shù)對應(yīng)值轉(zhuǎn)為字符,注意轉(zhuǎn)換出的字符串是反向的,還要考慮傳入的若是負(fù)數(shù)如何處理,再用翻轉(zhuǎn)字符串完成最后整個(gè)操作

下面這段代碼需要好好研究一下,最好自己運(yùn)行試試。

#include?"stdio.h"

char?*sky_itoa(int?value,?char?*str,?unsigned?int?radix)
{
?char?list[]?=?"0123456789ABCDEF";
?unsigned?int?tmp_value;
?int?i,?j,?k;
?if?(NULL?==?str)?{
??return?NULL;
?}
?if?(2?!=?radix?&&?8?!=?radix?&&?10?!=?radix?&&?16?!=?radix)?{
??return?NULL;
?}
?i?=?0;
?k?=?0;
?if?(radix?==?10?&&?value???tmp_value?=?(unsigned?int)(0?-?value);
??str[i++]?=?'-';
??k?=?1;
?}?else?{
??tmp_value?=?(unsigned?int)value;
?}
?do?{
??str[i++]?=?list[tmp_value%radix];
??tmp_value?/=?radix;
?}?while(tmp_value);
?str[i]?=?'\0';
?//翻轉(zhuǎn)
?char?tmp;
?for?(j?=?k;?j???tmp?=?str[j];
??str[j]?=?str[i+k-j-1];
??str[i+k-j-1]?=?tmp;
?}
?return?str;
}

int?main(void)
{
?int?a?=?1254545;
?char?str[100]?={0};

?printf("%s\n",sky_itoa(a,str,2));
?printf("%s\n",sky_itoa(a,str,8));
?printf("%s\n",sky_itoa(a,str,10));
?printf("%s\n",sky_itoa(a,str,16));
?return?(0);
}?

程序輸出

100110010010010010001
4622221
1254545
132491

--------------------------------
Process?exited?after?0.02963?seconds?with?return?value?0
請按任意鍵繼續(xù).?.?.

#字符串復(fù)制

實(shí)現(xiàn)邏輯,逐個(gè)賦值直到遇到'\0'停止即可

#include?"stdio.h"

char?*sky_strcpy(char?*dst,?const?char?*str)
{
?if?(NULL?==?dst?||??NULL?==?str)?{
??return?NULL;
?}
?char?*ret?=?dst;
?while?(*str?!=?'\0')?{
??*dst?++?=?*str?++;
?}
?return?ret;?
}?

int?main(void)
{
?char?str_1[100]?=?"hello,world";
?char?str[100]?={0};

?sky_strcpy(str,str_1);
?printf("str_1:%s\n",str_1);
?printf("str:%s\n",str);
?return?(0);
}?

程序輸出

str_1:hello,world
str:hello,world

--------------------------------
Process?exited?after?0.03334?seconds?with?return?value?0
請按任意鍵繼續(xù).?.?.

#字符串比較

1、正常比較是否相同 實(shí)現(xiàn)邏輯,判斷字符串長度是否相同,若相同逐個(gè)比較字符是否相同

#include?"stdio.h"

int?sky_strcmp(char?*dst,?char?*str)
{
?int?i,?len;
?if?(NULL?==?dst?||?NULL?==?str)?{
??return?0;
?}
?if?(strlen(dst)?!=?strlen(str))?{
??return?0;
?}
?len?=?strlen(dst);
?for?(i?=?0;?i???if?(*dst++?!=?*str++)?{
???return?0;
??}
?}
?return?1;
}?

int?main(void)
{
?char?str_1[100]?=?"hello,world";
?char?str_2[100]?=?"hello,world";
?char?str[100]?=?"adfs";
?
?printf("%d\n",sky_strcmp(str_1,str));
?printf("%d\n",sky_strcmp(str_1,str_2));
?return?(0);
}?

程序輸出

0
1

--------------------------------
Process?exited?after?0.02802?seconds?with?return?value?0
請按任意鍵繼續(xù).?.?.

2、忽略大小寫字符串比較

實(shí)現(xiàn)邏輯,在比較字符時(shí)可以將其統(tǒng)一轉(zhuǎn)換為大寫或小寫,然后再進(jìn)行比對即可,和正常對比無其他不同

?#include?"stdio.h"
?
?#define?CONVERT(c)?(((c)?>=?'A'?&&?(c)?<=?'Z')???((c)?-?'A'?+?'a')?:?(c))
?int?sky_strcmp(char?*dst,?char?*str)
?{
??int?i,?len;
??if?(NULL?==?dst?||?NULL?==?str)?{
???return?0;
??}
??if?(strlen(dst)?!=?strlen(str))?{
???return?0;
??}
??len?=?strlen(dst);
??for?(i?=?0;?i????if?(CONVERT(*dst)?!=?CONVERT(*str))?{
????return?0;
???}
???dst?++;
???str?++;
??}
??return?1;
?}?
?
?int?main(void)
?{
??char?str_1[100]?=?"heLlo,world";
??char?str_2[100]?=?"hello,world";
??char?str[100]?=?"adfs";
??
??printf("%d\n",sky_strcmp(str_1,str));
??printf("%d\n",sky_strcmp(str_1,str_2));
??return?(0);
?}?

程序輸出

0
1

--------------------------------
Process?exited?after?0.04624?seconds?with?return?value?0
請按任意鍵繼續(xù).?.?.

#memcpy函數(shù)實(shí)現(xiàn)

實(shí)現(xiàn)邏輯,主要就是逐個(gè)賦值即可完成?

1、不考慮拷貝覆蓋問題

#include?"stdio.h"
#include?"string.h"

void?*sky_memecpy(void?*dst,?const?void?*str,?int?n)
{
?if?(NULL?==?dst?||?NULL?==?str?||?n?<=?0)?{
??return?NULL;
?}
?char?*pdst?=?(char?*)dst;
?char?*pstr?=?(char?*)str;
?while?(n?--)?{
??*pdst?++?=?*pstr?++;
?}
?return?dst;
}

int?main(void)
{
?char?str_1[100]?=?"heLlo,world";
?char?str_2[100]?=?"sdfsdfs";
?sky_memecpy(str_2,str_1,strlen(str_1));
?printf("%s\n",str_2);
?return?(0);
}?

程序輸出

heLlo,world

--------------------------------
Process?exited?after?0.02516?seconds?with?return?value?0
請按任意鍵繼續(xù).?.?.

2、考慮拷貝覆蓋問題

拷貝覆蓋是我們在拷貝字符串的時(shí)候需要注意的一個(gè)問題,我下面的示例程序,使用第一個(gè)函數(shù)的時(shí)候,就出現(xiàn)了問題,使用第二個(gè)函數(shù)就沒有出現(xiàn)問題。

原因是,我們源字符串和目的字符串的地址都是一樣的,我們希望把字符串往后移動一個(gè)位置,但是實(shí)際上出現(xiàn)了問題。

?#include?"stdio.h"
?#include?"string.h"
?
?void?*sky_memecpy_1(void?*dst,?const?void?*str,?int?n)
?{
??if?(NULL?==?dst?||?NULL?==?str?||?n?<=?0)?{
???return?NULL;
??}
??char?*pdst?=?(char?*)dst;
??char?*pstr?=?(char?*)str;
??while?(n?--)?{
???*pdst?++?=?*pstr?++;
??}
??return?dst;
?}
?
?void?*sky_memecpy(void?*dst,?const?void?*str,?int?n)
?{
??if?(NULL?==?dst?||?NULL?==?str?||?n?<=?0)?{
???return?NULL;
??}
??char?*pdst?=?(char?*)dst;
??char?*pstr?=?(char?*)str;
???
??if?(pdst?>?pstr?&&?pdst????pdst?=?pdst?+?n?-?1;
???pstr?=?pstr?+?n?-?1;
???while?(n?--)?{
????*pdst?--?=?*pstr?--;
???}
??}?else?{
???while?(n?--)?{
????*pdst?++?=?*pstr?++;
???}
??}
??return?dst;
?}
?
?int?main(void)
?{
??char?str_1[100]?=?"heLlo,world";
??char?str_2[100]?=?"heLlo,world";
??sky_memecpy_1(str_1+1,str_1,strlen(str_1));
??printf("%s\n",str_1);
??
??sky_memecpy(str_2+1,str_2,strlen(str_2));
??printf("%s\n",str_2);
??return?(0);
?}?

程序輸出

hhhhhhhhhhhh
hheLlo,world

--------------------------------
Process?exited?after?0.02773?seconds?with?return?value?0
請按任意鍵繼續(xù).?.?.

針對上面的拷貝覆蓋問題,單獨(dú)寫了一個(gè)測試程序

#include?"stdio.h"
#include?"string.h"

void?*sky_memecpy(void?*dst,?const?void?*str,?int?n)
{
?if?(NULL?==?dst?||?NULL?==?str?||?n?<=?0)?{
??return?NULL;
?}
?char?*pdst?=?(char?*)dst;
?char?*pstr?=?(char?*)str;
?while?(n?--)?{
??printf("dst:%c--->str:%c\n",*pdst,*pstr);
??*pdst?++?=?*pstr?++;
?}
?return?dst;
}

int?main(void)
{
?char?str_1[100]?=?"heLlo,world";
?sky_memecpy(str_1+1,str_1,strlen(str_1));
?printf("%s\n",str_1);
?return?(0);
}?

程序輸出

dst:e--->str:h
dst:L--->str:h
dst:l--->str:h
dst:o--->str:h
dst:,--->str:h
dst:w--->str:h
dst:o--->str:h
dst:r--->str:h
dst:l--->str:h
dst:d--->str:h
dst:?--->str:h
hhhhhhhhhhhh

--------------------------------
Process?exited?after?0.02575?seconds?with?return?value?0
請按任意鍵繼續(xù).?.?.

初始的時(shí)候,dst指向 e 字符,str 指向h 字符,然后每次都是dst先移動,str再移動,就出現(xiàn)了dst被h字符所覆蓋。

好了,就這些內(nèi)容,希望大家好好消化,這些代碼對面試很有幫助。


END

來源:嵌入式Linux

版權(quán)歸原作者所有,如有侵權(quán),請聯(lián)系刪除。

推薦閱讀

飛機(jī)上一般是什么操作系統(tǒng)?

高速CAN、容錯(cuò)CAN、LIN總線有什么區(qū)別?

大佬終于把鴻蒙OS講明白了,收藏了!

免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺僅提供信息存儲服務(wù)。文章僅代表作者個(gè)人觀點(diǎn),不代表本平臺立場,如有問題,請聯(lián)系我們,謝謝!

嵌入式ARM

掃描二維碼,關(guān)注更多精彩內(nèi)容

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運(yùn)營商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉