简体   繁体   中英

What defines floating point precision in python?

I learnt of the "exactly equal to" operator in Erlang, which compares not only values , but also data types of numbers, and I was curious about how things work in Python and its lone "equals to" operator. So after making sure that

>>> 1 == 1.0 
True

I wondered about the floating point precision, and got to this

>>> 0.9999999999999999 == 1
False
>>> 0.99999999999999999 == 1
True
>>>

Could someone explain how floating point precision is determined here? It works the same in both 2.7.1 and 3.1.2

Please check with the Python documentation:

http://docs.python.org/tutorial/floatingpoint.html

It's a peril of using floating-point numbers.

If you need precision at this deep a level, use the Decimal type.

More here: http://docs.python.org/library/decimal.html

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM