字符串函數—strcat()與strncat詳解及實現

分類:編程 時間:2017-02-06

一、strcat()與strncat()

strcat():strcat(dest,src); strcat把src所指向的字符添加到dest結尾處(覆蓋原dest結尾處的'\0'),並添加新的'\0'。

說明:src和dest所指內存區域不可以重疊,並且dest必須有足夠的空間來容納src的字符串,返回指向dest的指針。

strncat():strncat(dest,src,n); strncat把速溶茶所指向的字符的前n個字符添加到dest結尾處(覆蓋原dest結尾處的'\0'),並添加新的'\0'。

說明:src和dest所指內存區域不可以重疊,並且dest必須有足夠的空間來容納src的前n個字符串,返回指向dest的指針。

1.具體實例:

#include<iostream>
#include<string>

using  namespace std;

int main()
{
	//以下strcat
	char a[30]="lanzhihui is ";

	char b[]="a good boy!";

	strcat(a,b); //如果數組a的剩余存儲空間不足以存放數組b,則出錯。
	             //數組a中字符串的成為連接後的字符串
	
	cout<<"strcat(a,b):"<<a<<endl;


	//以下strncat
	char c[30]="Hello ";
	char d[]="world!";
	strncat(c,d,sizeof(d)-1);

	cout<<"strncat(c,d):"<<c<<endl;

	strncat(c,d,30);   //只要是c中空間足夠大,可以存儲d中的字符串,n為任何值都可以(實際上連接是按照d數組中的字符個數計算的)

	cout<<"strncat(c,d):"<<c<<endl;

	system("pause");
	return 0;
}

2.以'\0'結束讀取、連接

#include<iostream>
#include<string>

using namespace std;

int main()
{
	char a[100]="lanzhi\0hui is ";

	char b[]="a good \0boy!";

	strcat(a,b);//連接以'\0'結束,即數組a以'\0'停止,數組b以'\0'停止

	cout<<a<<endl;

	system("pause");
	return 0;
}

二、strcat()與strncat()的具體實現

#include<iostream>
#include<assert.h>

using  namespace std;

char *strcat_m(char *dest,const char *str)
{
	assert((dest!=NULL)&&(str!=NULL));
	char *cp=dest;

	while(*cp!='\0') ++cp;

	while((*cp++=*str++)!='\0')
	{
		//
	}

	return dest;
}

char *strncat_m(char *dest,const char *str,int n)
{
	assert((dest!=NULL)&&(str!=NULL));
	char *cp=dest;

	while(*cp!='\0') ++cp;

	while(n&&(*cp++=*str++)!='\0')
	{
		--n;
	}

	return dest;
}

int main()
{
	//以下strcat
	char a[30]="lanzhihui is ";

	char b[]="a good boy!";

	strcat_m(a,b); 
	
	cout<<"strcat(a,b):"<<a<<endl;


	//以下strncat
	char c[30]="Hello ";
	char d[]="world!";
	strncat_m(c,d,sizeof(d)-1);

	cout<<"strncat(c,d):"<<c<<endl;

	strncat_m(c,d,30);   

	cout<<"strncat(c,d):"<<c<<endl;

	system("pause");
	return 0;
}

與調用原函數結果一樣,strcat_m()與strncat_m()函數功能實現。


Tags: include system return 字符串 world

文章來源:


ads
ads

相關文章
ads

相關文章

ad