std::move_only_function::operator bool
Von cppreference.com
< cpp | utility | functional | move only function
| explicit operator bool() const noexcept; |
(seit C++23) | |
Prüft, ob *this ein aufrufbares Ziel speichert, d. h. nicht leer ist.
Inhalt |
[bearbeiten] Parameter
(keine)
[bearbeiten] Rückgabewert
true, wenn *this ein aufrufbares Ziel speichert, andernfalls false.
[bearbeiten] Beispiel
Führen Sie diesen Code aus
#include <functional> #include <iostream> void sampleFunction() { std::cout << "This is the sample function!\n"; } void checkFunc(std::move_only_function<void() const> const& func) { // Use operator bool to determine if callable target is available. if (func) { std::cout << "Function is not empty! Calling function.\n"; func(); } else std::cout << "Function is empty. Nothing to do.\n"; } int main() { std::move_only_function<void() const> f1{}; std::move_only_function<void() const> f2{sampleFunction}; std::cout << "f1: "; checkFunc(f1); std::cout << "f2: "; checkFunc(f2); }
Ausgabe
f1: Function is empty. Nothing to do. f2: Function is not empty! Calling function. This is the sample function!
[bearbeiten] Siehe auch
| (C++23) |
vergleicht ein std::move_only_function mit nullptr(function) |
| prüft, ob ein Ziel enthalten ist (public member function of std::function<R(Args...)>) |