void类型:空类型,定义变量的时候不能将其定义成void类型,否则会报错。
void指针:通用指针
#include <stdio.h>
int main()
{
int num = 2024 ;
int *pi = &num ;
char *ps = "MARS" ;
void *pv;
pv = pi;
printf("pi: %p, pv: %p\n", pi,pv);
pv = ps;
printf("ps: %p , pv: %p\n", ps,pv);
return 0;
}
但当我们将void指针类型转变回去的时候,最好再前面加上强制类型转换,这样代码更容易阅读。
此外不能直接对一个void指针进行解引用。
#include <stdio.h>
int main()
{
int num = 2024 ;
int *pi = &num ;
char *ps = "MARS" ;
void *pv;
pv = pi;
printf("pi: %p, pv: %d\n", pi,pv);
printf("pv: %d\n",*(int *)pv);
pv = ps;
printf("ps: %p , pv: %s\n", ps,pv);
printf("pv: %s\n",(char *)pv);
return 0;
}
为什么 printf("pv: %d\n",*(int *)pv);中需要加上解引用*,而字符串printf("pv: %s\n",(char *)pv);不需要?
答:C语言里没有字符串类型,“abc” 这样的字符串其实是字符数组的简写,即 {‘a’, ‘b’, ‘c’, ‘\0’} 。
以下两种写法表示相同的意思。根据数组表示法,可以知道数组名==数组第一个元素的地址==数组的地址。赋值时str代表的是数组str的地址,相等于&str[0]
char *p ="abc"; //写法1
char str[] = {'a', 'b', 'c', '\0'}; //写法2
char *p = str;
在字符串输出时必定会存在 %s 这一占位符,例如:
void addItem(char* name)
{
printf("Add %s successfully!\n", name);
}
在这里你可能会想问,name是一个指针啊,你这样输出最后不就会输出字符串的地址了吗?
这里就涉及到占位符 %s 的功能了,你可以理解为 %s 会自动识别读取字符串这个指针直到结束标志‘\0’,把它指向的内通过printf函数打印出来。
如果把示例中的%s换成%d,就会出现你想象中的效果,没错,就是这个字符串的地址,并且是一个随机地址,每次运行都会得到一个不同的值。
同样对于name+1,如下:
void addItem(char* name)
{
printf("Add %s successfully!\n", name+1);
}
name+1是指,这个指针会指向下一个字符的地址,因此会从第二个字符输出。
因此,在字符串输出时要注意不能加*解引用。
————————————————
版权声明:本文为CSDN博主「MUSIC南瓜」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/m0_59738220/article/details/123495373
null指针:
#include <stdio.h>
int main()
{
int *p1;//出现未定义的野指针
int *p2 = NULL;//用NULL避免这个问题
printf("%d\n", *p1);
printf("%d\n", *p2);
return 0;
}