Big Moose Saloon
 Search | Java FAQ | Recent Topics Register / Login

# How to Format Double value?

aypa genga
Greenhorn

Joined: Nov 26, 2008
Posts: 5
Hi,
i have two double values which are then multiplied.
Can you please tell me how to get the exact values.
Below is the example :

4069976.23 * 1815496.43 = 7389027315749.8589

the code :

double x = 4069976.23d;
double y = 1815496.43d;

double z =x*y;

System.out.println("z :"+z);

the result that i get is
z :7.389027315749858E12

how can i get the exact answer 7389027315749.8589

Ayyappan G
Rob Spoor
Sheriff

Joined: Oct 27, 2005
Posts: 19423

13

Both float and double are simply not that precise. Sure, they can store very large numbers, but part of the precision is lost.

java.math.BigDecimal, although slower, does not have this problem.

SCJP 1.4 - SCJP 6 - SCWCD 5 - OCEEJBD 6
Ranch Hand

Joined: Apr 12, 2009
Posts: 443

Rob Prime wrote:Both float and double are simply not that precise. Sure, they can store very large numbers, but part of the precision is lost.

java.math.BigDecimal, although slower, does not have this problem.

Big Decimal is less convenient than using a primitive arithmetic type, and it’s slower too. An alternative to using BigDecimal is to use int or long, depending on the amounts involved, and to keep track of the decimal point yourself.
If performance is of the essence and the quantities aren’t too big, use int or long. If the quantities don’t exceed nine decimal digits, you can use int; if they don’t exceed eighteen digits, you can use long. If the quantities might exceed eighteen digits, you must use BigDecimal.

Rob Spoor
Sheriff

Joined: Oct 27, 2005
Posts: 19423

13

But you will need another int to store the number of decimals, since this is not fixed. Simply using an int or long is not sufficient. In the end, you'll probably end up with your own version of BigDecimal.

I agree. Here's the link: http://aspose.com/file-tools

subject: How to Format Double value?