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

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

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

3天內不再提示

一些常見的C語言字符串操作

Q4MP_gh_c472c21 ? 來源:嵌入式ARM ? 作者:嵌入式Linux ? 2020-12-24 16:31 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

#字符串倒序輸出

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

如果len是奇數,最后一個字符就不需要倒序,如果是偶數,最后兩個字符就倒序。

#include"stdio.h"

voidrechange_str(char*str)
{
inti,len;
chartmp;
if(NULL==str){
return;
}
len=strlen(str);
for(i=0;i"hello,world";
printf("%s
",str);
rechange_str(str);
printf("%s
",str);
return(0);
}

程序輸出

hello,world
dlrow,olleh

--------------------------------
Processexitedafter0.02841secondswithreturnvalue0
請按任意鍵繼續(xù)...

#整型轉字符串

實現邏輯,每個整數看其轉換進制,從個位到十位百位都可以通過%操作加上/操作獲得,再用一個字符數組保存0-F。

用個位數對應值轉為字符,注意轉換出的字符串是反向的,還要考慮傳入的若是負數如何處理,再用翻轉字符串完成最后整個操作

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

#include"stdio.h"

char*sky_itoa(intvalue,char*str,unsignedintradix)
{
charlist[]="0123456789ABCDEF";
unsignedinttmp_value;
inti,j,k;
if(NULL==str){
returnNULL;
}
if(2!=radix&&8!=radix&&10!=radix&&16!=radix){
returnNULL;
}
i=0;
k=0;
if(radix==10&&value'-';
k=1;
}else{
tmp_value=(unsignedint)value;
}
do{
str[i++]=list[tmp_value%radix];
tmp_value/=radix;
}while(tmp_value);
str[i]='';
//翻轉
chartmp;
for(j=k;jreturnstr;
}

intmain(void)
{
inta=1254545;
charstr[100]={0};

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

程序輸出

100110010010010010001
4622221
1254545
132491

--------------------------------
Processexitedafter0.02963secondswithreturnvalue0
請按任意鍵繼續(xù)...

#字符串復制

實現邏輯,逐個賦值直到遇到''停止即可

#include"stdio.h"

char*sky_strcpy(char*dst,constchar*str)
{
if(NULL==dst||NULL==str){
returnNULL;
}
char*ret=dst;
while(*str!=''){
*dst++=*str++;
}
returnret;
}

intmain(void)
{
charstr_1[100]="hello,world";
charstr[100]={0};

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

程序輸出

str_1:hello,world
str:hello,world

--------------------------------
Processexitedafter0.03334secondswithreturnvalue0
請按任意鍵繼續(xù)...

#字符串比較

1、正常比較是否相同 實現邏輯,判斷字符串長度是否相同,若相同逐個比較字符是否相同

#include"stdio.h"

intsky_strcmp(char*dst,char*str)
{
inti,len;
if(NULL==dst||NULL==str){
return0;
}
if(strlen(dst)!=strlen(str)){
return0;
}
len=strlen(dst);
for(i=0;iif(*dst++!=*str++){
return0;
}
}
return1;
}

intmain(void)
{
charstr_1[100]="hello,world";
charstr_2[100]="hello,world";
charstr[100]="adfs";

printf("%d
",sky_strcmp(str_1,str));
printf("%d
",sky_strcmp(str_1,str_2));
return(0);
}

程序輸出

0
1

--------------------------------
Processexitedafter0.02802secondswithreturnvalue0
請按任意鍵繼續(xù)...

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

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

#include"stdio.h"

#defineCONVERT(c)(((c)>='A'&&(c)<=?'Z')???((c)?-?'A'?+?'a')?:?(c))
intsky_strcmp(char*dst,char*str)
{
inti,len;
if(NULL==dst||NULL==str){
return0;
}
if(strlen(dst)!=strlen(str)){
return0;
}
len=strlen(dst);
for(i=0;iif(CONVERT(*dst)!=CONVERT(*str)){
return0;
}
dst++;
str++;
}
return1;
}

intmain(void)
{
charstr_1[100]="heLlo,world";
charstr_2[100]="hello,world";
charstr[100]="adfs";

printf("%d
",sky_strcmp(str_1,str));
printf("%d
",sky_strcmp(str_1,str_2));
return(0);
}

程序輸出

0
1

--------------------------------
Processexitedafter0.04624secondswithreturnvalue0
請按任意鍵繼續(xù)...

#memcpy函數實現

實現邏輯,主要就是逐個賦值即可完成

1、不考慮拷貝覆蓋問題

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

void*sky_memecpy(void*dst,constvoid*str,intn)
{
if(NULL==dst||NULL==str||n<=?0)?{
??returnNULL;
}
char*pdst=(char*)dst;
char*pstr=(char*)str;
while(n--){
*pdst++=*pstr++;
}
returndst;
}

intmain(void)
{
charstr_1[100]="heLlo,world";
charstr_2[100]="sdfsdfs";
sky_memecpy(str_2,str_1,strlen(str_1));
printf("%s
",str_2);
return(0);
}

程序輸出

heLlo,world

--------------------------------
Processexitedafter0.02516secondswithreturnvalue0
請按任意鍵繼續(xù)...

2、考慮拷貝覆蓋問題

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

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

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

void*sky_memecpy_1(void*dst,constvoid*str,intn)
{
if(NULL==dst||NULL==str||n<=?0)?{
???returnNULL;
}
char*pdst=(char*)dst;
char*pstr=(char*)str;
while(n--){
*pdst++=*pstr++;
}
returndst;
}

void*sky_memecpy(void*dst,constvoid*str,intn)
{
if(NULL==dst||NULL==str||n<=?0)?{
???returnNULL;
}
char*pdst=(char*)dst;
char*pstr=(char*)str;

if(pdst>pstr&&pdstwhile(n--){
*pdst--=*pstr--;
}
}else{
while(n--){
*pdst++=*pstr++;
}
}
returndst;
}

intmain(void)
{
charstr_1[100]="heLlo,world";
charstr_2[100]="heLlo,world";
sky_memecpy_1(str_1+1,str_1,strlen(str_1));
printf("%s
",str_1);

sky_memecpy(str_2+1,str_2,strlen(str_2));
printf("%s
",str_2);
return(0);
}

程序輸出

hhhhhhhhhhhh
hheLlo,world

--------------------------------
Processexitedafter0.02773secondswithreturnvalue0
請按任意鍵繼續(xù)...

針對上面的拷貝覆蓋問題,單獨寫了一個測試程序

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

void*sky_memecpy(void*dst,constvoid*str,intn)
{
if(NULL==dst||NULL==str||n<=?0)?{
??returnNULL;
}
char*pdst=(char*)dst;
char*pstr=(char*)str;
while(n--){
printf("dst:%c--->str:%c
",*pdst,*pstr);
*pdst++=*pstr++;
}
returndst;
}

intmain(void)
{
charstr_1[100]="heLlo,world";
sky_memecpy(str_1+1,str_1,strlen(str_1));
printf("%s
",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

--------------------------------
Processexitedafter0.02575secondswithreturnvalue0
請按任意鍵繼續(xù)...

初始的時候,dst指向 e 字符,str 指向h 字符,然后每次都是dst先移動,str再移動,就出現了dst被h字符所覆蓋。好了,就這些內容,希望大家好好消化,這些代碼對面試很有幫助。

責任編輯:xj
原文標題:面試必備!常見的C語言字符串操作
文章出處:【微信公眾號:嵌入式ARM】歡迎添加關注!文章轉載請注明出處。

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

    關注

    5186

    文章

    20149

    瀏覽量

    328871
  • C語言
    +關注

    關注

    183

    文章

    7642

    瀏覽量

    144617
  • 字符串
    +關注

    關注

    1

    文章

    594

    瀏覽量

    23044

原文標題:面試必備!常見的C語言字符串操作

文章出處:【微信號:gh_c472c2199c88,微信公眾號:嵌入式微處理器】歡迎添加關注!文章轉載請注明出處。

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    C語言常見算法

    ### 字符串反轉 ```c void reverseString(char* str) { int n = strlen(str); for (int i = 0; i < n / 2
    發(fā)表于 11-24 08:29

    C語言的常量介紹

    、-13; 實型常量:13.33、-24.4; 字符常量:‘a’、‘M’ 字符串常量:”I love china!” 在C語言中,可以用
    發(fā)表于 11-24 07:12

    C語言的printf基本用法介紹

    十進制形式輸出個整數。除了 %d,printf 支持更多的格式控制,例如: %c:輸出一個字符。c 是 character 的簡寫。 %s:輸出
    發(fā)表于 11-12 07:04

    labview如何生成個帶字符串返回的dll

    labview如何生成個dll,如下圖,要求個輸入,類型是字符串,返回類型也是字符串
    發(fā)表于 08-28 23:20

    在Python中字符串逆序有幾種方式,代碼是什么

    對于個給定的字符串,逆序輸出,這個任務對于python來說是種很簡單的操作,畢竟強大的列表和字符串處理的
    的頭像 發(fā)表于 08-28 14:44 ?784次閱讀

    harmony-utils之StrUtil,字符串工具類

    harmony-utils之StrUtil,字符串工具類 harmony-utils 簡介與說明 [harmony-utils] 款功能豐富且極易上手的HarmonyOS工具庫,借助眾多實用工具類
    的頭像 發(fā)表于 07-03 11:32 ?369次閱讀

    對CY7C65211有一些疑問求解答

    我對 CY7C65211 有一些疑問。 (1)關于制造商字符串,評估套件(CYUSB234)顯示“ CYPRESS? Semiconductor”,但我認為從現在開始發(fā)貨的設備的默認值將更改
    發(fā)表于 05-06 09:28

    STM32C031C6使用的是UART2通訊,通過printf()函數發(fā)送字符串時,漢字錯碼怎么解決?

    使用的是UART2通訊,通過printf()函數發(fā)送字符串時,漢字錯碼(見下圖),應該是KEIL哪里沒有設置好的問題。 啟用了UART2的中斷接收,可以接收到串口調試助手的數據,但是緩存區(qū)的指針沒有歸零,下次接收時緩存區(qū)中的內容接續(xù)(如下圖所示),不知道用什么命令來清除緩存區(qū)(即讓指針歸零)。
    發(fā)表于 03-07 12:30

    基于OpenHarmony標準系統(tǒng)的C++公共基礎類庫案例:ThreadPoll

    。每個線程每秒打印1段字符串,10秒后停止。2、基礎知識C++公共基礎類庫為標準系統(tǒng)提供了一些常用的C++開發(fā)工具類,包括:文件、路徑、字符串
    的頭像 發(fā)表于 02-10 18:09 ?600次閱讀
    基于OpenHarmony標準系統(tǒng)的<b class='flag-5'>C</b>++公共基礎類庫案例:ThreadPoll

    字符串在數據庫中的存儲方式

    數據庫是現代信息技術中存儲和管理數據的核心組件。字符串作為最常見的數據類型之,在數據庫中的存儲方式對其性能和可擴展性有著重要影響。 數據類型 固定長度字符串 :如CHAR類型,它為每
    的頭像 發(fā)表于 01-07 15:41 ?1252次閱讀

    字符串在編程中的應用實例

    字符串在編程中有著廣泛的應用,它們被用于表示文本數據、處理用戶輸入、構建動態(tài)內容等。以下是一些字符串在編程中的應用實例: 1. 用戶輸入與輸出 用戶輸入 :程序通常需要從用戶那里獲取輸入,這些輸入通
    的頭像 發(fā)表于 01-07 15:33 ?1131次閱讀

    字符串字符數組的區(qū)別

    在編程語言中,字符串字符數組是兩種基本的數據結構,它們都用于存儲和處理文本數據。盡管它們在功能上有定的重疊,但在內部表示、操作方式和使用
    的頭像 發(fā)表于 01-07 15:29 ?1679次閱讀

    字符串反轉的實現方式

    在編程中,字符串反轉是個基礎而重要的操作,它涉及到將一個字符串中的字符順序顛倒過來。這個操作
    的頭像 發(fā)表于 01-07 15:27 ?1244次閱讀

    字符串處理方法 字符串轉數字的實現

    在編程中,將字符串轉換為數字是常見的需求。不同的編程語言有不同的方法來實現這功能。以下是一些
    的頭像 發(fā)表于 01-07 15:26 ?1400次閱讀

    C語言筆試題

    ("this is g ..."); return 2;}int main(){ printf("%d %d", f(), g()); return 0;} 代碼很簡單,函數 f 輸出一個字符串,返回整數 1
    的頭像 發(fā)表于 12-30 09:48 ?675次閱讀