在用stm32h7 板子的时候,看了一个usmart历程,里面有个usart.c函数,声明了一个函数叫做HAL_UART_RxCpltCallback(UART_HandleTYpeDef *huart)
然后再stm32h7xx_hal_uart.c里看到了同样的一个函数
__weak void HAL_UART_RxCpltCallback(UART_HandleTYpeDef *huart)
{
}
然后看了下__weak的定义:#define __weak __attribute__((weak))
场景:
A,B两个模块,A模块调用了不确定B模块是否提供了函数,但是又不得不调用,这个时候在A模块中再申明一个弱符号函数,即用weak,如果外部提供了调用外部的,如果没提供调用申明的。
弱符号:
若两个或两个以上全局符号(函数或变量名)名字一样,而其中之一声明为weak属性,则这些全局符号不会引发重定义错误。链接器会忽略弱符号,去使用普通的全局符号来解析所有对这些符号的引用,但当普通的全局符号不可用时,链接器会使用弱符号。当有函数或变量名可能被用户覆盖时,该函数或变量名可以声明为一个弱符号。
示例:
//模块A中调用func,但是不确定外部是否提供了该函数
...
extern int func(void);
...
int a = func();
...
如果直接这么调用,如果外部不提供该函数程序可能出现crash。
所以在本模块中__attribute__((weak))就派上了用场
int __attribute__((weak)) func(......)
{
return 0;
}