C语言——(面试常见)字符串函数strcpy和strncpy函数的自现

在C语言中,strcpy 和 strncpy 是处理字符串时常用的两个函数,但它们在处理字符串复制时的行为和安全性上有所不同。下面,我将简要介绍这两个函数的功能,并提供它们的自实现(即不使用标准库函数,自己编写实现这些功能的代码)。

strcpy的复现

char *myStrcpy(char *des,char *src)
{
	char *back = des;
	
	if(des == NULL || src == NULL){
		return NULL;
	}
	while(*src != '\0'){
		*des = *src;
		des++;
		src++;
	}
	*des = '\0';
	return back;
}

char *myStrcpy2(char *des,char *src)
{
	char *back = des;
	
	if(des == NULL || src == NULL){
		return NULL;
	}
	while(*src != '\0'){
		*des++ = *src++;
	}
	*des = '\0';
	return back;
}

char *myStrcpy3(char *des,char *src)
{
	char *back = des;
	
	if(des == NULL || src == NULL){
		return NULL;
	}
	while((*des++ = *src++) != '\0')
	*des = '\0';
	return back;
}

上述共提供了三个复现代码,逻辑相同,区别主要体现在while循环的书写方式,从第一个到第三个,越来越简单。在循环后加入 *des = '\0'; 主要是因为strcpy 函数会将源字符串(包括空终止符 '\0')复制到目标字符串中。而在我们的复现代码的循环中是没有 ' \0 ' 的,因此要手动添加。

同时在循环复制开始之前,需要先判断des和src两个指针是否为空。若为空,直接返回空,复制失败。

strcpy的复现

代码如下:

char *myStrncpy(char *des,char *src,int count)
{
	char *back = des;
	
	if(des == NULL || src == NULL){
		return NULL;
	}
	while((*src != '\0') && count > 0){
		*des++ = *src++;
		count--;
	}
	if(count > 0){
		while(count>0){
			*des++ = '\0';
			count--;
		}
		return back;
	}
	*des = '\0';
	return back;
}
  • 首先检查 des 和 src 是否为 NULL。如果任一为 NULL,则函数立即返回 NULL。这是一个重要的安全特性,防止在空指针上解引用导致的未定义行为。
  • 接着使用一个 while 循环来复制字符,直到遇到源字符串的结尾(\0)或已达到 count 指定的最大复制次数。
  • 在循环内部,将 src 指向的字符复制到 des 指向的位置,然后递增 src 和 des 指针,并递减 count
  • 循环结束后,如果 count 仍然大于 0,说明源字符串的长度小于指定的字符数,需要在目标字符串的末尾添加足够的空字符('\0')直到达到指定的字符数。此时,使用一个内部的 while 循环来在剩余的空间中填充空字符 \0,直到 count 减至 0。
  • 如果在复制完所有源字符串字符后 count 恰好为 0(即源字符串长度等于或大于 count),则循环结束后,源字符串的末尾可能没有空字符。因此,代码显式地在 des 指向的当前位置(即最后一个复制的字符之后)添加了一个空字符 \0

相关推荐

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-21 04:48:03       52 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-21 04:48:03       54 阅读
  3. 在Django里面运行非项目文件

    2024-07-21 04:48:03       45 阅读
  4. Python语言-面向对象

    2024-07-21 04:48:03       55 阅读

热门阅读

  1. C语言中值滤波函数

    2024-07-21 04:48:03       18 阅读
  2. 【大模型基础】4.1 数据挖掘(待)

    2024-07-21 04:48:03       20 阅读
  3. 【LeetCode 0231】【位运算】2的N次方

    2024-07-21 04:48:03       16 阅读
  4. 【Socket 编程】基于UDP协议建立多人聊天室

    2024-07-21 04:48:03       16 阅读
  5. 会Excel就会sql?

    2024-07-21 04:48:03       18 阅读
  6. Android笔试面试题AI答之布局Layout(1)

    2024-07-21 04:48:03       12 阅读