C语言初阶——实用调试技巧(新课学习)

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>

strcpy 字符串拷贝

char * strcpy (char * destination, const char * source);

#include<string.h>//strcpy头文件
int main()
{
char arr1[20] = { 0 };//char arr1[20] = "woshishui";
char arr2[] = "hello";
strcpy(arr1, arr2);
printf("%s\n", arr1);

return 0;
}

函数实现

void my_strcpy(char* dest, char* src)
{
while (*src != '\0')
{
*dest = *src;
dest++;
src++;
}
*dest = *src;//拷贝'\0'
}
int main()
{
char arr1[20] = "woshishui";
char arr2[] = "hello";
my_strcpy(arr1, arr2);
printf("%s\n", arr1);

return 0;
}

优化

void my_strcpy(char* dest, char* src)
{
while (*dest++ = *src++)//'\0'的ASCII码值为0
{
;
}
}
int main()
{
char arr1[20] = "woshishui";
char arr2[] = "hello";
my_strcpy(arr1, arr2);
printf("%s\n", arr1);

return 0;
}

当source无指向,为空指针时,那么解引用时就会出现问题------读取访问权限冲突,程序挂了。

再优化

#include<assert.h>
void my_strcpy(char* dest, char* src)
{
//if (dest == NULL || src == NULL)//判断指针的有效性。
//{
// return;
//}//这里虽然在遇到空指针,不执行代码,直接返回,拦截了空指针的问题,但没有报错,没有暴露问题,不易找出错误代码。

//断言
//assert中放一个表达式,表达式的结果为假,则报错;结果为真,则正常往下运行。//即,只能判断真假。
assert(dest != NULL);
assert(src != NULL);

//也可以写成:assert(dest && src);

while (*dest++ = *src++)//'\0'的ASCII码值为0
{
;
}
}
int main()
{
char arr1[20] = "woshishui";
char *p = NULL;
my_strcpy(arr1, p);
printf("%s\n", arr1);

return 0;
}

const

const修饰指针变量时
1.const放在*的左边,修饰的是指针指向的内容,表示指针指向的内容不能通过指针来改变,但是指针变量本身可以被修改。
2.const放在*的右边,修饰的是指针变量本身,表示指针变量本身的内容不能被改变,但是指针指向的内容可以通过指针来改变。

库函数strcpy返回的是目标空间的起始位置

#include<assert.h>
char * my_strcpy(char* dest, char* src)
{
assert(dest && src);
char* ret = dest;
while (*dest++ = *src++)
{
;
}
return ret;
}
int main()
{
char arr1[20] = "woshishui";
char* p = NULL;

//链式访问:
printf("%s\n", my_strcpy(arr1, p));//打印字符串:从起始位置开始。

return 0;
}

练习:

求字符串长度

strlen

#include<string.h>
int my_strlen(char* arr)
{
int count = 0;
while (*arr != '\0')
{
arr++;
count++;
}
return count;
}
int main()
{
char arr[] = "abcdef";

printf("%d\n", my_strlen(arr));
return 0;
}

使用const

#include<string.h>
#include<assert.h>
int my_strlen(const char* arr)
{
int count = 0;
assert(arr != NULL);
while (*arr != '\0')
{
arr++;
count++;
}
return count;
}
int main()
{
char arr[] = "abcdef";

printf("%d\n", my_strlen(arr));
return 0;
}

标准答案:

#include<string.h>
#include<assert.h>
unsigned int my_strlen(const char* arr)
//size_t my_strlen(const char* arr)//strlen返回类型:size_t------unsigend int
{
unsigned int count = 0;
assert(arr != NULL);
while (*arr != '\0')
{
arr++;
count++;
}
return count;
}
int main()
{
char arr[] = "abcdef";

printf("%d\n", my_strlen(arr));
return 0;
}

相关推荐
口袋物联7 小时前
设计模式之工厂模式在 C 语言中的应用(含 Linux 内核实例)
linux·c语言·设计模式·简单工厂模式
Want5959 小时前
C/C++跳动的爱心①
c语言·开发语言·c++
lingggggaaaa9 小时前
免杀对抗——C2远控篇&C&C++&DLL注入&过内存核晶&镂空新增&白加黑链&签名程序劫持
c语言·c++·学习·安全·网络安全·免杀对抗
gfdhy10 小时前
【c++】哈希算法深度解析:实现、核心作用与工业级应用
c语言·开发语言·c++·算法·密码学·哈希算法·哈希
我不会插花弄玉10 小时前
vs2022调试基础篇【由浅入深-C语言】
c语言
福尔摩斯张11 小时前
《C 语言指针从入门到精通:全面笔记 + 实战习题深度解析》(超详细)
linux·运维·服务器·c语言·开发语言·c++·算法
fashion 道格11 小时前
数据结构实战:深入理解队列的链式结构与实现
c语言·数据结构
铁手飞鹰12 小时前
二叉树(C语言,手撕)
c语言·数据结构·算法·二叉树·深度优先·广度优先
[J] 一坚14 小时前
深入浅出理解冒泡、插入排序和归并、快速排序递归调用过程
c语言·数据结构·算法·排序算法
散峰而望16 小时前
C++数组(一)(算法竞赛)
c语言·开发语言·c++·算法·github