Item Avoid float and double if exact answers are required

Problem with float and double:
- Designed for scientific and mathematical calculations, perform binary floating point arithmetic.
- Not suitable for monetary calculations or situations that require exact answers.
- They cannot accurately represent negative powers of ten, such as 0.1, which leads to errors.
Example 1:
Incorrect calculation when subtracting dollar amounts:
System.out.println(1.03 - 0.42); // Resultado: 0.6100000000000001
Example 2:
Error when purchasing nine items for 10 cents each:
System.out.println(1.00 - 9 * 0.10); // Resultado: 0.09999999999999998
Even rounding, errors persist.
Problem with progressive calculations, such as when purchasing sweets at incremental prices of 0.10 to 1.00.
Example 3:
Mistake when buying sweets until you have no more money:
double funds = 1.00;
for (double price = 0.10; funds >= price; price += 0.10) {
funds -= price;
}
System.out.println(funds); // Resultado: 0.3999999999999999
Solution 1: Use BigDecimal
- Ideal for financial calculations and situations where precision is essential.
- Avoid using BigDecimal's double constructor, preferring the String constructor.
Example with BigDecimal:
BigDecimal funds = new BigDecimal("1.00");
BigDecimal price = new BigDecimal("0.10");
int itemsBought = 0;
while (funds.compareTo(price) >= 0) {
funds = funds.subtract(price);
price = price.add(new BigDecimal("0.10"));
itemsBought++;
}
System.out.println(itemsBought + " items bought. Money left: " + funds);
// Resultado: 4 items bought. Money left: 0.00
The calculation is now precise.
Disadvantages of BigDecimal:
- Less convenient to use than primitive types.
- Slower, especially for large volumes of operations.
Solution 2: Use int or long
- To avoid accuracy problems, do calculations in cents, using int or long instead of dollars with double.
Example with int (in cents):
int funds = 100; // 1.00 dólar = 100 centavos
int price = 10; // 0.10 dólar = 10 centavos
int itemsBought = 0;
while (funds >= price) {
funds -= price;
price += 10;
itemsBought++;
}
System.out.println(itemsBought + " items bought. Money left: " + funds);
// Resultado: 4 items bought. Money left: 0
The calculation is fast and accurate.
Conclusion:
- Do not use float or double for calculations that require exact precision.
- Use BigDecimal for monetary calculations or situations that require decimal precision.
- Use int or long for financial calculations that do not involve large numbers, doing the calculations in cents.
Choices:
- For up to 9 digits, use int.
- For up to 18 digits, use long.
- For larger quantities, use BigDecimal.
- This summary shows that, depending on the context, choosing between BigDecimal, int or long can optimize both precision and performance.
The above is the detailed content of Item Avoid float and double if exact answers are required. For more information, please follow other related articles on the PHP Chinese website!
Hot AI Tools
Undress AI Tool
Undress images for free
Undresser.AI Undress
AI-powered app for creating realistic nude photos
AI Clothes Remover
Online AI tool for removing clothes from photos.
Clothoff.io
AI clothes remover
Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!
Hot Article
Hot Tools
Notepad++7.3.1
Easy-to-use and free code editor
SublimeText3 Chinese version
Chinese version, very easy to use
Zend Studio 13.0.1
Powerful PHP integrated development environment
Dreamweaver CS6
Visual web development tools
SublimeText3 Mac version
God-level code editing software (SublimeText3)
Comparing Java Frameworks: Spring Boot vs Quarkus vs Micronaut
Aug 04, 2025 pm 12:48 PM
Pre-formanceTartuptimeMoryusage, Quarkusandmicronautleadduetocompile-Timeprocessingandgraalvsupport, Withquarkusoftenperforminglightbetterine ServerLess scenarios.2.Thyvelopecosyste,
What is a deadlock in Java and how can you prevent it?
Aug 23, 2025 pm 12:55 PM
AdeadlockinJavaoccurswhentwoormorethreadsareblockedforever,eachwaitingforaresourceheldbytheother,typicallyduetocircularwaitcausedbyinconsistentlockordering;thiscanbepreventedbybreakingoneofthefournecessaryconditions—mutualexclusion,holdandwait,nopree
How to join an array of strings in Java?
Aug 04, 2025 pm 12:55 PM
Using String.join() (Java8) is the easiest recommended method for connecting string arrays, just specify the separator directly; 2. For old versions of Java or when more control is needed, you can use StringBuilder to manually traverse and splice; 3. StringJoiner is suitable for scenarios that require more flexible formats such as prefixes and suffixes; 4. Using Arrays.stream() combined with Collectors.joining() is suitable for filtering or converting the array before joining; To sum up, if Java8 and above is used, the String.join() method should be preferred in most cases, which is concise and easy to read, but for complex logic, it is recommended.
How to implement a simple TCP client in Java?
Aug 08, 2025 pm 03:56 PM
Importjava.ioandjava.net.SocketforI/Oandsocketcommunication.2.CreateaSocketobjecttoconnecttotheserverusinghostnameandport.3.UsePrintWritertosenddataviaoutputstreamandBufferedReadertoreadserverresponsesfrominputstream.4.Usetry-with-resourcestoautomati
Comparing Java Build Tools: Maven vs. Gradle
Aug 03, 2025 pm 01:36 PM
Gradleisthebetterchoiceformostnewprojectsduetoitssuperiorflexibility,performance,andmoderntoolingsupport.1.Gradle’sGroovy/KotlinDSLismoreconciseandexpressivethanMaven’sverboseXML.2.GradleoutperformsMaveninbuildspeedwithincrementalcompilation,buildcac
How to compare two strings in Java?
Aug 04, 2025 am 11:03 AM
Use the .equals() method to compare string content, because == only compare object references rather than content; 1. Use .equals() to compare string values equally; 2. Use .equalsIgnoreCase() to compare case ignoring; 3. Use .compareTo() to compare strings in dictionary order, returning 0, negative or positive numbers; 4. Use .compareToIgnoreCase() to compare case ignoring; 5. Use Objects.equals() or safe call method to process null strings to avoid null pointer exceptions. In short, you should avoid using == for string content comparisons unless it is explicitly necessary to check whether the object is in phase.
How to send and receive messages over a WebSocket in Java
Aug 16, 2025 am 10:36 AM
Create a WebSocket server endpoint to define the path using @ServerEndpoint, and handle connections, message reception, closing and errors through @OnOpen, @OnMessage, @OnClose and @OnError; 2. Ensure that javax.websocket-api dependencies are introduced during deployment and automatically registered by the container; 3. The Java client obtains WebSocketContainer through the ContainerProvider, calls connectToServer to connect to the server, and receives messages using @ClientEndpoint annotation class; 4. Use the Session getBasicRe
Correct posture for handling non-UTF-8 request encoding in Spring Boot application
Aug 15, 2025 pm 12:30 PM
This article discusses the mechanism and common misunderstandings of Spring Boot applications for handling non-UTF-8 request encoding. The core lies in understanding the importance of the charset parameter in the HTTP Content-Type header, as well as the default character set processing flow of Spring Boot. By analyzing the garbled code caused by wrong testing methods, the article guides readers how to correctly simulate and test requests for different encodings, and explains that Spring Boot usually does not require complex configurations to achieve compatibility under the premise that the client correctly declares encoding.


