Can I set an int
to NaN
? If yes, then how can I check if an int
is NaN
or not?
No, NaN is a floating point value.
Every possible value of an int
is a number.
Edit
The standard says:
6.2.6.2 40) Some combinations of padding bits might generate trap representations, for example, if one padding bit is a parity bit. Regardless, no arithmetic operation on valid values can generate a trap representation other than as part of an exceptional condition such as an overflow, and this cannot occur with unsigned types.
So there may be some implementation specific invalid integer values, but there is no defined way to generate them.
numeric_limits<int>::quiet_NaN()
, of course ;v) . — And seriously, NaN is not a floating point value, it is the absence of any value, FP or otherwise. It just happens to be cheaper to add to an FP format than a fixed-point format. –
Rotterdam quiet_NaN()
will return 0
for int
. –
Nereen Generally (and specifically in the case of C++, to the best of my knowledge): no.
Integer NaN
Most fixed sized integer formats do not have any way of explicitly indicating invalid data.
ilogb
uses FP_ILOGB0
, INT_MAX
and FP_ILOGBNAN
to encode the invalid results (of int
type) from the mathematically invalid inputs. These are invalid in the sense of the fact that the function may also raise the FE_INVALID
floating-point exception in the same conditions. –
Interpretive I think the most proper API to handle failures is to return a second integer error code in your api like:
int myfunc(args, int* realReturn);
The returned int is an error code.
The previous output is passed as a pointer in calling code:
int myInt;
if (myFunc(args, &myInt) != 0) {
//handle error
}
You don't have any specific int value as Nan. What normally people do is use some large integer to represent this value. IF it is unsigned int then its normally use -1.
© 2022 - 2024 — McMap. All rights reserved.
unsigned char
is guaranteed not to have any. – Linkage