assert断言与const修饰指针的妙用(模拟实现strcpy函数)

assert断言

目录

assert断言的妙用:

头文件:

使用方法:

const修饰指针的妙用

主要用法

const在*左边

const在*右边

断言和const修饰指针的应用

模拟实现C语言strcpy函数

    1、若字符串str1,str2有空指针怎么办?

    2.str2改变了怎么办?


assert断言的妙用:

头文件:

#include <assert.h>

使用方法:

我们不希望某件事情发生,直接就将该事件的判断语句放在assert()的括号内部,如果判断为真,没有发生,则代码正常运行;如果判断为假,那么直接终止程序,并且报错,assert断言的好处还在于报错时能够精准定位到哪一行出现了问题,所以程序员看到assert断言还是非常亲切的。

const修饰指针的妙用

主要用法

按照const在*左边,在*右边,可以分为两大类。

  • const在*左边

限制的是指针指向的内容,不能通过指针变量改变指针指向的内容,但是指针变量本身是可以改变的

 比如指针p指向的内容不可以改变,但是指针p本身是谁的地址是可以改变的

  • const在*右边

限制的是指针变量本身,指针变量本身是不能改变的,但是指针指向的内容是可以改变的。

比如指针p指向的内容是可以改为20的,但是指针p本身不能改变原有的指向地址a。

断言和const修饰指针的应用

讲了这么多关于断言和const修饰指针的知识,那就让我们来实践一下

模拟实现C语言strcpy函数

我们已知函数的参数有两个,将后面的字符串内容拷贝到前面去,然后返回目标空间的起始地址

初始代码:

//模拟实现strcpy函数

char* my_strcpy(char* str1, char* str2)
{
	char* ret = str1;
	while (*str1++ = *str2++)
		;
	return ret;
}

int main()
{
	char arr1[20] = "*****************";
	char arr2[] = "i love jing";
	//strcpy(arr1, arr2);
	my_strcpy(arr1, arr2);
	printf("%s\n", arr1);
	printf("%s\n", my_strcpy(arr1,arr2));
	return 0;
}

 上面的代码初步实现了strcpy函数,但仍然有很多细节需要注意。

  1. 若字符串str1,str2有空指针怎么办?

以防出现上述情况,我们可以使用断言判断这两个字符串不能为空

     2.str2改变了怎么办?

可以看出,在设定这个函数时,就已经考虑到被拷贝的字符串的内容不能改变,所以就需要const来修饰指针,并且在*的左边,使得指针指向的内容不会更改。

//模拟实现strcpy函数
#include<assert.h>
char* my_strcpy(char* str1,const char* str2)//const修饰被拷贝的字符串
{
	assert(str1 != NULL);//断言判断
	assert(str2 != NULL);//断言判断
	char* ret = str1;
	while (*str1++ = *str2++)
		;
	return ret;
}

int main()
{
	char arr1[20] = "*****************";
	char arr2[] = "i love jing";
	//strcpy(arr1, arr2);
	my_strcpy(arr1, arr2);
	printf("%s\n", arr1);
	printf("%s\n", my_strcpy(arr1,arr2));
	return 0;
}

 上面的代码才是最终解!

猜你喜欢

转载自blog.csdn.net/hanwangyyds/article/details/131469849