• Post Reply
  • Bookmark Topic Watch Topic
  • New Topic

java

 
Babar Saeed
Greenhorn
Posts: 13
  • Mark post as helpful
  • send pies
  • Quote
  • Report post to moderator
when i compile the following code
float f = 6.3f % 2.1f;
The answer must be 0.0.
but it's not.
but when i try this code
float f = 8.4f % 2.1f;
the answer is 0.0.

------------------
 
Ajith Kallambella
Sheriff
Posts: 5782
  • Mark post as helpful
  • send pies
  • Quote
  • Report post to moderator
I am moving this post to Java in general( Beginner ) forum. Please restrict the discussions in this forum to topics related to this site.
 
Peter Gragert
Ranch Hand
Posts: 424
  • Mark post as helpful
  • send pies
  • Quote
  • Report post to moderator
Strange, I thaught that % (= modulus computation) is only defined for integers.
But experimenting shows that it works in Java too for floats
and then you can get rounding errors, because not all floats can be expressed exactly in (internal) binary format.
What is done looks like:
6.3f-Math.round(6.3f/2.1f)*2.1f
mimicing 'real modulus' computation.
So I would not use 'modulus' with floats.
 
  • Post Reply
  • Bookmark Topic Watch Topic
  • New Topic