如何正确"perfect forward"吸气功能?
How to correctly "perfect forward" getter functions?
我正在为C++14创建一个JSON库,并尽可能利用移动语义。
我的Value
类有几个setter和getter,它们总是尽可能地移动:
template<class T> void setObj(T&& x) { type = Obj; hObj.init(forward<T>(x)); }
template<class T> void setArr(T&& x) { type = Arr; hArr.init(forward<T>(x)); }
template<class T> void setStr(T&& x) { type = Str; hStr.init(forward<T>(x)); }
auto& getObj() & noexcept { assert(is<Obj>()); return hObj; }
auto& getArr() & noexcept { assert(is<Arr>()); return hArr; }
auto& getStr() & noexcept { assert(is<Str>()); return hStr; }
const auto& getObj() const& noexcept { assert(is<Obj>()); return hObj; }
const auto& getArr() const& noexcept { assert(is<Arr>()); return hArr; }
const auto& getStr() const& noexcept { assert(is<Str>()); return hStr; }
auto getObj() && noexcept { assert(is<Obj>()); return move(hObj); }
auto getArr() && noexcept { assert(is<Arr>()); return move(hArr); }
auto getStr() && noexcept { assert(is<Str>()); return move(hStr); }
正如您从代码中看到的,使用模板和通用引用,完美的转发setter函数非常容易。
如何对getter函数执行同样的操作我很确定我必须使用模板返回类型,但我不确定如何复制ref限定符和const正确性。
由于您不能对ref限定符和成员常量进行模板化,因此遗憾的答案是您不能。你必须把它们写出来。
这与C++模板不同,但它能完成任务。
#define GETTERS(V)
V(Obj)
V(Arr)
V(Str)
#define VISIT(X)
auto &get ## X() & noexcept { assert(is<X>()); return h ## Obj; }
const auto &get ## X() const& noexcept { assert(is<X>()); return h ## Obj; }
auto &get ## X() && noexcept { assert(is<X>()); return std::move(h ## Obj); }
GETTERS(VISIT)
相关文章:
- 在执行其他功能的同时播放动画(LED矩阵和Arduino/ESP8266)
- 多态性和功能结合
- 带内存和隔离功能的SQLite
- 在CMakeLists.txt的安装功能中使用.cmake文件有什么用
- 类模板的成员功能的定义在单独的TU中完全专业化
- 有没有一种方法可以创建一个带有哈希表的数据库,该哈希表具有恒定时间查找功能
- 如何在C++中获得"静态纯虚拟"功能?
- 两个文件使用彼此的功能-如何解决
- 我应该实现右值推送功能吗?我应该使用std::move吗
- QML按钮点击功能执行顺序
- 无法理解此 return 语句的功能,没有它就会发生运行时错误
- 有没有可能有一个只有ADL才能找到的非好友功能
- 功能样式转换从 'int' 到 'ItemType' 的匹配转换
- 文件系统:复制功能的速度秘诀是什么
- 在用于格式4的arm模拟器中实现功能时的一个问题
- 如何在Directwrite中获得给定字体的可用OpenType功能
- 对可变参数使用声明.如何选择正确的功能
- Forward宣布了Singleton班级,并带有Freshial声明的朋友功能
- 如何跟踪LLVM验证功能错误"Expected no forward declarations!"?
- 如何正确"perfect forward"吸气功能?