C语言下字符串拷贝函数汇总对比
1.1、strcpy 函数原型char *strcpy(char *dest, const char *src)
需要注意的是如果目标数组 dest 不够大,而源字符串的长度又太长,可能会造成缓冲溢出的情况,所以在实际使用一定要注意dest的空间一定要大于strlen(src)+1,最后有一个结束符‘\0’
1.2、strncpy 函数原型char *strncpy(char *dest, const char *src, size_t n)
把 src所指向的字符串复制到 dest,最多复制 n 个字符。当 src 的长度小于 n 时,dest 的剩余部分将用空字节填充。需要特别注意的是该函数不会自动添加结束符号,需要手动在添加一个‘\0’,相对于strcpy多了一个复制长度的设置,但是仍然存在溢出风险
1.3、strcpy_s() 函数原型errno_t strcpy_s(char *dest,size_t numberOfElements,const char *src);
相对于strcpy多了一个参数,目标缓冲区的大小,可以避免一些不必要的故障
1.4、strncpy_s() 函数原型errno_t strncpy_s(char * restrict dest,rsize_t destsz,const char * restrict src,rsize_t count);
strcpy_s、strncpy_s可以理解为strcpy、strncpy函数的升级安全版本,相比于原来的函数功能一致用于字符串拷贝/固定长度字符串拷贝,能够有限判断是否存在溢出情况
2.1、memcpy 函数原型void *memcpy(void *dest, const void *src, size_t n);
不存在结束符这个概念,所以必须制定拷贝数量n
2.2、memcpy_s 函数原型errno_t strncpy_s(char * restrict dest,rsize_t destsz,const char * restrict src,rsize_t count);
可以执行以下函数观察不同宏定义的时候的结果,
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#define USE_STRING 0
int main(int argc, const char *argv[])
{
char dest[10] = {0x30,0x31,0x32,0x34,0x35,0x36,0x37,0x38,0};
char src[10] = {0x61,0x62,0x63,0,0x41,0x42,0};
printf("%s %s \r\n",dest,src);
#if USE_STRING
strncpy(dest,src,8);
#else
memcpy(dest,src,8);
#endif
printf("%s %s \r\n",dest,src);
printf("%#x %#x\r\n",dest[4],dest[5]);
return 0;
}
strncpy和memcpy系列的函数在功能上类似,主要就是区别我觉得可以理解为strcpy系列的函数用于字符串之间的拷贝,如果是buffer之间的拷贝建议使用memcpy系列的函数,因为不涉及到结束符‘\0’
3、格式化字符串输出sprintf系列
3.1 int printf(const char *format, ...);
格式化输出到标准输出流
3.2 int fprintf(FILE *stream, const char *format, ...);
格式化输出到文件流
3.3 int sprintf(char *str, const char *format, ...);
格式化输出到字符串str,需要保证str大小避免内存溢出引发不可预期的错误
3.4 int snprintf(char *str, size_t size, const char *format,...);
(1) 如果格式化后的字符串长度 < size,则将此字符串全部复制到str中,并给其后添加一个字符串结束符('\0');
(2) 如果格式化后的字符串长度 >= size,则只将其中的(size-1)个字符复制到str中,并给其后添加一个字符串结束符('\0'),返回值为欲写入的字符串长度。
sprinf