❤️强烈推荐人工智能学习网站❤️

         这4个字符串处理函数是我们经常用到的,下面我们来了解释一下它们之间的区别。

strcpy:只用于字符串的复制,以\0为结束符,且\0也一并拷贝过去。不需要在末尾加上\0。

 

#include<stdio.h>
#include <string.h>


int main()
{
	char str1[10];
	char str2[10] = "abcefg";

	strcpy(str1,str2);
	printf("%s\n",str1);

	return 0;
}

打印:abcefg

 

 

strncpy:只用于字符串的复制,但可以指定长度,以\0为结束符。这里要值得注意的是,遇到\0立即结束复制,不管复制字符的个数是否达到指定长度。当复制长度小于被复制字符串长度时,要注意手动加上\0。

 

#include<stdio.h>
#include<string.h>

int main()
{
	char str1[30];
	char str2[30] = "abcdef\0ghijklmn";
	strncpy(str1,str2,3);
	str1[3] = '\0';
	printf("%s\n", str1);

	return 0;
}

打印:abc

 

 

再看:

 

#include<stdio.h>
#include<string.h>

int main()
{
	char str1[30];
	char str2[30] = "abcdef\0ghijklmn";
	strncpy(str1,str2,10);
	//str1[3] = '\0';
	printf("%s\n", str1);

	return 0;
}

打印:abcdef

 

复制的过程中遇到\0,则停止了复制。复制的长度超过了\0,加上之前字符的长度,所以不用手动加上\0。

 

memcpy:可以复制任意内容,如字符串数组,整型,结构体,类等。它与strncpy的区别是遇到\0或其他结束符不会停止复制,一直复制到指定长度为止。

 

#include <stdio.h>
#include <string.h>

int main()
{
	char str1[10];
	char str2[10] = "abc\0def";
	memcpy(str1,str2, 5);

	for (int i = 0; i < 5; i++)
	{
		printf("%c\n",str1[i]);
	}

	return 0;
}

打印:a

 

            b

            c

 

           d

中间有一个空格,代表\0对应的字符。这里不能用printf("%s\n",str1)来测试,因为中间有\0,是字符串结束符。

 

当复制的字符长度小于被复制字符串长度,这里的字符串长度包括的\0的长度,需要手动加上\0,等于则不必

 

#include<stdio.h>
#include <string.h>

int main()
{
	char str[10];
	char str1[10];
	char str2[10] = "abcefg";
	memcpy(str1,str2,2);
	str1[2] = '\0';
	printf("str1=%s\n",str1);

	memcpy(str, str2, 7);
	printf("str=%s\n", str);

	return 0;
}

打印:str1=ab

 

            str2=abcefg

 

memcpy不允许内存重叠,memmove允许内存重叠。

 

#include <stdio.h>  
#include <string.h>

int main()
{
	char a[10] = "abcdefg";
	memcpy(a + 1, a, 5);
	printf("%s\n", a);

	char b[10] = "abcdefg";
	memmove(b + 1, b, 5);
	printf("%s\n", b);

	return 0;
}

打印:strcpy,strncpy,memcpy,memmove_C语言

 

这是在linux上运行的结果,VS2013上memcpy竟然是正确的,不知为何。至于为何两个函数有不同的结果,网上搜它们的实现方法。
 

 

参考地址:http://blog.csdn.net/stpeace/article/details/61626795