- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在我的类(class)中,我有很多 setXXX 函数,如下所示:
void setName(const std::string& newName) {
name = newName;
}
这是大多数程序员在 C++11 之前会做的事情。
我了解到(来自 Effective Moderm C++ 的第 25 项)使用转发可以使这些函数更有效率。所以它们看起来如下:
template<typename T>
void setName(T&& newName) {
name = std::forward<T>(newName);
}
我的问题是将所有此类 C++11 之前的设置函数转换为具有转发引用参数的模板是否是个好主意?我目前的理解是它总是有益的,至少我没有看到缺点。
最佳答案
Perfect forwarding 听起来很有趣,但我还没有将它用于 setter。 (虽然,我确实从事性能关键型软件的工作)
根据我的经验,我认为这会使您的代码更难理解,但没有太大好处。让我解释一下:
从现在开始,此设置方法的每个调用者都需要在知道传递什么之前检查成员的类型。让我们假设一个方法“setFile”:
template<typename T>
void setFile(T &&file) { m_file = std::forward<T>(file); }
我们应该用字符串(文件名)、c 风格的文件句柄、文件流、你的库特定的文件包装器来调用这个方法吗?看到这个方法,不清楚用哪个。如果您是代码库的新手,尤其如此。
即使您的类可以很小,可以放在一个终端屏幕上,代码完成也无法为您提供所需的信息。
请注意,如果您使用了错误的类型,编译错误也会变得更加复杂。
这让我们想到了一个问题:您获得了什么?从现在开始,您使用完美转发。换句话说,您可以将 const char *
分配给 std::string
而不会产生性能开销。然而,这样的收获有多大?如果您有性能关键代码,则此重载已经存在。但是,如果代码对性能的要求不高,那么损失几个 CPU 周期也没有关系。
最重要的是,您的编译器(Clang、GCC、MSVC ...)是一个优化编译器。换句话说,它允许你编写你想要的代码而不必担心性能。 (不要误会我的意思,如果代码很关键,请担心,尽管相信许多编译器作者和研究人员会处理显而易见的问题)
因此,如果您有此 setName(const std::string &)
,请确保它已在 header 中实现,以便编译器可以对其进行推理并尝试将其优化为尽可能多。 (对于您自己的类,请确保所有构造函数、析构函数和赋值/强制转换函数对编译器可见)
我怀疑花时间“升级”您的代码是否有用。如果它能带来那么多 yield ,那么基于 clang 的实用程序早就存在了。我什至敢打赌,通过花相同的时间分析您的应用程序和修复容易实现的成果,您会获得更高的性能。
关于c++ - 将 c++11 之前的设置函数更改为带有转发功能的现代模板化函数是个好主意吗,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42454853/
我有一个库(围绕nlohmann / json封装),可以从JSON反序列化: struct MyStruct { int propertyA; std::string propert
如果 的第 1、3、5、7、9、11、13 或 15 位之一,我希望 var 不等于 FALSE输入已设置。 一个似乎相当普遍的解决方案是: int var = 1 & (input >> 1) |
当我说目标类型时,我的意思是使用接收者变量或参数的类型作为信息来推断我分配给它的部分代码。例如,在 C# 中,您会编写类似这样的内容来传递可为 null 的值或 null (空)如有必要: void
我需要从 native 内存读取/写入一堆结构。我想弄清楚我是否应该为结构对齐而烦恼。这是我编写的用于测试的简单代码。它将压缩结构写入未对齐的指针,然后读回该结构: public static uns
采用以下代码: char chars[4] = {0x5B, 0x5B, 0x5B, 0x5B}; int* b = (int*) &chars[0]; (int*) &chars[0] 值将在循环(
因此,当我发现将整个解决问题的方法颠倒过来时,我正在网上搜索最佳实践,以实现使用多个数据存储的存储库模式。这就是我所拥有的... 我的应用程序是一个BI工具,它从四个数据库中提取数据。由于内部限制,我
我想仅使用现代 OpenGL 技术(即没有即时模式的东西)来设置正交投影。我在网络上看到有关如何处理此问题的相互矛盾的信息。 有些人说调用 glMatrixMode(GL_PROJECTION) 然后
我想知道当前的 cpus 是否避免在其中至少一个为零时将两个数字相乘。谢谢 最佳答案 这取决于 CPU 和(在某些情况下)操作数的类型。 较旧/较简单的 CPU 通常使用如下乘法算法: integer
在精美的 OpenGL 新版本(3.0 和 4.0 以上)中,不推荐使用 gl_Vertex 等内置顶点属性 .实际渲染任何东西的“新方法”是为位置、颜色等指定您自己的顶点属性,然后将这些自定义属性绑
在我的 OpenGL 研究(我认为是 OpenGL 红皮书)中,我遇到了一个关节机器人 ARM 模型的示例,该模型由“上臂”、“下臂”、“手”和五个或更多“手指”。每个部分都应该能够独立移动,但受“关
像 Kaby Lake 这样的现代 CPU 如何处理小分支? (在下面的代码中,它是跳转到标签 LBB1_67)。据我所知,分支不会有害,因为跳转低于 16 字节块大小,即解码窗口的大小。 或者是否有
编辑:此问题假设您启用了发生检查。不是关于 setting Prolog flags . 30 年前有很多关于在安全的情况下自动优化发生检查的论文(大约 90% 的谓词,在典型的代码库中)。提出了不同
现在是 2020 年,在 iOS 终于添加了对 Widget 的支持之后,Widget 再次风靡一时。但是,自 2012 年以来,Android 小部件似乎没有更新。 来自 Android docs
我正在看一些关于算法的讲座,教授用乘法作为如何改进朴素算法的例子...... 它让我意识到乘法并不是那么明显,虽然当我编码时我只是认为它是一个简单的原子操作,乘法需要一个算法来运行,它不像求和数字那样
我们将 PIXI.js 用于内部使用 WebGL 进行渲染的游戏。时不时地,我会偶然发现避免 NPOT 纹理(https://developer.mozilla.org/en-US/docs/Web/
我是一名计算机科学专业的学生,即将毕业。我们现在必须用我们选择的语言编写完整的应用程序。我们选择 Objective-C 因为我们都是 Mac 人。 为了让我们的教授高兴,必须做一些事情:-)一项
我正在编写一个带有 x86 后端的 JIT 编译器,并且正在学习 x86 汇编器和机器代码。大约 20 年前,我使用 ARM 汇编程序,并对这些架构之间的成本模型差异感到惊讶。 具体来说,内存访问和分
如果负载与两个较早的存储重叠(并且负载未完全包含在最旧的存储中),现代 Intel 或 AMD x86 实现能否从两个存储转发以满足负载? 例如,考虑以下序列: mov [rdx + 0], eax
http://www.lighthouse3d.com/opengl/glsl/index.php?ogldir2 报告 OpenGL 上下文中的半向量是“眼睛位置 - 灯光位置”,但接着又说“幸运的
在现代 (GL3.3+) GPU 上使用 GLSL 时,在统一上进行分支的可能成本是多少? 在我的引擎中,我已经达到了拥有大量着色器的程度。我为其中的很多预设了几种不同的质量预设。就目前情况而言,我在
我是一名优秀的程序员,十分优秀!