做项目的时候发现,把头文件中的 printf 相关宏定义去掉以后,设备照常能够通过串口输出内容。为此,在 windows 下用vs2010写了一个最简单的helloworld的测试程序。
1. 首先用 vs2010 将输出 "helloworld" 的程序做成一个库。
define_test_lib.h
#ifndef __DEFINE_TEST_LIB_H__
#define __DEFINE_TEST_LIB_H__
#define DEBUG_TEST /*根据宏定义的不同,打印出不同的信息*/
void Printf_HelloWorld(void);
#endif
define_test_lib.c
#include <stdio.h>
#include "define_test_lib.h"
void Printf_HelloWorld(void)
{
#ifdef DEBUG_TEST
printf("HelloWorld 1\n");/*如果打开宏定义就会有此打印*/
#else
printf("HelloWorld 2\n");
#endif
}
2. 使用第一步生成的lib库,写一个测试程序
define_test_main.c
#include "lib\define_test_lib.h"
int main(void)
{
Printf_HelloWorld();
return 0;
}
3. 测试结果
1. 使能 define_test_lib.h 中的 DEBUG_TEST 宏定义
2. 失能 define_test_lib.h 中的 DEBUG_TEST 宏定义
3. 分析
不管 DEBUG_TEST 是否被使能,程序最后输出的都是『HelloWorld 1』。这是因为生成库文件时,在预编译期,函数『Printf_HelloWorld()』的内容已经固定了,就是『printf("HelloWorld 1\n");』。所以,在生成库以后,不论 DEBUG_TEST 是否被定义,程序的输出结果都是相同的。