c语言(7.25)

今天学习了指针的运算,野指针和悬空指针,void类型的指针

cs 复制代码
#include <stdio.h>

int main()
{
	//指针跟整数进行加减
	//前提条件:保证内存空间是连续的
	//数组
	int arr[] = { 1,2,3,4,5,6,7,8,9,10 };
	//获取0索引的内存地址
	int* p1 = &arr[0];
	//通过内存地址p获取数据
	printf("%d\n", *p1);
	printf("%d\n", *(p1 + 1));
	//p2-p1间隔了多少步长
	int* p2 = &arr[5];
	printf("%d", p1 - p2);




	return 0;
}
cs 复制代码
#include<stdio.h>
void swap(void* p1, void* p2, int len);
int main()
{
	//viod 类型的指针
	//1,定义两个变量
	int a = 10;
	int b = 20;

	//2.定义两个指针
	int* p1 = &a;
	int* p2 = &b;

	//打印输出
	printf("%d\n", *p1);
	printf("%d\n", *p2);
	//不同类型的指针之间,是不能互相赋值的
	//viod类型的指针可以接收任意类型指针记录的内存地址
	void* p3 = p1;
	void* p4 = p2;
	
	//调用函数
	int c = 100;
	int d = 200;

	swap(&c, &d, 4);
	printf("c=%d,d=%d\n", c, d);
	
	return 0;
}

void swap(void* p1, void* p2, int len)
{
	//把void类型的指针转变成char类型的指针
	//char的字节是1
	char* pc1 = p1;
	char* pc2 = p2;
	char temp = 0;//用来记录pc1
	//以字节为单位,一个字节一个字节地进行交换
	for (int i = 0; i < len; i++)
	{
		temp = *pc1;//用*p1而不是p1,因为这里交换的是这个字节的数据而不是地址
		*pc1 = *pc2;
		*pc2 = temp;
		//交互第二个字节的数据
		pc1++;
		pc2++;

	}

}

冲冲冲

相关推荐
谙弆悕博士几秒前
【附C源码】二叉搜索树的C语言实现
c语言·开发语言·数据结构·算法·二叉树·项目实战·数据结构与算法
C+++Python3 分钟前
C++ 泛型编程 极简示例代码
开发语言·c++
Rust研习社10 分钟前
Ubuntu 全面拥抱 Rust 后,我意识到 Rust 社区要变了
linux·服务器·开发语言·后端·ubuntu·rust
宵时待雨14 分钟前
回溯算法专题2:二叉树中的深搜
开发语言·数据结构·c++·笔记·算法·深度优先
jiayong2318 分钟前
第 43 课:任务详情抽屉里的批量处理闭环与删除联动
java·开发语言·前端
likerhood19 分钟前
Java 访问修饰符:public、protected、private讲解
java·开发语言·javascript
学不思则罔39 分钟前
ParallelStream并发陷阱解析
java·开发语言·windows
认真的小羽❅43 分钟前
【Java并发编程】volatile关键字深度解析:从内存语义到实际应用
java·开发语言
jayson.h1 小时前
可视化界面
开发语言·python
kgduu1 小时前
python中的魔法方法
开发语言·python