欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語言中strlen() strcpy() strcat() strcmp()函數(shù)的實(shí)現(xiàn)方法

 更新時(shí)間:2017年08月07日 16:26:44   作者:曉百  
這篇文章主要介紹了C語言中strlen() strcpy() strcat() strcmp()函數(shù)的實(shí)現(xiàn)方法,需要的朋友可以參考下

strlen函數(shù)原型:unsigned int strlen(const char *);返回的是字符串中第一個(gè)\0之前的字符個(gè)數(shù)。

  1.strcat函數(shù)原型char* strcat(char* dest,const char* src); 進(jìn)行字符串的拼接,將第二個(gè)字符串連接到第一個(gè)字符串中第一個(gè)出現(xiàn)\0開始的地方。返回的是拼接后字符的首地址。并不檢查第一個(gè)數(shù)組的大小是否可以容納第二個(gè)字符串。如果第一個(gè)數(shù)組的已分配的內(nèi)存不夠容納第二個(gè)字符串,則多出來的字符將會(huì)溢出到相鄰的內(nèi)存單元。

  2.strncat函數(shù)原型:strncat(dest,src,maxsize)功能跟strcat一致,不過它帶有一個(gè)maxsize的參數(shù),設(shè)置容納的最大的字符長(zhǎng)度。如在遇到\0之前達(dá)到了最大字符長(zhǎng)度,則會(huì)只連接最大字符長(zhǎng)度個(gè)數(shù)的字符。

  3.strcpy函數(shù)原型 char* strcpy(char* dest,const char* src); 將第二個(gè)字符串\0之前的字符復(fù)制到第一個(gè)內(nèi)存地址內(nèi)。返回的是復(fù)制后的字符串的首地址。有char*返回值是為了函數(shù)能夠支持鏈?zhǔn)奖磉_(dá)式,增加了函數(shù)的“附加值”。 char a[7]="abcdef",char b[5]="xyz";

strcpy(a,b)函數(shù) 當(dāng)將后面的數(shù)組賦值給前面那個(gè)時(shí)侯 除去五個(gè)元素后,從下標(biāo)為5開始的元素仍舊是之前a[5]的元素。

  4.strncpy(str1,str2,numbe)函數(shù)是將str2中的前number個(gè)字符賦給str1,或是將\0之前的字符賦給str1.

  5.strcmp函數(shù)原型 int strcmp(const char *src1,const char* src2);進(jìn)行兩個(gè)字符串中從第一個(gè)開始的ASCII碼的比較。遇到\0或者不一致時(shí)退出,如果前者大于后者返回1,小于返回-1 如果在兩個(gè)中的任何一個(gè)的\0之前都保持一致,則返回0. 當(dāng)src或src遇到\0時(shí)即停止比較.strcmp比較的是字符串,不是字符,字符之間的比較可以直接用==

  6.strncmp(str1,str2,numbe)函數(shù)在strcmp的基礎(chǔ)上多了一個(gè)int參數(shù),即指定比較前幾個(gè)字符是否相等。

注意:對(duì)于strcat函數(shù)和strcpy函數(shù)并沒有進(jìn)行邊界大小的限定,所以在用時(shí)要注意是否足夠內(nèi)存。

對(duì)于內(nèi)存問題:用memcpy函數(shù)更為安全。

memcpy函數(shù)原型void * memcpy(void *desc,const char* src,unsigned int count);相對(duì)于strcpy函數(shù),memcpy函數(shù)并不是將\0前面的字符復(fù)制給desc,而是將前count個(gè)字符進(jìn)行復(fù)制。

memcmp函數(shù),函數(shù)原型: int memcmp(void *buf1, void *buf2, unsigned int count);也是對(duì)兩個(gè)字符串之前的count個(gè)字符進(jìn)行比較。

例子:

#include<stdio.h>
#include<assert.h>
//strlen
unsigned int strlenght(const char* src)
{
 unsigned int len=0;
 assert(src!=0);
 while(*src++)
 {
  len++;
 }
 return len;
}
//strcat
char* strlink(char* dest,char* src)
{
 char *tmp=dest;
 assert((dest!= NULL)&&(src!=NULL));
 while(*dest++);
 *dest--;
 while(*dest++=*src++);
  return tmp;
}
//strcpy
char* strcopy(char* dest,const char* src)
{
 char *tmp=dest;
 assert((dest!=NULL)&&(src!=NULL));
 while(*src)
 {
  *dest++=*src++;
 }
 *dest='\0';
 return tmp;
}
//strcmp
int strcompare(const char* src1,const char* src2)
{
 int x=0;
 while(!(x = *src1-*src2) && *src1)
 {
  src1++;
  src2++;
 }
 if(x>0)
  x = 1;
 if(x<0)
  x = -1;
 return x;
}
void main()
{
 char arr[100] = "It's wonderful weather!!";
 char arr1[20] = "I am\0 fine!";
 char *arr2;
 printf("%s的長(zhǎng)度為:%d\n",arr,strlenght(arr));
 printf("%s的長(zhǎng)度為:%d\n",arr1,strlenght(arr1));
 arr2 = strlink(arr,arr1);
 printf("%s\n%s\n",arr2,arr);
 printf("%s %s\n %d\n",arr1,arr,strcompare(arr1,arr));
 printf("%s\n%s\n",arr,strcopy(arr,arr1));
}

總結(jié)

以上所述是小編給大家介紹的C語言中strlen() strcpy() strcat() strcmp()函數(shù)的實(shí)現(xiàn)方法,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

相關(guān)文章

  • C語言字符串函數(shù)操作(strlen,strcpy,strcat,strcmp)詳解

    C語言字符串函數(shù)操作(strlen,strcpy,strcat,strcmp)詳解

    大家好,本篇文章主要講的是C語言字符串函數(shù)操作(strlen,strcpy,strcat,strcmp)詳解,感興趣的同學(xué)趕快來看一看吧
    2021-12-12
  • C++實(shí)現(xiàn)多人聊天室

    C++實(shí)現(xiàn)多人聊天室

    這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)多人聊天室,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-06-06
  • C語言圖文并茂講解分支語句用法

    C語言圖文并茂講解分支語句用法

    分支結(jié)構(gòu)的執(zhí)行是依據(jù)一定的條件選擇執(zhí)行路徑,而不是嚴(yán)格按照語句出現(xiàn)的物理順序。分支結(jié)構(gòu)的程序設(shè)計(jì)方法的關(guān)鍵在于構(gòu)造合適的分支條件和分析程序流程,根據(jù)不同的程序流程選擇適當(dāng)?shù)姆种дZ句
    2022-04-04
  • C++實(shí)例分析講解臨時(shí)對(duì)象與右值引用的用法

    C++實(shí)例分析講解臨時(shí)對(duì)象與右值引用的用法

    對(duì)性能來說,許多的問題都需要和出現(xiàn)頻率及本身執(zhí)行一次的開銷掛鉤,有些問題雖然看似比較開銷較大,但是很少會(huì)執(zhí)行到,那也不會(huì)對(duì)程序有大的影響;同樣一個(gè)很小開銷的函數(shù)執(zhí)行很頻繁,同樣會(huì)對(duì)程序的執(zhí)行效率有很大影響。本章中作者主要根據(jù)臨時(shí)對(duì)象來闡述這樣一個(gè)觀點(diǎn)
    2022-08-08
  • C++回溯與分支限界算法分別解決背包問題詳解

    C++回溯與分支限界算法分別解決背包問題詳解

    給定n種物品和一背包。物品i的重量是wi,其價(jià)值為vi,背包的容量為C。問應(yīng)如何選擇裝入背包的物品,使得裝入背包中物品的總價(jià)值最大?下面我們分別用回溯與分支限界方法解決
    2022-06-06
  • 基于VC 6.0使用C語言實(shí)現(xiàn)俄羅斯方塊

    基于VC 6.0使用C語言實(shí)現(xiàn)俄羅斯方塊

    這篇文章主要為大家詳細(xì)介紹了基于VC 6.0使用C語言實(shí)現(xiàn)俄羅斯方塊,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-06-06
  • C語言實(shí)現(xiàn)學(xué)生信息管理系統(tǒng)(多文件)

    C語言實(shí)現(xiàn)學(xué)生信息管理系統(tǒng)(多文件)

    這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)學(xué)生信息管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-12-12
  • C語言實(shí)現(xiàn)循環(huán)鏈表

    C語言實(shí)現(xiàn)循環(huán)鏈表

    這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)循環(huán)鏈表,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-07-07
  • c語言全局變量和局部變量問題及解決匯總

    c語言全局變量和局部變量問題及解決匯總

    局部變量能否和全局變量重名,如何引用一個(gè)已經(jīng)定義過的全局變量,全局變量可不可以定義在可被多個(gè).C文件包含的頭文件中?為什么?,接下來為您一一介紹
    2013-01-01
  • C語言修煉之路函數(shù)篇真題訓(xùn)練下

    C語言修煉之路函數(shù)篇真題訓(xùn)練下

    函數(shù)是一組一起執(zhí)行一個(gè)任務(wù)的語句。每個(gè) C 程序都至少有一個(gè)函數(shù),即主函數(shù) main() ,所有簡(jiǎn)單的程序都可以定義其他額外的函數(shù)
    2022-03-03

最新評(píng)論