std:: isinf
|
Definiert im Header
<cmath>
|
||
| (1) | ||
|
bool
isinf
(
float
num
)
;
bool
isinf
(
double
num
)
;
|
(seit C++11)
(bis C++23) |
|
|
constexpr
bool
isinf
(
/*floating-point-type*/
num
)
;
|
(seit C++23) | |
|
SIMD-Überladung
(seit C++26)
|
||
|
Definiert im Header
<simd>
|
||
|
template
<
/*math-floating-point*/
V
>
constexpr
typename
/*deduced-simd-t*/
<
V
>
::
mask_type
|
(S) | (seit C++26) |
|
Definiert im Header
<cmath>
|
||
|
template
<
class
Integer
>
bool isinf ( Integer num ) ; |
(A) |
(seit C++11)
(constexpr seit C++23) |
|
S)
Die SIMD-Überladung führt eine elementweise
std::isinf
auf
v_num
aus.
|
(since C++26) |
Inhaltsverzeichnis |
Parameter
| num | - | Gleitkomma- oder Ganzzahlwert |
| v_num | - | ein datenparalleles Objekt einer std::basic_simd Spezialisierung, dessen Elementtyp ein Gleitkommatyp ist |
Rückgabewert
[
0
,
v_num.
size
(
)
)
.
Hinweise
GCC
und
Clang
unterstützen eine
-ffinite-math
Option (zusätzlich impliziert durch
-ffast-math
), die es dem jeweiligen Compiler erlaubt, die Nichtexistenz spezieller IEEE-754 Gleitkommawerte wie NaN, Unendlich oder negative Null anzunehmen. Mit anderen Worten wird angenommen, dass
std::isinf
unter dieser Option immer
false
zurückgibt.
Die zusätzlichen Überladungen müssen nicht exakt wie (A) bereitgestellt werden. Sie müssen lediglich sicherstellen, dass für ihr Argument num vom Ganzzahltyp std :: isinf ( num ) denselben Effekt hat wie std :: isinf ( static_cast < double > ( num ) ) .
Beispiel
#include <cfloat> #include <cmath> #include <iostream> #include <limits> int main() { const double max = std::numeric_limits<double>::max(); const double inf = std::numeric_limits<double>::infinity(); std::cout << std::boolalpha << "isinf(NaN) = " << std::isinf(NAN) << '\n' << "isinf(Inf) = " << std::isinf(INFINITY) << '\n' << "isinf(max) = " << std::isinf(max) << '\n' << "isinf(inf) = " << std::isinf(inf) << '\n' << "isinf(0.0) = " << std::isinf(0.0) << '\n' << "isinf(exp(800)) = " << std::isinf(std::exp(800)) << '\n' << "isinf(DBL_MIN/2.0) = " << std::isinf(DBL_MIN / 2.0) << '\n'; }
Ausgabe:
isinf(NaN) = false isinf(Inf) = true isinf(max) = false isinf(inf) = true isinf(0.0) = false isinf(exp(800)) = true isinf(DBL_MIN/2.0) = false
Siehe auch
|
(C++11)
|
kategorisiert den gegebenen Gleitkommawert
(Funktion) |
|
(C++11)
|
prüft, ob die gegebene Zahl einen endlichen Wert hat
(Funktion) |
|
(C++11)
|
prüft, ob die gegebene Zahl NaN ist
(Funktion) |
|
(C++11)
|
prüft, ob die gegebene Zahl normal ist
(Funktion) |
|
C-Dokumentation
für
isinf
|
|