Witam,
Mamy w teamie napisany dość spory projekt w oparciu o MySQL i pola typu DOUBLE. Jak pewnie wszyscy wiecie nie jest rozwiązanie idealne kiedy przyjdzie nam pomnożyć coś, co okazuje się mieć błędny wynik przy wykonaniu tej operacji matematycznej na doublach.
Dziwi mnie niesamowicie, że nie ma typu prostego decimal, a jest tylko klasa BigDecimal. Nie ma też przeciążąnia operatorów, możliwości definiowania funkcji rzutującej ani rozszerzenia doubla o swoje metody.
Jak zatem zamienić:
double wynik = (45.6 * 12.2) - (6 / 3);
Na jakiekolwiek decimale? Przecież poniższa składnia jest nie do przełknięcia:
BigDecimal wynik = (new BigDecimal(45.6).multiply(new BigDecimal(12.2)) - (new BigDecimal(6).divide(new BigDecimal(3)));
A tworzenie stu zmiennych i używanie metod i tak robi straszny syf w kodzie, zwłaszcza, że tych zmiennych w naszym przypadku nie będzie 4, a znacznie więcej dla np jednej funkcji:
BigDecimal a = new BigDecimal(45.6);
BigDecimal b = new BigDecimal(12.2);
BigDecimal c = new BigDecimal(6);
BigDecimal d = new BigDecimal(3);
BigDecimal wynik = a.multiply(b) - c.divide(d);
Jesteśmy dość zieloni w Javie. Jak taki problem powinien być rozwiązany? Jeżeli cały świat stosuje BigDecimale w sposób jaki opisałem powyżej, to jest to jakas abstrakcja dla mnie. Czemu Oracle nie może dodać typu prostego, który wewnątrz swoich metod będzie miał zaszyte funkcjonalności BigDecimala?
Jak powinniśmy podejść do rozwiązania tego zagadnienia? Abstrahując od tego, że najlepiej dla nas byłoby gdyby nie trzeba było przepisywać kodu ręcznie.
Pozdrawiam.