一、指针简介
指针与底层硬件联系紧密,使用指针可操作数据的地址,实现数据的间接访问。
1.计算机存储机制
数据在内存中的存放机制如下图:
此时,采用的是小端模式,即低位字节排放在内存的低地址端,高位字节排放在内存的高地址端。计算机普遍采用小端分配模式,而51单片机采用大端分配模式。数组分配的是连续的空间,如上图所示。
2.定义指针
注意1:存储的是首地址,为什么是首地址?
比如int型变量是跨越四个字节的,对应的地址也有四个,如果把地址都存起来,根本没法存。如果一个数组有一百项,那就跨越100个地址,根本没法存。
注意2:指针所占的位宽等于系统的位宽,为什么呢?
指针存放的数据单元的首地址,要存得下才行,对于64位系统,它的地址高达2的64次方个,要保证变量能够存得下任意一个地址,所以定义64位的指针就能足够大存下地址。
指针是为了放地址的首地址,而不同系统的寻址位数不同,这解释了为什么32位系统最大支持4G内存。
计算机的位数是什么意思?
二、指针操作
p=&a;这个操作,p会把a的地址存在p的内容中,原理如下图所示:
注意:p++;这个操作是使指针移动一个数据宽度,而不是一个字节,如下列代码:
#include <stdio.h>
int main()
{
/* Write C code in this online editor and run it. */
char a = 1;
short b[] = {
1,2,3