嵌入式-C语言基础:指针偏移打印数组
在C语言中,数组名代表数组中首元素的地址,所以,下面两句获取数组的首地址是等价的:
#include<stdio.h> int main()
{
int a[5]={1,2,3,4,5};
int *p=&a[0];
int *p2=a;
printf("地址p=%p\n",p);
printf("地址p2=%p",p2);
return 0;
}
输出结果:
地址p=000000000061FDF0
地址p2=000000000061FDF0
根据指针地址偏移,可以打印数组
#include<stdio.h> int main()
{
int a[5]={1,2,3,4,5};
int *p=&a[0];
int *p2=a;
printf("地址p=%p\n",p);
printf("地址p2=%p\n",p2);
printf("打印数组:\n");
for(int i=0;i<sizeof(a)/sizeof(a[0]);i++)
{
printf("%d",*(p+i));//带上*表示取该地址的值
}
return 0;
}
输出结果:
地址p=000000000061FDF0
地址p2=000000000061FDF0
打印数组:
12345
使用指针访问数组的效率是远远大于数组下标的访问效率。
也可以通过下面方法,将指针当作数组面名,通过下标法来访问:
#include<stdio.h> int main()
{
int a[5]={1,2,3,4,5};
int *p=&a[0];
int *p2=a;
printf("地址p=%p\n",p);
printf("地址p2=%p\n",p2);
printf("打印数组:\n");
for(int i=0;i<sizeof(a)/sizeof(a[0]);i++)
{
printf("%d",p[i]);//像数组一样访问
}
return 0;
}
也可以通过下面的方法:
#include<stdio.h> int main()
{
int a[5]={1,2,3,4,5};
int *p=&a[0];
int *p2=a;
printf("地址p=%p\n",p);
printf("地址p2=%p\n",p2);
printf("打印数组:\n");
for(int i=0;i<sizeof(a)/sizeof(a[0]);i++)
{
printf("%d",*(a+i));//数组++
}
return 0;
}
但是不能对数组名++,编译会发生错误
#include<stdio.h> int main()
{
int a[5]={1,2,3,4,5};
int *p=&a[0];
int *p2=a;
printf("地址p=%p\n",p);
printf("地址p2=%p\n",p2);
printf("打印数组:\n");
for(int i=0;i<sizeof(a)/sizeof(a[0]);i++)
{
printf("%d",*a++);//数组++,会发生编译错误
}
return 0;
}
数组++是禁止的,因为++相当于更改数组的地址,而数组地址是固定的,是一个常量,对它进行++操作是不允许的。
并且,在操作系统中,都用8个字节来表示一个地址:
#include<stdio.h>
int main()
{
printf("整型指针:%d\n",sizeof(int *));
printf("字符型指针:%d\n",sizeof(char *));
printf("浮点型指针:%d\n",sizeof(float *));
return 0;
}
输出结果:
整型指针:8
字符型指针:8
浮点型指针:8
嵌入式-C语言基础:指针偏移打印数组的更多相关文章
- 嵌入式-C语言基础:二维数组
二维数组的每个元素都是一个一维数组,例如int arr[2][3]={{1,2,3},{4,5,6}}; 下面通过几个例子来对二维数组进行深入了解:二维数组可以看作是一个父数组,他的每个元素都是一个一 ...
- 嵌入式-C语言基础:二维数组的地址写法
二维数组a的有关指针: 表示形式 含义 ...
- 嵌入式-C语言基础:指针数组(和数组指针区分开来)
指针数组:一个数组,若其元素均为指针类型的数据,称为指针数组,指针数组存放的是指针类型的数据,也就是指针数组的每个元素都存放一个地址.下面定义一个指针数组: int * p[4];//[]的优先级是比 ...
- 嵌入式-C语言基础:二级指针
二级指针:可以理解为指向指针的指针,存放的是指针变量的地址. 下面用一级指针来保存一个指针变量的地址: #include<stdio.h> int main() { int *p1; in ...
- 嵌入式-C语言基础:指针是存放变量的地址,那为什么要区分类型?
指针是存放变量的地址,那为什么要区分类型?不能所有类型的变量都用一个类型吗?下面用一个例子来说明这个问题. #include<stdio.h> int main() { int a=0x1 ...
- [Coursera][计算导论与C语言基础][Week 10]对于“数组应用练习”课后习题的思考题的一些想法
(首先,关于Honor Code,我咨询过了Help Center,分享课后练习的思考题的想法是可以的(注意不是代码),但要标明引用,引用格式来源于https://guides.lib.monash. ...
- C语言 字符串指针和字符串数组使用区别
字符串指针和字符串数组使用区别 1 #include <stdio.h> 2 #include <string.h> 3 #include <stdlib.h> 4 ...
- 嵌入式-C语言基础:数组指针
定义一个数组指针,指向二维数组: int a[3][4]={{1,2,3,4},{5,6,7,8},{9,10,11,12}}; int (*p)[4];//定义二维指针数组 p=a;//指向二维数组 ...
- 嵌入式-C语言基础:通过结构体指针访问结构体数组
#include<stdio.h> #include<string.h> struct Student { char name[32]; int age; int height ...
随机推荐
- 《吐血整理》进阶系列教程-拿捏Fiddler抓包教程(15)-Fiddler弱网测试,知否知否,应是必知必会
1.简介 现在这个时代已经属于流量时代,用户对于App或者小程序之类的操作界面的数据和交互的要求也越来越高.对于测试人员弱网测试也是需要考验自己专业技术能力的一种技能.一个合格的测试人员,需要额外关注 ...
- Dapr中国社区活动之 分布式运行时开发者日 (2022.09.03)
自2019年10月首次发布以来,Dapr(Distributed Application Runtime,分布式应用运行时)因其"更稳定"."更可靠".&quo ...
- 日志:Redo Log 和 Undo Log
本篇文章主要介绍 Redo Log 和 Undo Log: 利用 Redo Log 和 Undo Log 实现本地事务的原子性.持久性 Redo Log 的写回策略 Redo Log Buffer 的 ...
- Bootstrap Blazor 开源UI库介绍-Table 虚拟滚动行
今天我们来介绍一下 Bootstrap Blazor 中 Table 组件的虚拟滚动行,什么是虚拟滚动呢,我查到的解释是:只渲染可视区域的列表项,非可见区域的 完全不渲染,在滚动条滚动时动态更新列表项 ...
- std:move() 作用 和 移动语义后 右值行为,unique_ptr的"移动"操作问题
unique_ptr 不能进行赋值操作,但是可以有返回unique_ptr的函数,由此产生的问题: 结论1:std:move() 只是将一个实参强行转换为右值引用. 我们知道对象初始化时有 构造函数, ...
- MySQL一致性读原来是有条件的
众所周知,在设定了隔离等级为Repeatable Read及以上时,InnoDB 可以实现数据的一致性读.换句话来说,就是事务执行的任意时刻,读取到的数据是同一个快照,不会受到其他事务的更新影响. 以 ...
- frp服务利用云主机docker服务实现Windows远程连接
1.云主机配置 1.docker部署 # 创建文件 mkdir -p /root/docker/frp && touch /root/docker/frp/frps.ini # 配置文 ...
- Allure的简单使用
Allure的简单使用 1.Allure简介 简单的理解下,可以把Allure当成一个用于生成美观测试报告的开源工具,配合Pytest测试框架使用更佳. 也就是说,Allure是在Pytest执行测试 ...
- 仿B站小火箭发射上升
效果图: CSS代码块: <style type="text/css"> .goTop { background-image: url(img/rocket_top ...
- 插件化编程之WebAPI统一返回模型
WebApi返回数据我们一般包裹在一个公共的模型下面的,而不是直接返回最终数据,在返回参数中,显示出当前请求的时间戳,是否请求成功,如果错误那么错误的消息是什么,状态码(根据业务定义的值)等等.我们常 ...