<< Vissza

Hibakeresés

Kollekciók 2. (Halmazok)

Feladat: Keresd meg az alábbi kódban azokat a sorokat, amelyek hibásak és kattints rájuk. Indokold meg, hogy szerinted miért hibás. Amennyiben úgy érzed, hogy az összes hiba megvan, kattins a "Kész vagyok" gombra!

Milyen hibákra kell gondolni? Szintaktikai és szemantikai hibák is lehetnek a kódban: nem megfelelő szintaxis az egyes nyelvi konstrukciókban, módosítók sorrendje, visszatérési típusokkal kapcsolatos, nullával való osztás, tömb alul- vagy túlindexelés, adott scope-ban már/még nem látható változók, stb.

import java.util.*;

public class Set2 {

    private TreeSet<Integer> items;

    public void Set2() {

        super(); 

        this.items = new TreeSet<>();

    }

    public Set<Integer> tizRandomSzam() {

        items = new HashSet(); 

        while (items.size() < 10) {

            int meret = items.size();

            while (meret == items.size()) {

                items.add(new Random().nextInt(50));

            }

        }

        return items;

        items = null; 

    }

    

    public String toString() {

        if (items = null) return ""; 

        Iterator<Integer> it = items.iterator();

        String str = "";

        while (it.hasNext()) {

            str = str + it.next() + " ";

        }

        return str;

    }

    public static void main(String[] args) {

        new Set2().tizRandomSzam().forEach(szam -> { System.out.println(szam) }); 

    }

}

Több helyes megoldás is létezhet, amit sajnos nem lehet felvinni a programba, ezért az általunk megadott példamegoldás nem szentírás. Előfordulhat, hogy mi a hiba helyét jelöltük be hibásnak, míg te azt a helyet, ahol a hibás sor miatt probléma lép fel. Amennyiben meg bírod indokolni, hogy miért véled hibásnak az adott sort vizsgán, valószínűleg azt is el fogják fogadni (ha valóban hiba és visszavezethető az indoklásodra).