首先我们来看这两者之间的区别, Keil专用于嵌入式程序仿真编译书写的平台, 支持C99, 不支持标准输入输出, 不支持文件操作, 带有标准库和各类处理器的固件库. POJ专用于程序测试, 支持C99, 支持标准输入输出, 不支持文件操作, 自带C, C++标准库.
其实早在Keil开始发布的时候, 附带的ST件器例程里就有对printf函数的实现. 具体的工程如图所示:
软件仿真的运行结果:
但不管怎样, 都不能用于POJ中, 原因有以下几点: ① 在main函数中配置了系统的时钟 ② 在main函数中配置了串口 ③ 在main.c文件中包含了很多POJ上不需要的函数 ④ 必须调用ST的固件库
也就是说, 如果能做到以上四点, 那么几乎就可以将Keil的代码用于POJ中了. 我们试着解释一下整个工程的工作流程: 系统上电→STM32F10X.S→main()→RCC_Configuration()→NVIC_Configuration()→GPIO_Configuration()→USART_Init()→USART_Cmd()→printf(); 其中RRC_Configuration(), NVIC_Configuration(), GPIO_Configuration(), USART_Init(), USART_Cmd()等函数都是ST的固件库, 不能被POJ系统所识别. 正如我们所见, 在执行printf函数之前, 先运行了一个汇编文件和一些系统配置专用的函数. 完全可以把配置函数的功能写到汇编文件STM32F10X.S里. 这样系统在进入main函数之前就已经配置好了. 这样在main.c文件里需要做的事情就是: #include <stdio.h>
Int main() { Printf(“ this is a test!\n”); Return (0); } 这样的代码在POJ系统上是可以运行的. 同时ST例程里的这个函数也需要放到头文件stdio.h里. /************************************************************************ * Function Name : PUTCHAR_PROTOTYPE * Description : Retargets the C library printf function to the USART. * Input : None * Output : None * Return : None ************************************************************************/ PUTCHAR_PROTOTYPE { /* Write a character to the USART */ USART_SendData(USARTx, (u8) ch);
/* Loop until the end of transmission */ while(USART_GetFlagStatus(USARTx, USART_FLAG_TXE) == RESET) { }
return ch; }
|