关于指针、函数和地址
在主函数中
uint8_t Rx_Buffer[BufferSize];
/* 将刚刚写入的数据读出来放到接收缓冲区中 */
SPI_FLASH_BufferRead(Rx_Buffer, FLASH_WriteAddress, BufferSize);
printf("\r\n THE READ DATA IS: %s \r\n", Rx_Buffer);
在flash.c文件中
void SPI_FLASH_BufferRead(u8* pBuffer, u32 ReadAddr, u16 NumByteToRead)
{
/* 选择FLASH: CS低电平 */
SPI_FLASH_CS_LOW();
/* 发送 读 指令 */
SPI_FLASH_SendByte(W25X_ReadData);
/* 发送 读 地址高位 */
SPI_FLASH_SendByte((ReadAddr & 0xFF0000) >> 16);
/* 发送 读 地址中位 */
SPI_FLASH_SendByte((ReadAddr& 0xFF00) >> 8);
/* 发送 读 地址低位 */
SPI_FLASH_SendByte(ReadAddr & 0xFF);
/* 读取数据 */
while (NumByteToRead--) /* while there is data to be read */
{
/* 读取一个字节*/
*pBuffer = SPI_FLASH_SendByte(Dummy_Byte);
/* 指向下一个字节缓冲区 */
pBuffer++;
}
/* 停止信号 FLASH: CS 高电平 */
SPI_FLASH_CS_HIGH();
}
函数定义的形参是指针类型,在main函数中,我们直接带入了数组。
可以将Rx_Buffer理解为该数组的首地址,而形参要求我们带入地址,所以这样带入是可以的
同时,我们还可以用另外一种写法:
/* 将刚刚写入的数据读出来放到接收缓冲区中 */
SPI_FLASH_BufferRead(&Rx_Buffer[0], FLASH_WriteAddress, BufferSize);
printf("\r\n THE READ DATA IS: %s \r\n", Rx_Buffer);
验证结果是完全一样的。
2022.3.14更新
数组和字符串在本质上都是指针,因此会出现以下的情况:
#include <stdio.h>
void test(char *string)
{
printf("string未操作之前的的指针:%p\n",string);
string = "hello world";
printf("string未操作之后的的指针:%p\n",string);//字符串本身就是一个指针,所以前面不能加*
}
int main()
{
char *str = NULL;
printf("传入test函数之前str的指针:%p\n",str);
test(str);
printf("str=%s\n",str);
getchar();
return 0;
}
示例中的字符串本质上就是指针,所以在printf中并不能在string前加*