KEIL获取工程编译时间

可以使用KEIL内置的__DATE__ 和 __TIME__ 宏来实现这个功能
参考范例:
unsigned char code DataStr[]=__DATE__;
unsigned char code TimeStr[]=__TIME__;
这样,编译后TimeStr的字符串正好是编译的当前时刻,相当于
unsigned char code TimeStr[]="09:12:04"
这在某些时候很有用,比如管理产品版本时。


这个在编译时,编译器会自动的把计算机系统时间编译进去,它只是一个宏,编译后不会改变的,这样的好处在于确定编译时间确认版本好和代码发行时间


示例代码:

printf("%s_%s_%d_%d\n", __DATE__, __TIME__, sizeof(__DATE__),sizeof(__TIME__));

输出结果为:

Jan 13 2017_17:24:11_12_9

 

利用__DATE__获取当前日期,占用12个字节,包括字符串结束符
利用__TIME__获取当前时间,占用9个字节,包括字符串结束符
两个都是字符串型



一边情况下,C/C++编译器会内置几个宏,这些宏定义不仅可以帮助我们完成跨平台的源码编写,灵活使用也可以巧妙地帮我们输出非常有用的调试信息。

ANSI C标准中有几个标准预定义宏(也是常用的):
__LINE__:在源代码中插入当前源代码行号;
__FILE__:在源文件中插入当前源文件名;
__DATE__:在源文件中插入当前的编译日期
__TIME__:在源文件中插入当前编译时间;
__STDC__:当要求程序严格遵循ANSI C标准时该标识被赋值为1;
__cplusplus:当编写C++程序时该标识符被定义。

编译器在进行源码编译的时候,会自动将这些宏替换为相应内容。
示例:

[cpp]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. #include <stdio.h>  
  2.   
  3. #define YEAR ((((__DATE__ [7] - '0') * 10 + (__DATE__ [8] - '0')) * 10 \  
  4.     + (__DATE__ [9] - '0')) * 10 + (__DATE__ [10] - '0'))  
  5.   
  6. #define MONTH (__DATE__ [2] == 'n' ? 0 \  
  7.     : __DATE__ [2] == 'b' ? 1 \  
  8.     : __DATE__ [2] == 'r' ? (__DATE__ [0] == 'M' ? 2 : 3) \  
  9.     : __DATE__ [2] == 'y' ? 4 \  
  10.     : __DATE__ [2] == 'n' ? 5 \  
  11.     : __DATE__ [2] == 'l' ? 6 \  
  12.     : __DATE__ [2] == 'g' ? 7 \  
  13.     : __DATE__ [2] == 'p' ? 8 \  
  14.     : __DATE__ [2] == 't' ? 9 \  
  15.     : __DATE__ [2] == 'v' ? 10 : 11)  
  16.   
  17. #define DAY ((__DATE__ [4] == ' ' ? 0 : __DATE__ [4] - '0') * 10 \  
  18.     + (__DATE__ [5] - '0'))  
  19.   
  20. #define DATE_AS_INT (((YEAR - 2000) * 12 + MONTH) * 31 + DAY)  
  21.   
  22.   
  23. void show_version()  
  24. {  
  25.     printf("version:2.1\n");  
  26.     printf("build time:%d-%02d-%02d\n",YEAR, MONTH + 1, DAY);  
  27. }  
  28.   
  29. /** 
  30. __LINE__ 当前语句所在的行号, 以10进制整数标注. 
  31. __FILE__ 当前源文件的文件名, 以字符串常量标注. 
  32. __DATE__ 程序被编译的日期, 以"Mmm dd yyyy"格式的字符串标注. 
  33. __TIME__ 程序被编译的时间, 以"hh:mm:ss"格式的字符串标注, 该时间由asctime返回. 
  34.  
  35.  */  
  36.   
  37. void test_macro()  
  38. {  
  39.     // __DATE__, __TIME__, __FILE__, __LINE__ 为预定义宏  
  40.     printf("Date : %s\n", __DATE__);  
  41.     printf("Time : %s\n", __TIME__);  
  42.     printf("File : %s\n", __FILE__);  
  43.     printf("Line : %d\n", __LINE__);  
  44. #ifdef __cplusplus  
  45.     printf("__cplusplus=%d\n", __cplusplus);  
  46. #endif  
  47. }  
  48.   
  49. //https://bytes.com/topic/c/answers/215378-convert-__date__-unsigned-int  
  50. //c++转换__DATE__宏为友好格式的时间和编译器预定义的宏  
  51. int main (void)  
  52. {  
  53.     printf ("%d-%02d-%02d = %d\n", YEAR, MONTH + 1, DAY, DATE_AS_INT);  
  54.     show_version();  
  55.     test_macro();  
  56.     return 0;  



评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值