c/c++中void定义的空类型指针(void* p)要怎么使用(强制类型转换)以及使用场景(函数指针)

我们先看看下面的代码,p是一个void类型的指针,ch是一个char类型的变量,当我们用p来保存ch的地址时,我们却无法通过*p来对ch的值进行访问,因为char会自动转化为void*类型的指针,也就是空类型指针,空类型指针++(无类型可以是任意类型)++,只存储地址的值,丢失类型,无法访问,要访问其值,就要对这个指针进行强制类型转换

char* p1 = (char*)p;
printf("p1 指向的字符是: %c\n",*p1);//值为a

通过这段代码就能对ch的值进行访问了

复制代码
int main(void) {
		int arr[] = { 1,2,3,4,5 };
		char ch = 'a';
		void* p = arr; //定义了一个void 类型的指针
	    p = &ch;//其它类型会自动转换成void *指针
		printf("p: 0x%p ch: 0x%p\n", p, &ch);//结果是p和ch的地址相同且都能打印出来
		//强制类型转化
		char* p1 = (char*)p;
		printf("p1 指向的字符是:  %c\n",*p1);
	
     system("pause");
     return 0;
}

那么什么时候会用到空指针类型呢?请看下面

void 指针可以指向任意类型的数据,不受数据类型限制,可以在程序中给我们带来一些好处,函数中形参为指针类型时,我们可以将其定义为 void 指针,这样函数就可以接受任意类型的指针。如:

典型的如内存操作函数 memcpy 和 memset 的函数原型分别为:

复制代码
复制代码
void * memcpy(void *dest, const void *src, size_t len);

void * memset ( void * buffer, int c, size_t num );

这样,任何类型的指针都可以传入 memcpy 和 memset 中,这也真实地体现了内存操作函数的意义,因为它操作的对象仅仅是一片内存,而不论这片内存是什么类型

相关推荐
saltymilk4 小时前
C++ 模板参数推导问题小记(模板类的模板构造函数)
c++·模板元编程
感哥4 小时前
C++ lambda 匿名函数
c++
沐怡旸10 小时前
【底层机制】std::unique_ptr 解决的痛点?是什么?如何实现?怎么正确使用?
c++·面试
感哥11 小时前
C++ 内存管理
c++
博笙困了17 小时前
AcWing学习——双指针算法
c++·算法
感哥17 小时前
C++ 指针和引用
c++
感哥1 天前
C++ 多态
c++
沐怡旸1 天前
【底层机制】std::string 解决的痛点?是什么?怎么实现的?怎么正确用?
c++·面试
River4162 天前
Javer 学 c++(十三):引用篇
c++·后端
感哥2 天前
C++ std::set
c++