C进阶:08.指针赋值、野指针、项目开发模型强化

知识点:

1. 内存四驱模型

void change1(int number){ // 不能修改
    number = 300;
    printf("%p\n",&number);
}

int main(){
    int a = 100;

    // 修改 a 的值

    a = 200;
    change1(a); // a变量的值复制给了 number 变量,number 是在另一个函数中,number 是一个新的变量
    printf("change1:a = %d\n",a); // a = 200

    // getchar();
}

在这里插入图片描述

2. 指针间接赋值的意义

void change2(int* number){ //  可以
    *number = 300;
}

int main(){
    int a = 100;
    change2(&a); //  a 的地址复制给了 number 变量,number 是在另一个函数中,number 是一个新的变量

    printf("change2:a = %d\n",a); // a = 300;

    // getchar();
}

在这里插入图片描述

在做开发的时候,离不开指针,指针出现的意义有很多,其中一种就是通过方法去修改值 :

  1. 获取Bitmap信息
 AndroidBitmapInfo android_bitmap_info; // 结构体
 AndroidBitmap_getInfo(env,bitmap,&android_bitmap_info);// 通过 getInfo 方法去获取 Bitmap 的属性
 // 获取Bitmap的 宽,高,format
 int bitmap_width = android_bitmap_info.width;
 int bitmap_height = android_bitmap_info.height;

c 和 java 的方法不同所在,c 可以传对象的地址在方法里面去赋值,java 一般都是通过返回值

java 写法:
  AndroidBitmapInfo android_bitmap_info = AndroidBitmap_getInfo(env,bitmap);

3. 野指针和 null 地址

野指针:指 释放了指针对应的内存地址后,没有把指针置为 NULL

NULL : NULL 相当于指向 0x00000000,这块地方是 c 和 c++ 编译器所持有的,不能在这块区域赋值

strcpy(p,“string”);
p=“string”;
第一个是把string赋值给p,第二个是p指向“string”的首地址。

在这里插入图片描述

int main(){
    // 写入位置 0x00000000 时发生访问冲突
    char* p1 = NULL; // p1 = NULL,NUll 也是地方,指针指向 NULL 相当于指向 0x00000000

    // 但是我们不能对 0x00000000 去操作,这块地方是 c 和 c++ 编译器所持有的

    // Student student = null; 不用纠结 null 是啥,跟 c 和 c++ 有点类似

    strcpy(p1,"1122"); // 把 1122 赋值给p1 NUll的位置,这是错误的

    printf("p1 = %s",p1); // Null的地址不能操作

    getchar();
}

4. 字符串强化

int main(){
    // char buff[100] = {'e','a','s','t','r','i','s','e'};// 后面 8 - 99 都是默认值 0
    // char buff[5] = {'e','a','s','t','r'};
    // char buff[] = {'e','a','s','t','r'}; // 长度是 12('\0'), size 是 5(默认统计里面的个数)
    // char buff[2] = {'e','a','s','t','r'}; // 编译不通过,长度超出
    // char buff[100] = { 0 }; // 把数组初始化为 0
    // char buff[100] 数据都是默认值 -52

      char buff[] = "123456"; // len 是 6('\0'),size 是 7
    // 相当于 char buff[] = {1,2,3,4,5,6,\0}
//    char* buff= "123456"; // len==6, size==8(64位系统指针占8字节)

    // 纠结一下 char buff[] = "123456" 和 char* buff= "123456"; malloc 的方式 啥区别 ?
    // 字符串可以在任何地方开辟内存,栈区,堆区,常量区

    // 大小 size 100
    int len = strlen(buff);// len 5 碰到 '\0' 就结束了
    int size = sizeof(buff);

    printf("len = %d , size = %d\n",len,size);

    // 内容
    printf("%d,%d,%d,%d",buff[0],buff[66],buff[99],buff[77]);

    getchar();

}

在这里插入图片描述

5. 项目开发模型强化

  1. 确定你的参数,传递指针
  2. 一定要考虑健壮性
  3. 要异常错误进行抛出说明 萤视频 ffmpeg
  4. 不要直接轻易的去改变调用传递给你的指针
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值