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函数,但仍然有很多细节需要注意。
- 若字符串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; }
上面的代码才是最终解!