<CubeIDE + GCC> printf 输出不实时, 会Queue 一串 , 才送一次

#STM32F103C8T6
从MDK转到CubeIDE 1.10.1 + GCC, 上位机一直收不到 USART 回传心跳, 就Time out了。
抓方向,单独把 USART 和 stdio.h 测试。
发现<CubeIDE + GCC> printf 输出不实时, 会Queueu 一串心跳 , 才送一次,上位机Time out了…
请问, 这可能是我哪边设定错误吗?

#include <stdio.h>
// printf re-mapping to USART1
int __io_putchar(int ch)
{
    //HAL_UART_Transmit(&huart1,(uint8_t *)&ch,1,0xFFFF);
    while( !(USART1->SR & USART_SR_TXE) );
    (void)USART1->SR;
    USART1->DR=(ch & 0x1FF);
    return ch;
}

uint8_t ucBuf[16]; 
/* Test Program */
void Test (void)
{
   uint32_t  i=0;
    for( ; ; )
      {
          GPIOC->BRR = (1U << 13 );
        for( uint16_t  j=0;  j<256;  j++ )
        {
            ucBuf[j%16] = (uint8_t)ucReadRegister(j);
        }
         if( FAIL == bDataCompare(ucBuf)  ) break; 
        GPIOC->BSRR = (1U << 13 );
        printf("\rRead Test: %8lu", i );
    }
    hwSetBuzzerON( );    
    while(1); 
}
  1. 软件终端机测试, 可以看到 “Read Test 00000000”, 但输出不实时, 会几十个 , 才一起送一次,但没掉,都在。
  2. 示波器看PC13波形是连续且时间间隔是一致的,可以排除其他硬件因素。

程序没报错,也都执行,就是输出不实时连续。
Ex:
Read Test: 51
停一段时间, 约一秒, 直接连续输出, 跳到
Read Test: 110

ps: 实验
直接用 ( USART1->DR , USART_SR_TXE ) 控制 输出, 是正常且连续的。
问题是前人的码里面,printf( ) 有点多啊!

从网上搜到类似的现象, UNIX下printf有缓存:

  1. 会在遇到 \n 时输出
  2. 遇到 scanf()
  3. 缓存空间满了


把需要printf立即输出都以** \n**结尾, 可以解决目前测试问题。