std::experimental::source_location::function_name
Von cppreference.com
< cpp | experimental | source location
| constexpr const char* function_name() const noexcept; |
(Library Fundamentals TS v2) | |
Gibt den Namen der Funktion zurück, die mit der von diesem Objekt repräsentierten Position verknüpft ist, falls vorhanden.
Inhalt |
[bearbeiten] Parameter
(keine)
[bearbeiten] Rückgabewert
Wenn dieses Objekt eine Position im Körper einer Funktion repräsentiert, wird ein implementierungsdefinierter, nullterminierter Byte-String zurückgegeben, der dem Namen der Funktion entspricht.
Andernfalls wird ein leerer String zurückgegeben.
[bearbeiten] Beispiel
Das folgende Beispiel zeigt, wie mit std::source_location::function_name() der Name einer Funktion, eines Konstruktors, eines Destruktors oder eines überladenen operator() ausgegeben werden kann.
Führen Sie diesen Code aus
#include <experimental/source_location> #include <iostream> #include <string_view> inline void function_name( const std::string_view signature = "()", const std::experimental::source_location& location = std::experimental::source_location::current()) { std::cout << location.function_name() // <- name of the caller! << signature << '\n'; } void foo() { function_name(); } struct S { S() { function_name(); } S(int) { function_name("(int)"); } S& operator=(S const&) { function_name("(const S&)"); return *this; } S& operator=(S&&) { function_name("(S&&)"); return *this; } ~S() { function_name(); } }; int main() { foo(); S p; S q{42}; p = q; p = std::move(q); }
Mögliche Ausgabe
foo() S() S(int) operator=(const S&) operator=(S&&) ~S() ~S()
[bearbeiten] Siehe auch
| gibt die von diesem Objekt repräsentierte Zeilennummer zurück (public member function) | |
| gibt die von diesem Objekt repräsentierte Spaltennummer zurück (public member function) | |
| gibt den von diesem Objekt repräsentierten Dateinamen zurück (public member function) | |
| C++-Dokumentation für Dateiname und Zeileninformationen
| |