konstruktor a brak argumentu

konstruktor a brak argumentu
ArtS
  • Rejestracja:ponad 7 lat
  • Ostatnio:29 dni
  • Postów:32
0

Cześć, czy da się zrobić tak żeby w obiekcie staff[1] = new Employee("user_2"); nie było parametru salary i w jego miejsce nic nie wyświetlono w wyniku? Docelowym wynikiem ma być:
name=user_1,salary=10500.0
name=user_2

Kopiuj
import java.util.*;

public class test
{
    public static void main(String[] args)
    {
        Employee[] staff = new Employee[4];
        staff[0] = new Employee("user_1", 10000);
        staff[1] = new Employee("user_2");
  
        for (Employee e : staff)
            e.raiseSalary(5);

        for (Employee e : staff)
            System.out.println("name=" + e.getName() + ",salary=" + e.getSalary();

class Employeee
{
    private String name;
    private double salary;

    public Employeee(String n, double s)
    {
        name = n;
        salary = s;

    }
    public String getName()
    {
        return name;
    }
    public double getSalary()
    {
        return salary;
    }

    public void raiseSalary(double byPercent)
    {
        double raise = salary * byPercent/100;
        salary += raise;
    }
}
ArtS
Oczywiście konstruktor narzuca 2 parametry ale czy można to jakoś obejść?
lion137
  • Rejestracja:około 8 lat
  • Ostatnio:minuta
  • Postów:4924
1

Możesz przeładować konstruktor, ale nie podając salary, będzie domyślna wartość dla double, czyli 0.0


ArtS
  • Rejestracja:ponad 7 lat
  • Ostatnio:29 dni
  • Postów:32
0

Czyli wystarczy dodać:

Kopiuj
 public Employeee(String n)
    {
        name = n;
    }

Zastanawiam się czy można to jeszcze jakoś inaczej ugryźć, ale chyba nie. ;p

Areek
Zastosuj buildera (klasycznego lub na bazie klasy wewnętrznej by móc swobodnie chainowac metody). Będzie wygodnie i czytelnie.
Areek
I doczytaj jaki typ danych zastosować w przypadku pieniędzy. Podpowiedź: na pewno nie double ;)
ArtS
w Książce był double, ale teraz już wiem, że to zła praktyka. Pokombinuję z bulderem ;)
Areek
Zmień książkę ;)
PI
  • Rejestracja:ponad 9 lat
  • Ostatnio:4 miesiące
  • Postów:2787
1

Jeśli chcesz rozróżnić sytuację, gdzie ktoś faktycznie ma zerową pensję (np student na umowie zlecenie nie wyrobił ani jednej godziny w danym miesiącu) od sytuacji, gdzie dany pracownik w ogóle nie miał ustalonej pensji, to proponuję zamienić double na Double - wtedy w przypadku nie ustawienia wartości, będziesz mieć null (musiałbyś dodać ifa w raiseSalary wtedy).

edytowany 1x, ostatnio: Pinek
lion137
  • Rejestracja:około 8 lat
  • Ostatnio:minuta
  • Postów:4924
1

Albo tak:

Kopiuj
 public Employeee(String n)
    {
        name = n;
        salary = -1.0;
    }

gdy wartość jest ujemna, to osoba jeszcze nie pracowała, jak się Boisz NULL - a:)


ArtS
  • Rejestracja:ponad 7 lat
  • Ostatnio:29 dni
  • Postów:32
0

Jeszcze jedno pytanko:

Kopiuj
 public void raiseSalary(double byPercent)
    {
        double raise = salary * byPercent/100;
        salary += raise;
    }

Dlaczego tutaj jest void skoro ta metoda zwraca wartość salary? Nie powinno być double?

MarekR22
ta metoda nic nie zwraca, ale zmienia stan obiektu (powiększa salary).
baant
  • Rejestracja:ponad 11 lat
  • Ostatnio:2 miesiące
  • Lokalizacja:Wrocław
  • Postów:524
3

Co to za bluźnierstw uczycie chlopaka z nullem i -1 :| tylko czekac na metode, która robi obliczenia na pensjach kilku pracowników i klops. Najprostsze, najbezpieczniejsze i najbardziej pasujace do problemu jest wstawienie 0 do salary

Jeśli chcesz rozroznic pracownika bez pensji od pracownika z pensja zerowo (czy to jest wgl mozliwe? Xd) to zrob 2 obiekty, np Employee i WhyAmIWorkingHereForNothingEmployee

edytowany 2x, ostatnio: baant
LP
Ddd, brawo WhyAmIWorkingHereForNothingEmploy. Pojawil sie usmiech na mojej twarzy.
jarekr000000
  • Rejestracja:ponad 8 lat
  • Ostatnio:około 8 godzin
  • Lokalizacja:U krasnoludów - pod górą
  • Postów:4707
4

@lion137 @Pinek @baant

whip.gif

I teraz zgadnijcie za co.

I żeby to było ostatni raz.


jeden i pół terabajta powinno wystarczyć każdemu
edytowany 1x, ostatnio: jarekr000000
lion137
Takie sprzęty, na mnie, może tylko żona używać ;-)
PI
uuu @lion137 chyba nie będę brnął w szczegóły :D
PI
  • Rejestracja:ponad 9 lat
  • Ostatnio:4 miesiące
  • Postów:2787
0
jarekr000000 napisał(a):

I żeby to było ostatni raz.

No to słuchamy idealnego rozwiązania, panie Jarosławie xd

Zobacz pozostały 1 komentarz
jarekr000000
trochę razi - wali 5 megawatowym laserem po oczach wszystkich księgowych, którzy potem tego rypanego jednego grosza w bilansie nie mogą znaleźć.
K5
PI
@kixe52: ach, no tak xd albo BigDecimal albo int. Skupiłem się na czymś innym w tym wątku
jarekr000000
BigDecimal może być
DQ
  • Rejestracja:prawie 10 lat
  • Ostatnio:7 miesięcy
  • Postów:141
1

Właśnie udało wam się zepsuć ideę programowania obiektowego :P Konstruktor zawsze powinien zwracać obiekt, którego stan jest co najmniej w minimalnym stopniu poprawny i można wywołać każda publiczną funkcję. Ustawianie nulla zdecydowanie tego nie spełnia. Ustawienie -1 chyba jest jeszcze gorsze bo ktoś wywoła metodę raise salary, przekaże tam wartość "1", a pensja w rzeczywistości będzie wynosiła 0.

jarekr000000
  • Rejestracja:ponad 8 lat
  • Ostatnio:około 8 godzin
  • Lokalizacja:U krasnoludów - pod górą
  • Postów:4707
1
Pinek napisał(a):

No to słuchamy idealnego rozwiązania, panie Jarosławie xd

EmployeeBędzieMiałPanDoPortfolio


jeden i pół terabajta powinno wystarczyć każdemu
baant
Krócej: Intern.java
jarekr000000
Intern.java - Nazwa niezgodna ze standardem kodowania w Javie - za krótka. Do tego brak przyrostka Bean, Impl lub Service. Żadne review tego nie przepuści - pewnie nawet Sonar ma regułkę.
vpiotr
Krócej: Ceo.java
Charles_Ray
  • Rejestracja:około 17 lat
  • Ostatnio:około 11 godzin
  • Postów:1875
1

Proponuję kombo:
Double salary = -1;


”Engineering is easy. People are hard.” Bill Coughran
AK
  • Rejestracja:prawie 7 lat
  • Ostatnio:około miesiąc
  • Postów:3561
0
baant napisał(a):

Jeśli chcesz rozroznic pracownika bez pensji od pracownika z pensja zerowo (czy to jest wgl mozliwe? Xd) to zrob 2 obiekty, np Employee i WhyAmIWorkingHereForNothingEmployee

Scenka z życia: rząd robiąc w zeszłym roku ulgę dla <26 straszliwie zamotał koncepcje, wrzucił to w "nieopodatkowane" (jak delegacje itd), zamiast nie wysadzać niczego w powietrze i przyjąć "opodatkowane zero" czy "100% ulgi" jak początek roku mało zarabiających itd. Zwłaszcza że ta sama ustawa zakłada zaprzestanie ulgi z tytułu 26. urodzin lub przekroczenia limitu.

Było straszne zamieszanie z wzorami PIT-11, spóźnienia strony rządowej (co by było, gdyby spóźniał się podatnik???)
Co miały robić firmy softwarowe?
Więc na styku z polskimi podatkami czy kodeksem pracy (kosmos!) właściwa odpowiedź brzmi ... nawet nasze programersowe "to zależy" jest zbyt ścisłe.


Bo C to najlepszy język, każdy uczeń ci to powie
M3
  • Rejestracja:prawie 6 lat
  • Ostatnio:prawie 4 lata
  • Postów:9
0

Robić 2 konstruktory, jeden bez salary

DQ
i dopuszczać stan obiektu który nigdy nie powinien się pojawić? Brzmi średnio.
M3
2 konstruktory sprawia, że będzie mógł podać salary ale też nie koniecznie i nie wywali mu tam nulla
DQ
  • Rejestracja:prawie 10 lat
  • Ostatnio:7 miesięcy
  • Postów:141
2
Mateusz3991 napisał(a):

Jak nie powinien skoro tego oczekuje

On oczekuje możliwości przedstawienia pracownika który nie ma pensji, a nie ustawienie jej na null. Pierwsze jest potrzebą, drugie jest rakiem.

Jakby na to nie patrzeć to Java jest językiem typowanym, jeśli coś nie ma sensu dla danej klasy to dorabianie konstruktora na siłę jest obchodzeniem idei obiektowości i ogólnie systemu typu. Można do tego podejść na wiele sposobów:

  • Przedstawienie różnych typów pracowników jako ADT
  • Zrobienie dwóch oddzielnych typów pracowników na te dwa przypadki
  • Zmienienie typu salary na cokolwiek co przedstawia sytuacje, że możliwym jest nieposiadanie pensji
  • Wartość domyślna (najgorszy sposób ze wszystkich ale nadal lepszy niż null)
    I pewnie wiele innych. Tak czy siak, dorabianie konstruktora który pozwala na utworzenie obiektu danej klasy w stanie niekompletnym jest po prostu złą praktyką.
lion137
Wartośc domyślna jest rakiem, ale rakiem promowanym przez język.
DQ
Nie powiedziałbym że to jest rak bo czasami ma swoje zastosowania które są po prostu ok. Nie mniej, ciężko stwierdzić, że rozsądnym jest dawanie wartości domyślnej jeśli mówimy o polu salary w klasie Employee - tutaj na pierwszy rzut oka widać, że coś nie styka.
Charles_Ray
  • Rejestracja:około 17 lat
  • Ostatnio:około 11 godzin
  • Postów:1875
0

No dobra, a jaki jest sens posiadania Pracownika bez salary? :) To wynika z tego, że jego pensja jest nieznana (bo jest Kandydatem) czy dlatego, że pracuje za darmo?


”Engineering is easy. People are hard.” Bill Coughran
DQ
Nie ma większego ;) Dlatego, według mnie optymalnie byłoby zaprojektować ten fakt jako sum type gdzie byłby Employee, Volunteering, VeryUnhappyEmployee i tak dalej
AK
Może dostaje postojowe? :) Bez wódki tego nie zrozumiesz

Zarejestruj się i dołącz do największej społeczności programistów w Polsce.

Otrzymaj wsparcie, dziel się wiedzą i rozwijaj swoje umiejętności z najlepszymi.