C语言中,*类型就是指针类型,比如 int *p,double *q,虽然是不一样的指针,但是大小却一样sizeof(p) == sizeof(q),因为它们都是同一种类型*类型的。C语言是强类型的语言,对类型的区分十分严格,不同的类型占据的空间大小不同,地址偏移量也会不同;
基本认识
-
void*可以指向任何类型的地址,但是带类型的指针不能指向void*的地址
-
void*指针只有强制类型转换以后才可以正常取值
-
void*指针变量和普通指针一样可以通过等于0或者NULL来初始化,表示一个空指针
-
当void*指针作为函数的输入和输出时,表示可以接受任意类型的输入指针和输出任意类型的指针
#include "stdio.h"
void *test(void *buff)
{
return buff;
}
int main()
{
int nums[] = {3, 5, 6, 7, 9};
// 初始化指针
void *p1 = NULL;
p1 = nums;
// 打印地址
printf("%d\n", p1);
// 取值(报错)
// printf("%d\n", *p1);
// 取值(正常)
printf("%d\n", *(int *)p1);
// 地址偏移(警告)
// printf("%d\n", ++p1);
// 地址偏移(正常)
int *p2 = (int *)p1;
printf("%d\n", p2++);
}
典型应用
void*类型的指针其实本质就是一个过渡型的指针状态,在编写框架的时候就可以在不确定输入的时候使用,典型的应用有两种:
函数传参时不确定类型,或者要支持多类型的传参
void function(int dataType, void* data) {
// 根据dataType的不同值,进行不同的转换
switch (dataType) {
case 0:
int* a = (int*)data;
case 1:
char* a = (char*)data;
...
}
}
当函数的返回值不考虑类型指关心大小的时候
void * memcpy(void *dest, const void *src, size_t len);
void * memset ( void * buffer, int c, size_t num );
函数指针
各位第一眼看到下边的函数有什么想法,是不是有种熟悉又陌生的感觉:
typedef void (*fun)(void *data1);
看看下面的用法:
#include "stdio.h"
// 定义一个函数类型
typedef void (*fun)(void *data1);
// 实例一个函数变量
fun test;
// 定义一个回调函数
void callBack(void *p1)
{
printf("%d\n", *(int *)p1);
}
int main()
{
int a = 10;
test = callBack;
test(&a);
}