野指针 二级指针 一级指针运算

//如何规避野指针?
//1.指针初始化
//2.小心指针越界
//3.不用时,将指针置NULL
//4.指针使用之间检查有效性

//二级指针
//#include <stdio.h>
//int main()
//{
//    int a = 10;
//    int* pa= &a;
//    int* * ppa = &pa; //ppa是二级指针int*是类型再加一个*找到pa
//    printf("%d",**ppa);
//    return 0;
//}

//指针数组 - 数组 -》 存放指针的数组
//数组指针 - 指针
//指针数组 - 数组
//#include <stdio.h>
//int main()
//{
//    int a = 10;
//    int b = 20;
//    int c = 30;
//    int* arr2[3] = {&a,&b,&c};
//    int i;
//    for (i = 0; i < 3; ++i)
//    {
//        printf("%d",*(arr2[i]));
//    }
//    return 0;
//}



一级指针

//1.&数组名 -> 数组名不是首元素地址(整个数组的地址)
//2.sizeof(数组名) -> 数组名表示的整个数组()计算整个数组大小
//3.&arr[i]取得是是i的地址

//指针运算  指针++--    指针 - 指针 = 元素个数    指针可以比较大小
//#include <stdio.h>
//#define N_VALUES 5
//int main() {
//    //1.指针++--
    float values[N_VALUES];
    float *vp;
    for (vp = &values[0]; vp < &values[N_VALUES];)
    {
        *vp++;
    }
//
    return 0;
//
//    //2.指针 - 指针 = 元素个数  前提;同一个数组
    int arr[10] = {1,2,3,4,5,6,7,8,9};
    printf("%d",&arr[9] - &arr[0]);
    return 0;
//    //2.1回看8月15日 strlen()用指针实现
//    //3.指针可以比较大小
//    float values[N_VALUES];
//    float *vp;
//    for (vp = &values[N_VALUES]; vp > &values[N_VALUES];)
//    {
//        *--vp = 0;
//    }
//}
  • 4
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值