OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 5768|回复: 4

在头文件里面函数说名为什么要用条件编译#ifndef ,#define #endif原因是什么?

[复制链接]

9

主题

26

帖子

0

精华

初级会员

Rank: 2

积分
82
金钱
82
注册时间
2014-4-1
在线时间
0 小时
发表于 2014-5-13 11:06:15 | 显示全部楼层 |阅读模式
5金钱
在头文件里函数说明全局变量等定义为什么使用条件编译,我知道条件编译可以防止重复定义,使用预定义命令它的保存空间是在FLASH里面,你们这样写是不是把写好的程序保存到Flash里面吗?不然有些程序多超过了STM32SRAM 20K,而Flash有 128k容量很大,为什么要这样来定义呢?求原子大哥解答!!!!!

最佳答案

查看完整内容[请看2#楼]

1、条件编译在调试程序的时候很是方便 2、不同的功能可以通过条件编译进行切换而不需要每次都修改大量的代码 3、功能比较多的时候,可以通过宏定义进行裁剪 4、缺点就是,需要考虑的东西比较多,开始编写的代码量比较大,费脑,哈哈
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

120

主题

7878

帖子

13

精华

资深版主

Rank: 8Rank: 8

积分
12012
金钱
12012
注册时间
2013-9-10
在线时间
427 小时
发表于 2014-5-13 11:06:16 | 显示全部楼层
1、条件编译在调试程序的时候很是方便
2、不同的功能可以通过条件编译进行切换而不需要每次都修改大量的代码
3、功能比较多的时候,可以通过宏定义进行裁剪
4、缺点就是,需要考虑的东西比较多,开始编写的代码量比较大,费脑,哈哈
现在,程序把烂铜烂铁变得智能化了,人呢,一旦离开了这烂铜烂铁就不知道干啥了
回复

使用道具 举报

120

主题

7878

帖子

13

精华

资深版主

Rank: 8Rank: 8

积分
12012
金钱
12012
注册时间
2013-9-10
在线时间
427 小时
发表于 2014-5-13 12:42:47 | 显示全部楼层
首先你要知道为什么要条件编译,好处在哪里,坏处在哪里
现在,程序把烂铜烂铁变得智能化了,人呢,一旦离开了这烂铜烂铁就不知道干啥了
回复

使用道具 举报

9

主题

26

帖子

0

精华

初级会员

Rank: 2

积分
82
金钱
82
注册时间
2014-4-1
在线时间
0 小时
 楼主| 发表于 2014-5-13 17:14:11 | 显示全部楼层
回复【2楼】Badu_Space:
---------------------------------
就是不知道呀,你能指点下么
回复

使用道具 举报

13

主题

57

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
407
金钱
407
注册时间
2016-5-26
在线时间
108 小时
发表于 2018-8-10 00:24:47 | 显示全部楼层
有些程序在调试、兼容性、平台移植等情况下可能想要通过简单地设置一些参数就生成一个不同的软件,这当然可以通过变量设置,把所有可能用到的代码都写进去,在初始化时配置,但在不同的情况下可能只用到一部分代码,就没必要把所有的代码都写进去,就可以用条件编译,通过预编译指令设置编译条件,在不同的需要时编译不同的代码。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-7-12 18:49

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表