当前位置: 首页 > news >正文

C语言进阶课程学习记录-第29课 - 指针和数组分析(下)

C语言进阶课程学习记录-第29课 - 指针和数组分析(下)

    • 数组名与指针
    • 实验-数组形式转换
    • 实验-数组名与指针的差异
    • 实验-转化后数组名加一的比较
    • 实验-数组名作为函数形参
    • 小结

本文学习自狄泰软件学院 唐佐林老师的 C语言进阶课程,图片全部来源于课程PPT,仅用于个人学习记录

数组名与指针

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

实验-数组形式转换

#include <stdio.h>int main()
{int a[5] = {0};int* p = a;int i = 0;for(i=0; i<5; i++){p[i] = i + 1;}for(i=0; i<5; i++){printf("a[%d] = %d\n", i, *(a + i));}printf("\n");for(i=0; i<5; i++){i[a] = i + 10;//可行 }for(i=0; i<5; i++){printf("p[%d] = %d\n", i, p[i]);}return 0;
}/*
output:
a[0] = 1
a[1] = 2
a[2] = 3
a[3] = 4
a[4] = 5p[0] = 10
p[1] = 11
p[2] = 12
p[3] = 13
p[4] = 14用指针+下标代替数组赋值,可行*/

在这里插入图片描述

实验-数组名与指针的差异

//ext.c
int a[] = {1, 2, 3, 4, 5};
#include <stdio.h>int main()
{// extern int a[];//case1/*output:&a = 00402000 //数组地址a = 00402000  //首元素地址*a = 1*/extern int *a;//case2/*output:&a = 00402000a = 00000001*/printf("&a = %p\n", &a);//printf("a = %p\n", a);//1printf("*a = %d\n", *a);//访问地址00000001 报错return 0;
}

在这里插入图片描述

实验-转化后数组名加一的比较

#include <stdio.h>int main()
{int a[5] = {1, 2, 3, 4, 5};int* p1 = (int*)(&a + 1);int* p2 = (int*)((int)a + 1);int* p3 = (int*)(a + 1);printf("%d, %d, %d\n", p1[-1], p2[0], p3[1]);return 0;
}/*output:小端 数据低位放在低地址中01 00 00  00    02 00 00  00     03 00 00  00    04 00 00  00     05 00 00  005    33554432  3*/

实验-数组名作为函数形参

#include <stdio.h>void func1(char a[5])
{printf("In func1: sizeof(a) = %d\n", sizeof(a));*a = 'a';a = NULL;
}void func2(char b[])
{printf("In func2: sizeof(b) = %d\n", sizeof(b));*b = 'b';b = NULL;
}int main()
{char array[10] = {0};func1(array);printf("array[0] = %c\n", array[0]);func2(array);printf("array[0] = %c\n", array[0]);return 0;
}/*output:
In func1: sizeof(a) = 4
array[0] = a
In func2: sizeof(b) = 4
array[0] = b
数组名作为函数形参会退化为指针*/

小结

数组名与指针仅使用方式相同
数组名的本质不是指针;指针的本质不是数组
数组名并不是数组的地址,而是数组首元素的地址
函数的数组参数退化为指针

http://www.lryc.cn/news/336027.html

相关文章:

  • 一起学习python——基础篇(13)
  • SOCKS代理概述
  • AI助力M-OFDFT实现兼具精度与效率的电子结构方法
  • 【数据结构】单链表(一)
  • SCI一区 | Matlab实现INFO-TCN-BiGRU-Attention向量加权算法优化时间卷积双向门控循环单元注意力机制多变量时间序列预测
  • Coursera吴恩达《深度学习》课程总结(全)
  • C# 操作PDF表单 - 创建、填写、删除PDF表单域
  • Astropy:探索宇宙奥秘的Python工具箱
  • java数据结构与算法刷题-----LeetCode684. 冗余连接
  • 循环神经网络简介
  • 计算机网络 子网掩码与划分子网
  • HUD抬头显示器中如何设计LCD的阳光倒灌实验
  • Shoplazza闪耀Shoptalk 2024,新零售创新解决方案引领行业新篇章!
  • Linux:sprintf、snprintf、vsprintf、asprintf、vasprintf比较
  • Github远程仓库改名字之后,本地git如何配置?
  • Objective-C学习笔记(ARC,分类,延展)4.10
  • 02 Git 之IDEA 集成使用 GitHub(Git同时管理本地仓库和远程仓库)
  • CSS滚动条样式修改
  • 《零秒思考》像麦肯锡精英一样思考 - 三余书屋 3ysw.net
  • 使用docker制作Android镜像(实操可用)
  • 大厂MVP技术JAVA架构师培养
  • uniapp实现文件和图片选择上传功能实现
  • 2024认证杯数学建模C题思路模型代码
  • springcloud项目中,nacos远程的坑
  • 南京航空航天大学-考研科目-513测试技术综合 高分整理内容资料-01-单片机原理及应用分层教程-单片机有关常识部分
  • 【python】Flask Web框架
  • Electron+React 搭建桌面应用
  • 基于Android的记单词App系统的设计与实现
  • ELK 企业级日志分析系统 简单介绍
  • GET与POST:详述HTTP两大请求方法的语义、数据处理机制、安全特性与适用场景