看过论坛里面这个问题,并且百度过,但是关于#define GPIOA ((GPIO_TypeDef *) GPIOA_BASE)还有一些疑问,希望大神进来see

2019-07-20 23:17发布

这是我在论坛看的相关的帖子: #define GPIOA ((GPIO_TypeDef *) GPIOA_BASE)        http://www.openedv.com/forum.php ... IO%5C_TypeDef%2B%2B
但是还是有一些疑问,想请各位大神给个解答。
首先谈下个人的理解:宏定义就是预处理的时候将出现GPIOA的全部替换为(GPIO_TypeDef *) GPIOA_BASE
GPIO_TypeDef是一个结构体,里面包含着7个IO端口的寄存器。
(GPIO_TypeDef *) GPIOA_BASE这个语句的意思是将GPIOA_BASE(参照上面的帖子好像是个地址)强制转换为结构体指针变量。
这样GPIO_A就可以访问GPIO_TypeDef结构体中的成员。
那么我有以下几个疑问:
1.地址能够强制转换为指针变量?(百度上说是可以的)
2.即时地址(GPIOA_BASE)能够强制转换为结构体指针变量,那么结构体指针变量需要指向一个变量的地址(指针变量是装地址的)。例如:int a=3;  int * p; p=&a;  那么被强制转换后的结构体指针变量,它指向的是哪个地址?
3.是不是可以这样理解GPIOA_BASE被强制转换为结构体指针变量,那么这个结构体指针变量指向的地址还是原来GPIOA_BASE的地址。而这个地址又是IO端口第一个寄存器的地址?
深夜发帖,必是深思熟虑。刚刚踏入stm32,还请各位感受指点。
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
25条回答
少说多做
2019-07-21 17:44
rmrmrm 发表于 2018-4-4 08:37
GPIOA_BASE包括其他IO口这个是确定的硬件寄存器入口(基地址),结构体里面的是地址偏移量,每个IO的寄存器 ...

谢谢你的回答,GPIO_BASE(基地址)被强制转化为结构体指针变量,但是指针变量不得指向一个地址,那么基地址被强制转化为结构体指针变量后,结构体指针变量是不是指向本身GPIO_BASE的地址?如我问题3所述的那样

一周热门 更多>