wake-up-neo.com

error :: make_unique ist kein Mitglied von "std"

Ich versuche, das folgende Thread-Pool-Programm zu kompilieren, das bei der Codeüberprüfung veröffentlicht wurde, um es zu testen.

https://codereview.stackexchange.com/questions/55100/platform-independant-thread-pool-v4

Aber ich bekomme die Fehler

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>();
67
Ali786

make_unique ist eine kommende C++ 14-Funktion und daher möglicherweise nicht auf Ihrem Compiler verfügbar, selbst wenn sie C++ 11-kompatibel ist.

Sie können jedoch leicht Ihre eigene Implementierung rollen:

template<typename T, typename... Args>
std::unique_ptr<T> make_unique(Args&&... args) {
    return std::unique_ptr<T>(new T(std::forward<Args>(args)...));
}

(FYI, hier ist die endgültige Version von make_unique das wurde in C++ 14 abgestimmt. Dies beinhaltet zusätzliche Funktionen zur Abdeckung von Arrays, aber die allgemeine Idee ist immer noch dieselbe.)

116
ComicSansMS

Wenn Sie über den neuesten Compiler verfügen, können Sie in Ihren Build-Einstellungen Folgendes ändern:

 C++ Language Dialect    C++14[-std=c++14]

Das funktioniert bei mir.

14
Anil8753

1.gcc version> = 5
2.CXXFLAGS + = -std = c ++ 14
3. #include <Speicher>

3
Jagger Yu

Dies passiert mir, wenn ich mit XCode arbeite (ich verwende die aktuellste Version von XCode im Jahr 2019 ...). Ich benutze CMake für die Build-Integration. Die Verwendung der folgenden Anweisung in CMakeLists.txt hat dies für mich behoben:

set(CMAKE_CXX_STANDARD 14).

Beispiel:

cmake_minimum_required(VERSION 3.14.0)
set(CMAKE_CXX_STANDARD 14)

# Rest of your declarations...
0
swdon

In meinem Fall musste ich das std = c ++ aktualisieren

Ich meine in meiner gradle datei war das

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"
            }
        }
       ....
    }

Ich habe diese Zeile geändert

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"
            }
        }
       ....
    }

Das ist es...