淺談C語(yǔ)言中strcpy,strcmp,strlen,strcat函數(shù)原型
實(shí)例如下:
//strcat(dest,src)把src所指字符串添加到dest結(jié)尾處(覆蓋dest結(jié)尾處的'\0')并添加'\0'
char *strcat(char * strDest, const char *strSrc)
{
char *res=strDest;
assert((strDest!=NULL)&&(strSrc!=NULL));
while(*strDest)strDest++;
while(*strDest=*strSrc)
{
strDest++;
strSrc++;
}
return res;
}
//strcpy(dest,src)把從src地址開始且含有null結(jié)束符的字符串復(fù)制到以dest開始的地址空間
char *strcpy(char *strDest, const char *strSrc)
{
char *res=strDest;
assert((strDest!=NULL)&&(strSrc!=NULL));
while((*strDest=*strSrc)!='\0')
{
strDest++;
strSrc++;
}
return res;
}
今天去文思創(chuàng)新面試,考官問了我一個(gè)簡(jiǎn)單的實(shí)現(xiàn),即:自己編寫strcpm的實(shí)現(xiàn),IBM曾經(jīng)也考過寫strcpy原型,這幾個(gè)函數(shù)在面試的時(shí)候經(jīng)常被考到,很具有代表性,突然被問起還真有點(diǎn)措手不及呢。現(xiàn)在記下供大家學(xué)習(xí)和以后溫習(xí):(下面的程序經(jīng)本人通過)
1、Strcat函數(shù)原型如下:
char *strcat(char *strDest, const char *strScr) //將源字符串加const,表明其為輸入?yún)?shù)
{
char * address = strDest; //該語(yǔ)句若放在assert之后,編譯出錯(cuò)
assert((strDest != NULL) && (strScr != NULL)); //對(duì)源地址和目的地址加非0斷言
while(*strDest) //是while(*strDest!='/0')的簡(jiǎn)化形式
{ //若使用while(*strDest++),則會(huì)出錯(cuò),因?yàn)?+是不受循環(huán)
strDest++; //約束的。所以要在循環(huán)體內(nèi)++;因?yàn)橐?strDest最后指
} //向該字符串的結(jié)束標(biāo)志'/0'。
while(*strDest++ = *strScr++)
{
NULL; //該循環(huán)條件內(nèi)可以用++,
} //此處可以加語(yǔ)句*strDest='/0';有無必要?
return address; //為了實(shí)現(xiàn)鏈?zhǔn)讲僮?,將目的地址返?
}
以下是在VC6.0中調(diào)試的例子,函數(shù)名用strcata代替。
#include <stdio.h>
#include <assert.h>
char *strcata(char *strDest,const char *strScr)
{
char * address = strDest;
assert((strDest != NULL) && (strScr != NULL));
while(*strDest)
{
strDest++;
}
while(*strDest++ = *strScr++)
{
NULL;
}
return address;
}
void main()
{
char str1[100]={"i love"};
char str2[50]={"China"};
printf("%s/n",strcata(str1,str2));
}
2、Strcpy函數(shù)原型如下:
char *strcpy(char *strDest, const char *strScr)
{
char *address=strDest;
assert((strDest != NULL) && (strScr != NULL));
while(*strScr) //是while(*strScr != '/0')的簡(jiǎn)化形式;
{
*strDest++ = *strScr++;
}
*strDest = '/0'; //當(dāng)strScr字符串長(zhǎng)度小于原strDest字符串長(zhǎng)度
return address; //時(shí),如果沒有改語(yǔ)句,就會(huì)出錯(cuò)了。
}
以下是在VC6.0中調(diào)試的例子,函數(shù)名用strcpya代替。
#include <stdio.h>
#include <assert.h>
char *strcpya(char *strDest, const char *strScr)
{
char *address = strDest;
assert((strDest != NULL) && (strScr != NULL));
while(*strScr)
{
*strDest++ = *strScr++;
}
*strDest = '/0';
return address;
}
void main()
{
char str1[100]={"i love"};
char str2[50]={"China"};
printf("%s/n",strcpya(str1,str2));
}
3、Strcmp函數(shù)原型如下:
int strcmp (const char *str1,const char *str2)
{
int len = 0;
assert((str1 != '/0') && (str2 != '/0'));
while(*str1 && *str2 && (*str1 == *str2))
{
str1++;
str2++;
}
return *str1-*str2;
}
以下是在VC6.0中調(diào)試的例子,函數(shù)名用strcmpa代替。
#include <stdio.h>
#include <assert.h>
int strcmpa (const char *str1,const char *str2)
{
int len = 0;
assert((str1 != '/0') && (str2 != '/0'));
while(*str1 && *str2 && (*str1==*str2))
{
str1++;
str2++;
}
return *str1-*str2;
}
void main()
{
char str1[100] = {"i love"};
char str2[50] = {"China "};
printf("%d/n",strcmpa(str1,str2));
}
4、Strlen函數(shù)原型如下:
int strlen(const char *str)
{
int len = 0;
assert(str != NULL);
while(*str++)
{
len++;
}
return len;
}
以下是在VC6.0中調(diào)試的例子,函數(shù)名用strlena代替。
#include <stdio.h>
#include <assert.h>
int strlena(const char *str)
{
int len = 0;
assert(str != NULL);
while(*str++)
{
len++;
}
return len;
}
void main()
{
char str1[100] = {"i love"};
char str2[50] = {"China "};
printf("%d/n",strlena(str1));
}
以上這篇淺談C語(yǔ)言中strcpy,strcmp,strlen,strcat函數(shù)原型就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
10行C++代碼實(shí)現(xiàn)高性能HTTP服務(wù)
這篇文章主要介紹了10行C++代碼如何實(shí)現(xiàn)高性能HTTP服務(wù),幫助大家更好的理解和學(xué)習(xí)使用c++,感興趣的朋友可以了解下2021-04-04
C語(yǔ)言實(shí)現(xiàn)的程序員老黃歷實(shí)例
這篇文章主要介紹了C語(yǔ)言實(shí)現(xiàn)的程序員老黃歷,涉及日期的判定及流程控制的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-07-07
C語(yǔ)言之實(shí)現(xiàn)單鏈表指定結(jié)點(diǎn)的插入方式
這篇文章主要介紹了C語(yǔ)言之實(shí)現(xiàn)單鏈表指定結(jié)點(diǎn)的插入方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-07-07
Microsoft Visual C++ 6.0開發(fā)環(huán)境搭建教程
這篇文章主要為大家詳細(xì)介紹了Microsoft Visual C++ 6.0開發(fā)環(huán)境搭建教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-04-04
C/C++ 連接MySql數(shù)據(jù)庫(kù)的方法
本文對(duì)如何使用MySql的API連接MySql數(shù)據(jù)庫(kù),開發(fā)環(huán)境為VS2008,需要的朋友可以參考下2017-06-06
C++執(zhí)行shell命令的多種實(shí)現(xiàn)方法
在linux系統(tǒng)下,用C++程序執(zhí)行shell命令有多種方式,主要介紹了3中方法,具有一定的參考價(jià)值,感興趣的可以了解一下2021-11-11
超詳細(xì)解析C++實(shí)現(xiàn)快速排序算法的方法
快速排序是比較快的排序方法。它的基本思想是通過一組排序?qū)⒁判虻臄?shù)據(jù)分割成獨(dú)立的兩部分,本文將用C++實(shí)現(xiàn)快速排序算法,需要的可以參考一下2022-09-09

