Why does NSDecimalNumber.notANumber.intValue return 9?
Asked Answered
C

1

5

I found a bug in my code that is caused by NSDecimalNumber.notANumber.intValue returning 9, while I would expect NaN (as floatValue or doubleValue return). Does anybody know why?

enter image description here

Colombia answered 7/1, 2019 at 12:20 Comment(6)
There is no integer value which represents NaN.Hindoo
@MartinR has this 9 something to do with maximal value for Int64 (9223372036854775807)?Rejoice
@RobertDresler Definitely not. I would guess this will have something to do with the binary value of NaN representation.Understandable
According to Apple doc "If you ask an NSNumber object for its value using a type that cannot hold the value, you get back an erroneous result", could this be it?Rotten
@JoakimDanielson it would make sense, for Int32 it is -2147483648. But still, why not -9223372036854775808 for Int64 instead of 9?Rejoice
Thanks everyone, I learned a lot here!Colombia
K
6

Like mentioned by Joakim Danielson and noted in the Apple Developer Documentation

... Because numeric types have different storage capabilities, attempting to initialize with a value of one type and access the value of another type may produce an erroneous result ...

And since Swift's Int struct cannot represent NaN values, you get this erroneous result.

Instead you could use Int's Failable Initialiser init(exactly:) that converts your NSDecimalNumber to an Int? that will either contain it's value or be nil if it is not representable by an Int.

let strangeNumber = NSDecimalNumber.notANumber          // nan
let integerRepresentation = Int(exactly: strangeNumber) // nil
Katti answered 7/1, 2019 at 12:45 Comment(1)
In Swift you should use Decimal.nan anyway, not NSDecimalNumber.Understandable

© 2022 - 2024 — McMap. All rights reserved.