Я пытаюсь скомпилировать следующую программу пула потоков, опубликованную в обзоре кода, чтобы проверить ее.
/codereview/55100/platform-independant-thread-pool-v4
Но я получаю ошибки
threadpool.hpp: In member function ‘std::future<decltype (task((forward<Args>)(args)...))> threadpool::enqueue_task(Func&&, Args&& ...)’:
threadpool.hpp:94:28: error: ‘make_unique’ was not declared in this scope
auto package_ptr = make_unique<task_package_impl<R, decltype(bound_task)>> (std::move(bound_task), std::move(promise));
^
threadpool.hpp:94:81: error: expected primary-expression before ‘>’ token
auto package_ptr = make_unique<task_package_impl<R, decltype(bound_task)>>(std::move(bound_task), std::move(promise));
^
main.cpp: In function ‘int main()’:
main.cpp:9:17: error: ‘make_unique’ is not a member of ‘std’
auto ptr1 = std::make_unique<unsigned>();
^
main.cpp:9:34: error: expected primary-expression before ‘unsigned’
auto ptr1 = std::make_unique<unsigned>();
^
main.cpp:14:17: error: ‘make_unique’ is not a member of ‘std’
auto ptr2 = std::make_unique<unsigned>();
^
main.cpp:14:34: error: expected primary-expression before ‘unsigned’
auto ptr2 = std::make_unique<unsigned>();
c++
c++11
compiler-errors
c++14
unique-ptr
Али786
источник
источник
make_unique
это функция C ++ 14Ответы:
make_unique
- это новая функция C ++ 14, поэтому она может быть недоступна в вашем компиляторе, даже если она совместима с C ++ 11.Однако вы можете легко свернуть свою собственную реализацию:
template<typename T, typename... Args> std::unique_ptr<T> make_unique(Args&&... args) { return std::unique_ptr<T>(new T(std::forward<Args>(args)...)); }
(К вашему сведению, вот последняя версия,
make_unique
которая была выбрана для C ++ 14. Она включает дополнительные функции для работы с массивами, но общая идея остается той же.)источник
-std=c++1y
командную строку.Если у вас последняя версия компилятора, вы можете изменить следующее в настройках сборки:
C++ Language Dialect C++14[-std=c++14]
У меня это работает.
источник
1. версия gcc> = 5
2.CXXFLAGS + = -std = c ++ 14
3. #include <memory>
источник
Это происходит со мной во время работы с XCode (я использую самую последнюю версию XCode в 2019 году ...). Я использую CMake для интеграции сборки. Использование следующей директивы в CMakeLists.txt исправило это для меня:
set(CMAKE_CXX_STANDARD 14)
.Пример:
cmake_minimum_required(VERSION 3.14.0) set(CMAKE_CXX_STANDARD 14) # Rest of your declarations...
источник
Если вы застряли в C ++ 11 , вы можете получить
make_unique
от спускаться с крутизны на веревке-CPP , коллекцию с открытым исходным кодом библиотеки C ++ , взятых из внутренней кодовую Google.источник
В моем случае мне нужно было обновить std = c ++
Я имею в виду, что в моем файле Gradle было это
android { ... defaultConfig { ... externalNativeBuild { cmake { cppFlags "-std=c++11", "-Wall" arguments "-DANDROID_STL=c++_static", "-DARCORE_LIBPATH=${arcore_libpath}/jni", "-DARCORE_INCLUDE=${project.rootDir}/app/src/main/libs" } } .... }
Я изменил эту строчку
android { ... defaultConfig { ... externalNativeBuild { cmake { cppFlags "-std=c++17", "-Wall" <-- this number from 11 to 17 (or 14) arguments "-DANDROID_STL=c++_static", "-DARCORE_LIBPATH=${arcore_libpath}/jni", "-DARCORE_INCLUDE=${project.rootDir}/app/src/main/libs" } } .... }
Это оно...
источник