c – 如何在遵守得墨忒耳法的同时延迟加载?
发布时间:2020-12-16 07:30:02 所属栏目:百科 来源:网络整理
导读:我想遵守得墨忒耳法.但我还想懒惰加载一些传递给构造函数的对象.我应该如何实现呢?通过包装类?传递函数指针? 解决方法 您实际上可以编写一个通用的包装器来完成此任务: template typename Tclass Lazy {public: explicit Lazy(T const t): _loader(),_it
我想遵守得墨忒耳法.但我还想懒惰加载一些传递给构造函数的对象.我应该如何实现呢?通过包装类?传递函数指针?
解决方法
您实际上可以编写一个通用的包装器来完成此任务:
template <typename T> class Lazy { public: explicit Lazy(T const& t): _loader(),_item(t) {} explicit Lazy(T&& t): _loader() _item(t) {} explicit Lazy(std::function<T()> l): _loader(l),_item() {} T& operator*() { return this->get(); } T const& operator*() const { return this->get(); } T* operator->() { return &this->get(); } T const* operator->() const { return &this->get(); } private: T& get() { if (not _item) { _item = _loader(); } return *_item; } T const& get() const { if (not _item) { _item = _loader(); } return *_item; } std::function<T()> _loader; mutable boost::optional<T> _item; }; // class Lazy 只要完成,该类就可以保证加载器执行一次.如果未完成,则将在下次访问时重试执行.它不是线程安全的. 用法: // Output prime numbers as text bool isPrime(int); std::string toEnglish(int); void print(int i,Lazy<std::string> const& heavy) { if (not isPrime(i)) { return; } std::cout << *heavy << "n"; } int main(int argc,char* argv[]) { if (argc < 2) { return 1; } int max = atoi(argv[1]); for (int i = 2; i <= max; ++i) { print(i,[=](){ return toEnglish(i); }); // ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~ C++11 lambda syntax } } 在这里,toEnglish只用于素数. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |