• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Przekazanie metody z argumentem do toString

Object Storage Arubacloud
+3 głosów
261 wizyt
pytanie zadane 27 marca 2022 w Java przez jasper93 Obywatel (1,310 p.)
edycja 27 marca 2022 przez jasper93

Witam, mam pewien problem, posiadam dwie klasy Position, Order. W klasie Order mam stworzoną metodę calculateProduct(name), gdzie za pomocą Hashmapy obliczam wartość danej pozycji. Chciałbym wartość tej pozycji umieścić w metodzie toString w klasie Order. Niestety z racji tego że metoda toString nie przyjmuje argumentu, nie mam jak przekazać wartości z metody CalculateProduct. Poniżej kod:

package programming.com.pl;

import java.util.Objects;

public class Position  {

    private String name;
    private double price = 0;
    private int quantity = 0;


    public Position(String name, double price, int quantity){
        this.name = name;
        this.price = price;
        this.quantity = quantity;
    }

    public double getPrice() {
        return price;
    }

    public int getQuantity() {
        return quantity;
    }

    public String toString(){
        String str = String.format("%4s,%4s zł,%2s szt.", name,price,quantity);
        return  str;
    }

    @Override
    public boolean equals(Object other){
        if(this == other){
            return true;
        }
        if( other instanceof Position){
            Position p = (Position) other;
            return name.equals(p.name) && price == p.price && quantity == p.quantity;
        }
        return false;
    }
    @Override
    public int hashCode(){
        return Objects.hash(name,price,quantity);
    }






}


package programming.com.pl;

import java.util.ArrayList;
import java.util.HashMap;

public class Order {
    //final private ArrayList<Position> positions = new ArrayList<>();
    final private HashMap<String,Position> positions = new HashMap<String,Position>();




    double calculateProduct(String name){
        double value = positions.get(name).getPrice()*positions.get(name).getQuantity();
       return value;
    }


    void addPosition(String name, Position p) {
        positions.put(name,p);
    }

    void deletePosition(String name) {
        positions.remove(name);
    }



    public String toString() {
        return String.format("%f",calculateProduct(name));
    }

}

 

 

 

1
komentarz 27 marca 2022 przez Oscar Nałogowiec (29,290 p.)
W linii 27 masz dziwnie - same %s, gdy tylko 1 argument to String.

toString() też jest @override.

Zawsze możesz zdefiniować inne metodę o takiej samej nazwie, ale z innymi parametrami. Oczywiście na nowa metoda nie zastąpi tej pierwotnej, będzie istnieć w sumie niezależnie i będzie używana gdy podasz odpowiednie parametry.

1 odpowiedź

+3 głosów
odpowiedź 27 marca 2022 przez Wiciorny Ekspert (269,710 p.)
wybrane 27 marca 2022 przez jasper93
 
Najlepsza

Napisać własną implementacje metody przyjmującej parametr. Np taką

public class Order {
    //final private ArrayList<Position> positions = new ArrayList<>();
    final private HashMap<String,Position> positions = new HashMap<String,Position>()

 //... pominiety kod
 
    public String valueToString(String name) {
        return String.format("%f",calculateProduct(name));
    }
 
}


a jeśli mass użyc dokładnie to string to odwołać się do zmiennej która przetrzyma to 

public String toString() {
    String result = this.mapa.getElementzMapy(klucz) + "," + this.mapa.getElementzMapy(klucz); 
    return result;
}

korzystajac z this -> odwolujacego sie do "pola klasy tego obiektu, tej instancji" zabezpieczyc jednoczesnie przed faktem BRAKU KLUCZA, BRAKU ELEMENTU i upewnieniu sie ze elementy sa juz dodane 
 

1
komentarz 27 marca 2022 przez jasper93 Obywatel (1,310 p.)
Dziękuje bardzo za rozjaśnienie problemu, zastanawiałem się czy własna implementacja toString(parametr) jest zgodna z dobrymi praktykami programowania. Jeśli chodzi o błędy w toString %s już poprawiam, rzeczywiście popełniłem tam błąd :)
1
komentarz 27 marca 2022 przez Wiciorny Ekspert (269,710 p.)
sama w sobie implementacja poprzez nadpisanie niestety nie, nie możesz też tej metody przeciążyć, ale własne metody możesz dobrowolnie pisać, nawet w taki sposób, że wewnętrznie wywołasz toString
1
komentarz 27 marca 2022 przez Oscar Nałogowiec (29,290 p.)
Tylko widzę pewien zgrzyt projektowy - metoda toString ma wypisać obiekt, cały obiekt.

Jeśli wypisujesz tam coś na kształt cena*wartość to dlaczego dotyczy to jednej pozycji zamówienia a nie np. wartości całego zamówienia (suma po pozycjach).

Wypisanie wartości pojedynczej pozycji powinno być metodą klasy pozycja.
komentarz 27 marca 2022 przez Wiciorny Ekspert (269,710 p.)
tzn ja odwołałem się tylko do pytania, bez wglądu w mechanizm implementacji, dla mnie sam fakt takiego podejścia wypisania czegoś, co potem i tak jest w kolekcji nie ma sensu.
komentarz 28 marca 2022 przez jasper93 Obywatel (1,310 p.)
Rozumiem, z drugiej strony, czy wypisywanie w Klasie pozycja jest odpowiednie? Ogólnie robiąc to zadanie słyszałem, że w Klasie pozycja powinna być tylko nazwa i cena, natomiast w Zamówienie: ilość, wartość zamówienia. Teraz sam już zgupiałem.
komentarz 30 marca 2022 przez jasper93 Obywatel (1,310 p.)

@Wiciorny,  Z drugiej strony spróbowałem sposobu :

public String toString() {
    String result = this.mapa.getElementzMapy(klucz) + "," + this.mapa.getElementzMapy(klucz); 
    return result;
}

Niestety, ale problem polega na tym, że w miejscu(klucz), trzeba umieścić name, który tak jak mówiłem jest niewidoczny dla metody toString.

 

komentarz 30 marca 2022 przez Wiciorny Ekspert (269,710 p.)
jest niewidoczny bo go tak przekazujesz,  to słowo KLUCZ u mnie to nie nazwa zmiennej samej w sobie, a przyklad klucz musisz przekazać jako POLE KLASY TEGO OBIKETU.
Odwołuje się do poczytania o 'this'
nie potrafisz tego zaimplementować po prostu, możesz nawet zrobić dodatkową metodę która w runtime to zwróci.
https://stackoverflow.com/questions/27143951/how-make-tostring-method-return-super-class-private-fields-also-along-with-its
komentarz 30 marca 2022 przez jasper93 Obywatel (1,310 p.)
edycja 30 marca 2022 przez jasper93

@Wiciorny,  Posiłkując się Twoim tematem ze Stackoverflow zrobiłem coś takiego, tylko nie wiem czy to miałeś dokładnie na myśli?

 

package programming.com.pl;

import java.util.ArrayList;
import java.util.HashMap;

public class Order extends Position {
    //final private ArrayList<Position> positions = new ArrayList<>();
    final private HashMap<String,Position> positions = new HashMap<String,Position>();

    public Order(String name, double price, int quantity) {
        super(name, price, quantity);
    }


    double calculateProduct(String name){
        double value = positions.get(name).getPrice()*positions.get(name).getQuantity();
       return value;
    }


    void addPosition(String name, Position p) {
        positions.put(name,p);
    }

    void deletePosition(String name) {
        positions.remove(name);
    }


    public String toString() {
        String result = this.positions.get(getName()) +"," + this.positions.get(getName());
        return result;
    }

}

 

Podobne pytania

0 głosów
4 odpowiedzi 706 wizyt
0 głosów
1 odpowiedź 2,624 wizyt
pytanie zadane 19 czerwca 2017 w Java przez Kubs Mądrala (5,190 p.)
0 głosów
1 odpowiedź 1,506 wizyt
pytanie zadane 11 grudnia 2018 w Java przez msukiennik Początkujący (380 p.)

92,551 zapytań

141,399 odpowiedzi

319,529 komentarzy

61,937 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...