手把手带你搞懂C语言指针

时间:2021-11-05 23:40:25

前言

自学笔记,没有历史知识铺垫(省略百度部分),C语言指针的使用

一、概念

1.*指针

指针: 内存资源的地址指针
变量:存放指针的盒子 32位操作系统中,其大小位32bit,即4个字节,64位为64bit,即8个字节,与指针数据类型无关
指针的数据类型: 表示指针要读取的地址字节数,如:char *p;读取1个字节,int *p读取4个字节,具体选择根据指向的变量调整
指针指向的内存空间一定要合法(存在,且有读的权限)

?
1
2
3
4
5
6
7
8
int main()
{
    int *p1;
    char *p2;
    //p1:4,p2:1
    printf("p1:%lu,p2:%lu \n",sizeof(*p1),sizeof(*p2));
    return 0;
}

指针变量的写法:*p_xx
指针变量通常以*p_开头,是英文指针Pointer的首字母

2.&取址

&a 变量a的内存地址

?
1
2
3
4
5
6
7
8
9
int main()
{
    int a = 12312312;
    int *p1;
    p1 = &a;
    //*p1指针指向变量的值:12312312,p1指向的内存地址E9C4AE18(等价于&a)
       printf("*p1:%d,p1指向的内存地址%X",*p1,p1);
    return 0;
}

二、指针修饰符

1.const 常量指针

const char *p; 从右往左理解: *p指针 char指向1个字节的内容 const该字节内容为只读 场景:描述字符串
char *const p; 从右往左理解:*p指针 const指针方向为只读(无法切换) char指向的内容是1字节,内容允许修改 场景:硬件资源
const char *const p; 结合了上面1和2的限制,指针方向为只读,指向的内容为只读 场景:ROM设备

?
1
2
3
4
5
6
//以下两个写法的作用是一样的
const char *p;
char const *p;
//以下两个写法的作用是一样的
char *const p;
char *p const;

2.volatile 特征指针

volatile char *p;防止优化指向内存地址(阻止指令重排)

3.typedef 别名指针

为指针起别名,复杂的指针场景使用,提高代码可读性
typedef char *xx_p

三、指针运算

1. ++ -- + -

指针的运算都是指向地址的运算,最小单位为当前指针变量的数据类型所占的内存大小
如:p+1的效果为0x20+1*(sizeof(p))

2.[] 标签访问

指针指向的内存位置,标签默认为0,及:p[0]
标签访问一般用于非线性访问,如:访问当前指针指向内存位置的后边第二个位置p[2]效果为*(p+2)
使用标签访问,则取出的是标签内存里的值,而不是地址
C语言的标签化默认是允许越界的,甚至用标签扫描整个内存,修改不同应用的属性

?
1
2
3
4
5
6
7
8
9
10
11
int main()
{
    int a = 0x123;
    int a1 = 0x134;
    int a2 = 0x145;
    int *p;
    p = &a1;
    //*p:134 ,*(p-1):145 ,p[-1]:145,p[1]:123
    printf("*p:%X ,*(p-1):%X ,p[-1]:%X,p[1]:%X \n",*p,*(p-1),p[-1],p[1]);
    return 0;
}

四、指针逻辑操作

>= == <= != 指针可以做逻辑操作,比较大小,但实际运用的比较少
p1 > p2 指针所占的地址比较,意义不大
p1 == n 一般跟一个特殊值比较,比如p1 == 0x0,地址的无效值,结束标识,表示p1处理完了
*p1 > *p2 实际上是指向变量值的比较

注意:
指针必须是同类型比较才有意义

总结

本章主要为C语言指针

Segmentation fault 段错误异常,通常是指针指向问题引起

本篇文章就到这里了,希望能给你带来帮助,也希望您能够多多关注服务器之家的更多内容!

原文链接:https://blog.csdn.net/weixin_41832302/article/details/119879541