可选boost缓存
cacheing with boost optional
我想在一个不可变的类中创建一个缓存的结果,比如:
class Rot3() {
mutable boost::optional<Matrix3> transpose_;
Rot3 inverse() const {...}
Matrix3 matrix() const {...}
const Matrix3& transpose() const {
if (!transpose_)
transpose_.reset(inverse().matrix());
return *transpose_;
}
};
它简明扼要,似乎行之有效。这种做法好吗?有更好的方法吗?
注意,由于C++11将并发语义引入到C++内存&在执行模型中,成员函数上的const
限定符获得了额外的含义:线程安全也就是说,应该可以同时调用对象上的const
函数。事实上,如果您将对象与标准库一起使用,则必须如此(这是与标准库交互的先决条件之一)。
因此,为了回答您的问题:它本身没有什么问题。但为了使您的类与标准库一起使用,您实际上应该同步对transpose_
(或任何其他可变成员)的访问。
同步对性能的影响是否大于缓存的好处,由我们来决定。与任何其他优化一样,"我应该这样做吗?"的问题最好通过"评测建议是什么?"
这种做法好吗?
是的,除非你实际上并不需要。这是一种优化,所以你可能根本不需要缓存(即,如果你不经常调用transpose()
,或者每个实例最多调用一次)。
有更好的方法吗?
想不出比这更简单/更地道的了。
相关文章:
- 理解boost::asio-async_read在无需读取内容时的行为
- boost::进程间消息队列引发错误
- 如何运行位于boost/libs/python/example/tutorial目录中的hello.cpp和Jamfil
- cmake如何在fedora工作站中找到boost静态库包
- CMake项目Boost库错误:Boost/config/compiler/gcc.hpp:165:10:致命错误:cs
- Boost Graph Library,修复节点大小
- 什么是"#include <boost/functional/hash.hpp> "?
- 基于boost的程序的静态链接——zlib问题
- C++:如何在CLion IDE中安装Boost
- C++Boost Asio Pool线程,带有lambda函数和传递引用变量
- 如何在boost beast http请求中设置http头
- Boost Spirit,获取迭代器内部语义动作
- boost::asio::steady_timer()与sleep()我应该使用哪一个
- boost::asio如何生成多个协同程序,然后加入它们
- cmake更新缓存的变量
- 试图对缓存进行跨步测试,但程序并没有结束
- 当我尝试使用 sstream 和分面将 Boost Time_duration转换为字符串时,我没有得到所需的格式
- Visual Studio(或任何其他工具)能否将地址解释为调用堆栈(boost上下文)的开头
- 可选boost缓存
- 缓存的getter/calculations模式|具有依赖项跟踪的boost类