const 与 #define 相比,有何优点?好像现在比较多人建议使用 const ,这是为什么呢?

上传的附件
你的回答被采纳后将获得: 10点积分 (将会扣除手续费1点积分。)

keyboard_arrow_left上一篇 : C++Builder 编程工具太老吗? 想问下什么是双缓冲绘图技术?怎么理解呢? : 下一篇keyboard_arrow_right

3个回答

Foooooooood
2019-01-08 08:39:37

首先阐述两者区别

  • 就起作用的阶段而言: #define是在编译的预处理阶段起作用,而const是在 编译、运行的时候起作用

  • 就起作用的方式而言: #define只是简单的字符串替换,没有类型检查。而const有对应的数据类型,是要进行判断的,可以避免一些低级的错误

  • 就存储方式而言:#define只是进行展开,有多少地方使用,就替换多少次,它定义的宏常量在内存中有若干个备份;const定义的只读变量在程序运行过程中只有一份备份

  • 从代码调试的方便程度而言: const常量可以进行调试的,define是不能进行调试的,因为在预编译阶段就已经替换掉了

综上所述const有以下几个优点

  • const常量有数据类型,编译器可对其类型进行安全检查

  • const常量可进行调试

  • const可节省空间,避免不必要的内存分配,提高效率

const作用

定义常量、修饰函数参数、修饰函数返回值三个作用。被Const修饰的东西都受到强制保护,可以预防意外的变动,能提高程序的健壮性

  • const常量有数据类型,而宏常量没有数据类型。编译器可以对前者进行类型安全检查。而对后者只进行字符替换,没有类型安全检查,并且在字符替换可能会产生意料不到的错误

  • 有些集成化的调试工具可以对const常量进行调试,但是不能对宏常量进行调试

Carewho
2019-03-27 09:58:31

#define 这个是预编译指令吧?在编译过程中就执行了??

LittleGirl
2019-04-01 10:38:19

一个是变量,一个是常量

精彩评论

  • 说说最近的感想吧(最佳答案不止一个)
    业余时间学学数据结构及算法。。。还有数据库。最好弄个游戏类的软件代码改一改,玩一玩,学一学。
    2020-08-21 10:16:58 thumb_up( 2 )
  • [算法问题] 谁逃课了
    我也看了这个问题,可能是因为输出格式问题没有ac吧……我用了C语言的位运算,用单个数字表示五个人的逃课状况,比如00000就是都没逃课,01100就是只有BC逃课。用到了位进制运算符>>和<<,在递归函数中用了swich,最大数字是32,用char也可以,占用空间会小一些。 我的代码长这样: include<stdio.h>include<stdlib.h>/A->B; BvC; (C^D)v(-C^-D); DvE; E->(A^D)/ int check(int ans) { if ((ans >> 4) && (ans >> 3) % 2 == 0) return 0; if ((((ans >> 3) % 2) && ((ans >> 2) % 2)) || (!((ans >> 3) % 2) && !((ans >> 2) % 2))) return 0; if (((ans >> 2) % 2) - ((ans >> 1) % 2)) return 0; if (!((ans >> 1) % 2) && !(ans % 2)) return 0; if ((ans % 2) && (!(ans >> 4) || !(ans >> 1) % 2)) return 0; return 1;} int ans(int i, int now) { int a; switch (i) { case 1:{ a = ans(2, 0); if(a) return a; else return ans(2, 1); break; } case 2:{ a = ans(3, (now << 1)); if(a) return a; else return ans(3, (now << 1) + 1); break; } case 3:{ a = ans(4, now << 2); if(a) return a; else return ans(4, (now << 1) + 1); break; } case 4:{ a = ans(5, now << 2); if(a) return a; else return ans(5, (now << 1) + 1); break; } case 5:{ now = (now << 1); if (check(now)) return now; else if (check(++now)) return now; else return 0; break; } default: break; }} int main () { int Ans; Ans = ans(1, 0); if (Ans >> 4) printf(“A”); if ((Ans >> 3) % 2) printf(“B”); if ((Ans >> 2) % 2) printf(“C”); if ((Ans >> 1) % 2) printf(“D”); if ((Ans >> 0) % 2) printf(“E”); printf(“\n”); return 0;}
    2021-03-03 11:53:43 thumb_up( 1 )
  • [算法问题] 谁逃课了
    我也看了这个问题,可能是因为输出格式问题没有ac吧……我用了C语言的位运算,用单个数字表示五个人的逃课状况,比如00000就是都没逃课,01100就是只有BC逃课。用到了位进制运算符>>和<<,在递归函数中用了swich,最大数字是32,用char也可以,占用空间会小一些。 我的代码长这样:
    2021-03-03 11:51:38 thumb_up( 1 )
  • [算法问题] 谁逃课了
    给你个借鉴吧 我这边是php语言的基本语法如下:直接一个类实现 /** * 1)如果A逃课,B也一定逃课 * 2)B和C中有且只有一个人参与逃课 * 3)C和D要么都逃,要么都不逃 * 4)D和E至少有一个人逃了 * 5)如果E逃课,则A和D一定参与逃课 */class Truancy{ private $first = 'A'; public $set_list = []; public function __construct($first = ''){ if($first) $this->first = $first; array_push($this->set_list , $this->first); $this->relationship(); } // 主要逻辑 private function relationship(){ if(in_array('A',$this->set_list)){ array_push($this->set_list , 'B'); } if(in_array('B',$this->set_list)){ if(in_array('A',$this->set_list) == false){ array_push($this->set_list , 'A'); } if(in_array('C',$this->set_list)){ $key = array_search('C'); unset($this->set_list[$key]); } } if(in_array('C',$this->set_list)){ if(in_array('B',$this->set_list)){ $key = array_search('B'); unset($this->set_list[$key]); } if(in_array('D',$this->set_list) == false){ array_push($this->set_list , 'D'); } } if(in_array('D',$this->set_list) == false){ if(in_array('E',$this->set_list) == false){ $key = rand(1,2); $array_de = ['D','E']; // 两个随机出一个 如果两个都没有逃课的情况任意选择一个 array_push($this->set_list , $array_de[$key-1]); } } if(in_array('E',$this->set_list)){ if(in_array('D',$this->set_list) == false){ array_push($this->set_list , 'D'); } if(in_array('A',$this->set_list) == false){ array_push($this->set_list , 'A'); array_push($this->set_list , 'B'); if(in_array('C',$this->set_list)){ $key = array_search('C'); unset($this->set_list[$key]); $key = array_search('D'); unset($this->set_list[$key]); } } } // 将结果变成字符串显示(数组集合变成字符串) function merge_arr($v1,$v2) { return $v1 . "" . $v2; } sort($this->set_list); $this->set_list = array_reduce($this->set_list,merge_arr); }}$Truancy = new Truancy("B");// 输出结果var_dump($Truancy->set_list) ;
    2021-01-20 09:35:09 thumb_up( 1 )
  • 基于MFC中创建的TCP/IP中TCP的端点是什么?本机IP地址还是套接字?
    套接字
    2020-12-02 20:21:22 thumb_up( 1 )
  • 分时操作系统中CPU的时间片是越长越好还是越短越好?
    1、优点:缩短周转时间,以及等待时间,提高系统的吞吐量。2、缺点:延长长作业时间,长时间得不到执行,影响调度性能。3、根据任务执行时间长度设置时间片
    2020-11-16 09:06:01 thumb_up( 2 )
  • 说说最近的感想吧(最佳答案不止一个)
    写论文到头秃,计算机学生英语和写作能力也很重要
    2020-06-03 12:22:20 thumb_up( 4 )
eject