Является ли пересылка rvalue напрямую столь же эффективной, как и идеальная пересылка в простом случае? ⇐ C++
Является ли пересылка rvalue напрямую столь же эффективной, как и идеальная пересылка в простом случае?
Я встретил этот код ниже:
шаблон auto ThreadPool::add(F&& f, Args&&... args) -> std::future { используя return_type = имя типа std::result_of::type; auto Task = std::make_shared< std::packaged_task >( std::bind(std::forward(f), std::forward(args)...) ); std::future res = Task->get_future(); { std::unique_lock lock(tasks_mtx); если (стоп) throw std::runtime_error("поставить в очередь остановленный ThreadPool"); Tasks.emplace([task](){ (*task)(); }); } cv.notify_one(); вернуть разрешение; } Он сказал, что это идеальная пересылка, но для меня это сложно, и моему ThreadPool нужно обрабатывать только тип std::function. Поэтому я написал свой собственный ThreadPoll::add:
void Threadpool::add(std::function&& Task){ { std::unique_lock lock(mtx); Tasks.emplace(std::forward(task)); } cv.notify_one(); } Я не уверен, вызывается ли в моем коде конструктор копирования, который делает программу менее эффективной
Надеюсь, кто-нибудь ответит мне, будет ли мой код столь же эффективен, как и сложный, в случае, когда нужно обрабатывать только std::function.
Я встретил этот код ниже:
шаблон auto ThreadPool::add(F&& f, Args&&... args) -> std::future { используя return_type = имя типа std::result_of::type; auto Task = std::make_shared< std::packaged_task >( std::bind(std::forward(f), std::forward(args)...) ); std::future res = Task->get_future(); { std::unique_lock lock(tasks_mtx); если (стоп) throw std::runtime_error("поставить в очередь остановленный ThreadPool"); Tasks.emplace([task](){ (*task)(); }); } cv.notify_one(); вернуть разрешение; } Он сказал, что это идеальная пересылка, но для меня это сложно, и моему ThreadPool нужно обрабатывать только тип std::function. Поэтому я написал свой собственный ThreadPoll::add:
void Threadpool::add(std::function&& Task){ { std::unique_lock lock(mtx); Tasks.emplace(std::forward(task)); } cv.notify_one(); } Я не уверен, вызывается ли в моем коде конструктор копирования, который делает программу менее эффективной
Надеюсь, кто-нибудь ответит мне, будет ли мой код столь же эффективен, как и сложный, в случае, когда нужно обрабатывать только std::function.
-
- Похожие темы
- Ответы
- Просмотры
- Последнее сообщение
-
-
Почему std::array
::operator[] не возвращает ссылку rvalue для объекта rvalue?
Anonymous » » в форуме C++ - 0 Ответы
- 46 Просмотры
-
Последнее сообщение Anonymous
-
-
-
Почему не основан на диапазоне для модификатора RVALUE-reference Match Match-RVALUE?
Anonymous » » в форуме C++ - 0 Ответы
- 15 Просмотры
-
Последнее сообщение Anonymous
-