Refactor projektu z double do BigDecimal

0

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.

0

Użyjcie Kotlina.
Kotlin jest kompatybilny z javą, a Intellij umożliwia w locie podmianę składni z javy na kotlina. Czyli konwersja java na kotlin, a potem zmiana na BigDecimal i gotowe.

Przy okazji. Wiele lat pisałem taki kod na BigDecimalach w javie. To nie jest trudne. Wystarczy tylko schować godność osobistą do szafy.

0

Ok, z tego co patrzę Kotlin pozwala używać operatorów do wykonywania działań na BigDecimalach, czyli w moim przypadku miałbym już:

BigDecimal wynik = new BigDecimal(45.6) * new BigDecimal(12.2) - new BigDecimal(6) / new BigDecimal(3);

Tylko czy Intellij umożliwi pełną zamianę typów z doubla? Czy wykryje definicje wszystkich zmiennych i pozamienia je na kontruktory BigDecimalowe?

0

Nie zrobi tego sam z siebie. Ale po tym jak przerobisz kod na kotlin z doublami to nastepny krok to po prostu search i replace double na BigDecimal.

0

W sensie jakimś narzędziem czy zwykłym Ctrl+Shift+H, bo wydaje się, ze jednym zapytaniem nie jesteś w stanie zreplacować "double XX = YY" na "BigDecimal XX = new BigDecimal(YY);" bo nigdy nie wiesz co będzie w środku ciągu, na który chcesz zamienić.

1

Ctrl+Shift+H ? w czym ?
**IntelliJ **ma przerabianie Javy na kotlina i zrobi Ci double xx = yy na var xx:double = yy. Potem zmiana :double na :BigDecimal to search replace.

1 użytkowników online, w tym zalogowanych: 0, gości: 1