首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

在C++中使用"#define"的替代方法?为什么不赞成?

在C++编程中,使用#define的替代方法是为了避免一些#define的局限性,如预处理指令无法被const限定、#define定义的宏名称在代码中可见等。以下是一些常用的替代方法:

  1. 使用const限定符:
代码语言:c++
复制

#include <iostream>

int main() {

代码语言:txt
复制
   const int value = 42;
代码语言:txt
复制
   std::cout << "Value: " << value << std::endl;
代码语言:txt
复制
   return 0;

}

代码语言:txt
复制
  1. 使用inline关键字:
代码语言:c++
复制

#include <iostream>

inline int add(int a, int b) {

代码语言:txt
复制
   return a + b;

}

int main() {

代码语言:txt
复制
   int x = 10;
代码语言:txt
复制
   int y = 20;
代码语言:txt
复制
   int sum = add(x, y);
代码语言:txt
复制
   std::cout << "Sum: " << sum << std::endl;
代码语言:txt
复制
   return 0;

}

代码语言:txt
复制
  1. 使用constexpr关键字:
代码语言:c++
复制

#include <iostream>

constexpr int add(int a, int b) {

代码语言:txt
复制
   return a + b;

}

int main() {

代码语言:txt
复制
   int x = 10;
代码语言:txt
复制
   int y = 20;
代码语言:txt
复制
   int sum = add(x, y);
代码语言:txt
复制
   std::cout << "Sum: " << sum << std::endl;
代码语言:txt
复制
   return 0;

}

代码语言:txt
复制
  1. 使用inlineconstexpr关键字:
代码语言:c++
复制

#include <iostream>

inline constexpr int add(int a, int b) {

代码语言:txt
复制
   return a + b;

}

int main() {

代码语言:txt
复制
   int x = 10;
代码语言:txt
复制
   int y = 20;
代码语言:txt
复制
   int sum = add(x, y);
代码语言:txt
复制
   std::cout << "Sum: " << sum << std::endl;
代码语言:txt
复制
   return 0;

}

代码语言:txt
复制
  1. 使用#define定义常量:
代码语言:c++
复制

#include <iostream>

#define CONSTANT_VALUE 42

int main() {

代码语言:txt
复制
   int value = CONSTANT_VALUE;
代码语言:txt
复制
   std::cout << "Value: " << value << std::endl;
代码语言:txt
复制
   return 0;

}

代码语言:txt
复制
  1. 使用constexpr定义常量:
代码语言:c++
复制

#include <iostream>

constexpr int value = 42;

int main() {

代码语言:txt
复制
   std::cout << "Value: " << value << std::endl;
代码语言:txt
复制
   return 0;

}

代码语言:txt
复制
  1. 使用C++11引入的constexpr关键字:
代码语言:c++
复制

#include <iostream>

constexpr int add(int a, int b) {

代码语言:txt
复制
   return a + b;

}

int main() {

代码语言:txt
复制
   int x = 10;
代码语言:txt
复制
   int y = 20;
代码语言:txt
复制
   int sum = add(x, y);
代码语言:txt
复制
   std::cout << "Sum: " << sum << std::endl;
代码语言:txt
复制
   return 0;

}

代码语言:txt
复制
  1. 使用C++14引入的inline关键字:
代码语言:c++
复制

#include <iostream>

inline int add(int a, int b) {

代码语言:txt
复制
   return a + b;

}

int main() {

代码语言:txt
复制
   int x = 10;
代码语言:txt
复制
   int y = 20;
代码语言:txt
复制
   int sum = add(x, y);
代码语言:txt
复制
   std::cout << "Sum: " << sum << std::endl;
代码语言:txt
复制
   return 0;

}

代码语言:txt
复制
  1. 使用C++17引入的constexpr关键字和inline关键字:
代码语言:c++
复制

#include <iostream>

constexpr inline int add(int a, int b) {

代码语言:txt
复制
   return a + b;

}

int main() {

代码语言:txt
复制
   int x = 10;
代码语言:txt
复制
   int y = 20;
代码语言:txt
复制
   int sum = add(x, y);
代码语言:txt
复制
   std::cout << "Sum: " << sum << std::endl;
代码语言:txt
复制
   return 0;

}

代码语言:txt
复制
  1. 使用C++20引入的inline关键字和constexpr关键字:
代码语言:txt
复制
```c++
代码语言:txt
复制
#include <iostream>
页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

为什么静态方法不能使用this

看到这个标题读者,在你们心里多多少少都有自己答案,下面说一下我答案....JVM运行时数据区中有个虚拟机栈(或Java栈),里面是由栈帧'叠加'而成.栈帧由局部变量表,操作数栈,动态连接,方法返回地址等组成. 那么我们就从局部变量表角度解答下这个问题....下面是测试代码,一个静态方法query,一个普通方法shadow,这两个方法参数和函数体完全一样. // 静态方法 public static void query(String year) {...query方法局部变量表,如下 shadow方法局部变量表,如下 我们发现,非静态方法shadow局部变量表中有this,而在静态方法query局部变量表没有this....因此也就解答了文章开头提出问题. 普通方法,局部变量表第一个槽存放了this, 而静态方法局部变量表没有存放this.

1.9K30

C++this指针使用方法.

this指针是调用之前生成。类实例后函数,没有这个说法。类实例化时,仅仅分配类变量空间,并没有为函数分配空间。自从类函数定义完毕后,它就在那儿,不会跑。...C++,类和结构是仅仅有一个差别的:类成员默认是private,而结构是public。 this是类指针,假设换成结构,那this就是结构指针了。...#5:我们仅仅有获得一个对象后,才干通过对象使用this指针,假设我们知道一个对象this指针位置能够直接使用吗? this指针仅仅有成员函数才有定义。...因此,你获得一个对象后,也不能通过对象使用this指针。所以,我们也无法知道一个对象this指针位置(仅仅有成员函数里才有this指针位置)。...当然,成员函数里,你是能够知道this指针位置(能够&this获得),也能够直接使用。 #6:每一个类编译后,是否创建一个类函数表保存函数指针,以便用来调用函数?

1.2K20

C++map使用方法

C++map是一种关联容器,用于存储键值对。它提供了一种非常高效方法来快速查找特定值,并且允许我们根据键来排序和遍历数据。...C++mapmap介绍map是一种使用键值对数据结构,它允许我们使用键来查找值。map键必须是唯一且有序,而值可以重复并且没有特定顺序。...使用find()方法可以map查找给定键值。如果键存在,则find()方法返回指向该元素迭代器。否则,它将返回指向map结尾迭代器。...然后,我们使用find()方法map查找给定键,如果找到则输出相应消息。map删除操作我们可以使用erase()方法从map删除元素。...然后,我们使用lower_bound()和upper_bound()方法查找键值范围内元素。最后,我们遍历找到元素并输出它们键值对。总结:本文中,我们了解了C++map。

23900

C++模拟JAVA内部类方法

有时候我们需要把一批互相关联API用不同类提供给用户,以便简化每个类使用难度。但是这样这些类之间数据共享就成了问题。...JAVA内部类可以自由访问外围类所有数据,所以很时候做这工作,而如果C++也这样做,就变成要增加很多setter和getter。...但是,也可以用以下方法模拟实现: 首先,你内部类头文件一般是被外围类所#include,所以需要在内部类声明前增加“前置声明”: namespace outerspace{ class OuterClass...以上是内部类设定,外部类就很简单,只需要保存内部类指针,然后设置好内部类为友元就可以了: friend InnerClass; private: InnerClass inner_obj; 外部类则需要在初始化过程设置...设计API过程,内部类需要用到外部类任何成员,包括是private,都可以用 outer_obj->XXX直接引用。而外部类则可以直接返回内部类指针(引用)给使用者。

2K40

Android Studio 3.6使用视图绑定替代 findViewById方法

Activity 中使用视图绑定 使用视图绑定时,无须再调用 findViewById 方法,只要直接调用绑定对象对应属性即可。... Activity onCreate 方法,要将 root 传入 setContentView 方法,从而让 Activity 可以使用绑定对象布局。...解决方案: Activity 中使用视图绑定时,一定要将绑定对象 root 属性传入 setContentView() 方法。...每个绑定对象,都会暴露三个静态方法来创建绑定对象实例,下面是每个方法使用场景简要说明: inflate(inflater) — 例如 Activity onCreate 方法里,这类没有父视图需要被传入场合使用...总结 到此这篇关于Android Studio 3.6使用视图绑定替代 findViewById方法文章就介绍到这了。

2.4K31

【虚幻引擎|UE】TArrayC++使用

简介 TArray 类似于STLvector,可以自动扩容,因为提供了相关操作函数,所以当作队列、栈、堆来使用也很方便,是UE4最常用容器类。其速度快、内存消耗小、安全性高。...值 //Init(const ElementType& Element, SizeType Number) IntArray.Init(10, 5); 增删改查 注意:成员函数通常都有多个重载,代码我仅列举部分常用重载函数原型...Args) InitArray.Emplace(3); 两者区别 多数效果相同,细微区别: Add(或 Push)将元素类型实例复制(或移动)到数组。...Emplace 使用给定参数构建元素类型新实例。 总体而言,Emplace 优于 Add,因其可避免调用点创建无需临时变量。...FString,此为忽略大小写词典编纂比较。 稳定排序。 可自定义比较器。

56630

PytorchC++端(libtorch)Windows使用

前言 填一个之前坑啊,本篇姊妹篇——利用PytorchC++前端(libtorch)读取预训练权重并进行预测 这篇文章已经说明了如何在Ubuntu系统中使用libtorch做预测,当初也有朋友问我如何在...Windows版本libtorch,这下就节省了我们编译Pytorch时间,直接可以拿来使用,只要稍微配置一下就可以Windows跑起libtorch了,没有想象那么多步骤,大可放心。...下文中使用代码和之前Ubuntu中使用完全相同,我们不需要进行修改。 同样,首先,我们官网下载适合于Windowslibtorch,因为稳定版出来了,所以我们可以直接拿来使用。...simnet.exe放到一个文件夹,这时,我们点击simnet.exe就可以直接运行了: 后记 libtorchWIndow端使用也不是很复杂,我们根据运行环境不同下载不同版本libtorch...(CPU和GPU),然后使用cmake配置后,利用VS进行编译就可以直接使用,其中遇到问题大部分时环境问题,我们代码并不需要修改,是可以跨平台,我也VS2015和VS2017进行了测试,都是可以

61740

Java为什么不同返回类型不算方法重载?

本文已收录《Java常见面试题》:https://gitee.com/mydb/interview 方法重载是指在同一个类,定义了多个同名方法,但每个方法参数类型或者是参数个数不同就是方法重载...: 那为什么返回类型不能做为方法签名一部分呢?...方法重载使用场景 方法重载经典使用场景是 String 类型 valueOf 方法,valueOf 方法重载有 9 种实现,如下图所示: 它可以将数组、对象和基础数据类型转换成字符串类型...匹配原则5:可变参数匹配 最后将代码方法删除只剩一个可选参数,实现代码如下: public class OverloadExample { public static void main(...总结 同一个类定义了多个同名方法,但每个方法参数类型或者是参数个数不同就是方法重载。方法重载典型使用场景是 String valueOf 方法,它有 9 种实现。

3.3K10

Hanlpubuntu使用方法介绍

HanLP一个很大好处是离线开源工具包,换而言之,它不仅提供免费代码免费下载,而且将辛苦收集词典也对外公开啦,此诚乃一大无私之举.我安装时候,主要参照这份博客: blog.csdn.net...id=50938796 不过该博客主要介绍是windows如何使用hanlp,而ubuntu是linux,所以会有所区别.下面我主要介绍unbuntu安装使用....安装eclipse 终端输入 sudo get-apt install eclipse-platform实现一键安装,然后应用程序找到eclipse 图1.jpg 下载hanlp  访问hanlp...(配置文件),而后面是说明文档,可以不下载 图2.jpg  在下载data.zip时候,下载链接有点隐晦,点击蓝色data-for-1.2.11.zip,就会出现百度云链接啦 图3.jpg...将hanlp.propertie复制至项目的bin目录,修改词典路径 将root路径修改至data保存路径(记得data要解压) 图4.jpg 编程代码示范 图5.JPG 运行结果

1.4K20

c语言random函数vc,C++ 随机函数random函数使用方法

大家好,又见面了,我是你们朋友全栈君。 C++ 随机函数random函数使用方法 一、random函数不是ANSI C标准,不能在gcc,vc等编译器下编译通过。...随机数生成器总是以相同种子开始,所以形成伪随机数列也相同,失去了随机意义。(但这样便于程序调试) 2、C++另一函数srand(),可以指定不同数(无符号整数变元)为种子。...// C++随机函数(VC program) #include #include #include #define MAX 100 void main() { srand( (unsigned...通常rand()产生随机数每次运行时候都是与上一次相同,这是有意这样设计,是为了便于程序调试。...三、按要求设置概率 比如要设置一个10%概率问题,我们可以采取rand()函数来实现,if条件句判断里,用rand()得到值%一个设定值,再与另一个值做“==”运算。

3.9K20

Vueset、delete方法列表渲染使用

不知大家是否有过类似的经历,比如说for循环渲染数组或者对象数据,渲染完成后,给数组或者对象添加、修改、删除数据后却没有页面渲染出来。...本篇就是来解释说明修改数组和对象数据视图立马更新问题,要掌握各种情况和set、delete方法使用 数组数据渲染后修改、新增、删除问题 <!...当然,set方法和delete方法不仅仅是Vue全局方法,也是实例方法,这个我们放在第二个例子讲解。...综上所述,数组要能直接触发视图更新页面上渲染出来方法 1.利用数组api方法 2.改变数组指向内存地址(改引用) 3.利用Vueset、delete方法操作数组(推荐) 对象数据渲染后修改...$delete(vm.userInfo, "age") 经过我测试这都是可以,根据需要使用 综上所述 虽然修改数组、对象数据都可以直接改变引用地址实现,但是不推荐。

3.3K10

C++输入函数scanf使用方法详解

一、scanf基本用法 scanf函数是C和C++中常用输入函数之一,可以从用户输入标准输入流stdin读取格式为指定类型数据。...由于前一个scanf读取整数后面有一个换行符缓冲区,后一个scanf会读取这个换行符,而不是我们期望字符: #include  int main() {     int a;...六、scanf输入数据类型转换 使用scanf函数读取数据时,有时候会遇到数据类型转换问题。如果输入数据类型与要求数据类型不匹配,可以通过类型转换函数进行转换。...八、总结 本文中,我们介绍了C和C++中常用输入函数scanf使用方法,包括基本用法、格式化字符串、返回值、输入缓冲区问题、输入限制、输入数据类型转换和安全问题等方面。...相信通过本文学习,读者已经掌握了scanf函数基本使用方法,并能够熟练运用scanf函数进行数据输入。

99460

Mayer能量分解方法及其Amesp使用

而本文将介绍可以获得分子中原子能量以及原子对之间相互作用Mayer能量分解方法7及其Amesp使用。...Vyboishchikov等人工作,εxc(r)使用一组以原子为中心辅助基函数进行展开,而εAxc(r)则以原子A为中心辅助基函数表示: (11)式,ξk为待定拟合系数,使用最小二乘法求得...Amesp,为保证总能量拟合过程不变,添加了以下约束条件: 求解如下线性方程组,即可得到拟合系数ξk: 上式: 值得注意是,εxc(r)乘以一个权重函数w(r)不影响总能量结果...能量分解Amesp使用 这里介绍一个简单使用Amesp计算NH3分子Mayer能量分解例子,其输入为: % npara 4 !...def2/J,若想使用其他辅助基组,需要在>ope模块做如下修改: >ope dfset def2-JK end 其中dfset后面为具体辅助基组,也可以使用自定义基组,关键词为define,做法可以参考

21730

【虚幻引擎|UE4】TArrayC++使用

简介TArray 类似于STLvector,可以自动扩容,因为提供了相关操作函数,所以当作队列、栈、堆来使用也很方便,是UE4最常用容器类。其速度快、内存消耗小、安全性高。...Element值//Init(const ElementType& Element, SizeType Number)IntArray.Init(10, 5);图片增删改查注意:成员函数通常都有多个重载,代码我仅列举部分常用重载函数原型...Args)InitArray.Emplace(3);两者区别多数效果相同,细微区别:Add(或 Push)将元素类型实例复制(或移动)到数组。Emplace 使用给定参数构建元素类型新实例。...总体而言,Emplace 优于 Add,因其可避免调用点创建无需临时变量。...FString,此为忽略大小写词典编纂比较。稳定排序。可自定义比较器。

59900

pullup和pulldownverilog使用方法

_<1 pullup和pulldown介绍pullup和pulldown并非是verilog内置原语,仅在仿真或综合过程起作用,用来设置信号默认状态实际硬件电路,用来代表上拉和下拉,就比如在...I2C,SCL和SDA两个信号是open-drain实际使用过程往往需要接上拉电阻,如下图图片接在VCC两个电阻就是上拉电阻,这个上拉电阻verilog中就可以用pullup表示下面结合实例来看看怎么使用...当sel = 1'b1时输出highz,sel = 0时输出0,initial·对sel先后赋值0和1,来看看运行结果图片可以看到当sel = 0时,dout = 0,当sel = 1时,dout...= z,这个结果符合预期注意,在这个例子,并没有使用到pullup,下面给出使用pullup例子2 使用pullup和pulldown情况`timescale 1ns/10psmodule tb;...R和一个电阻无穷大NMOS串联,那么OUT点电压自然约等于VDD---OK,先这样,至于在用pullup时候为什么不能用logic声明,下次介绍吧

73400

PHP如何使用全局变量方法详解

有很多方法能够使这些数据成为全局数据,其中最常用就是使用“global”关键字申明,稍后文章我们会具体讲解到。...这也是为什么单件不是我们理想解决方法主要原因。 注册模式 让一些对象能够被我们代码中所有的组件使用到(译者注:全局化对象或者数据)最好方法就是使用一个中央容器对象,用它来包含我们所有的对象。...为了更加容易使用注册器,我们把它调用改成单件模式(译者注:不使用前面提到函数传递)。因为我们程序只需要使用一个注册器,所以单件模式使非常适合这种任务。...虽然这些变量都非常标准,而且在你使用也不会出什么问题,但是某些情况下,你可能同样需要使用注册器来封装它们。 一个简单解决方法就是写一个类来提供获取这些变量接口。...> 正如你看到,现在我们不再依靠任何全局变量了,而且我们完全让这些函数远离了全局变量。 结论 本文中,我们演示了如何从根本上移除代码全局变量,而相应用合适函数和变量来替代

7.2K100
领券