This shows you the differences between two versions of the page.
| Both sides previous revision Previous revision Next revision | Previous revision | ||
|
java:jfc_intf_list [2016/04/21 09:00] gthanos [Υλοποιήσεις] |
java:jfc_intf_list [2021/05/22 03:21] |
||
|---|---|---|---|
| Line 1: | Line 1: | ||
| - | ====== java.util.List ====== | ||
| - | |||
| - | Το interface //List// υλοποιεί μία διπλά διασυνδεδεμένη λίστα. Η βασικές διαφορές σε σχέση με το //Set// interface είναι ότι ένα αντικείμενο μπορεί να εμφανίζεται περισσότερες από μία φορές μέσα στη λίστα. Επίσης η σειρά των αντικειμένων στη λίστα διατηρείται και είναι η σειρά με την οποία εισήχθησαν (όλα τα νέα αντικείμενα εισάγονται στο τέλος της λίστας). Μπορείτε να σκεφτείτε την λίστα σαν ένα πίνακα, | ||
| - | |||
| - | Το interface //List// ορίζει τις εξής επιπλέον μεθόδους σε σχέση με το interface // | ||
| - | * **[[http:// | ||
| - | * **[[http:// | ||
| - | * **[[http:// | ||
| - | * **[[http:// | ||
| - | * **[[http:// | ||
| - | * Η μέθοδος [[http:// | ||
| - | |||
| - | <code java> | ||
| - | for (ListIterator< | ||
| - | Type t = it.previous(); | ||
| - | ... | ||
| - | } | ||
| - | </ | ||
| - | |||
| - | ===== Υλοποιήσεις ===== | ||
| - | |||
| - | |||
| - | Υπάρχουν δύο βασικές κλάσεις που υλοποιούν το συγκεκριμένο interface, [[https:// | ||
| - | |||
| - | * **Χρόνος αναζήτησης στοιχείου: | ||
| - | * **Εισαγωγή στοιχείου στο τέλος: | ||
| - | * **Εισαγωγή στοιχείου στην αρχή ή στην μέση:** Η // | ||
| - | * Η // | ||
| - | * Η // | ||
| - | |||
| - | ===== Παράδειγμα χρήσης ===== | ||
| - | |||
| - | Με δεδομένο ότι έχουμε ένα αρχείο λεξικό που περιέχει όλες τις λέξεις του αγγλικού αλφαβήτου θέλουμε να φτιάξουμε ένα πρόγραμμα που να διαβάζει λέξεις από το πληκτρολόγιο και να μας εκτυπώνει εάν αυτές βρίσκονται ή όχι μέσα στο λεξικό που έχουμε δώσει στο πρόγραμμα. | ||
| - | |||
| - | Αρχικά καλούμαστε να φτιάξουμε μία λίστα με όλες τις λέξεις του αρχείου λεξικού. Στη συνέχεια για κάθε λέξη που διαβάζουμε εξετάζουμε εάν βρίσκεται μέσα στην λίστα. Θα επιτύχουμε το ίδιο αποτέλεσμα α) χρησιμοποιώντας ένα **iterator** για να διατρέξουμε τη λίστα και β) χρησιμοποιώντας την μέθοδο contains που μας δίνει το //interface Collection// | ||
| - | |||
| - | ==== Χρήση iterator ==== | ||
| - | |||
| - | <code java SearchDictionary.java> | ||
| - | import java.util.*; | ||
| - | import java.io.*; | ||
| - | |||
| - | public class SearchDictionary { | ||
| - | | ||
| - | public SearchDictionary(File dictionary) { | ||
| - | List< | ||
| - | try (FileInputStream fin = new FileInputStream(dictionary) ) { | ||
| - | Scanner fsc = new Scanner(fin); | ||
| - | | ||
| - | while( fsc.hasNext() ) { | ||
| - | myDictionary.add(fsc.next()); | ||
| - | } | ||
| - | System.err.println(" | ||
| - | | ||
| - | Scanner isc = new Scanner(System.in); | ||
| - | String word; | ||
| - | do { | ||
| - | System.out.print(" | ||
| - | word = isc.next(); | ||
| - | Iterator< | ||
| - | boolean wordFound = false; | ||
| - | while( it.hasNext() ) { | ||
| - | String entry = it.next(); | ||
| - | if( entry.equals(word) ) { | ||
| - | wordFound = true; | ||
| - | break; | ||
| - | } | ||
| - | } | ||
| - | | ||
| - | if( wordFound ) | ||
| - | System.out.println(" | ||
| - | else | ||
| - | System.out.println(" | ||
| - | } while( !word.equals("# | ||
| - | | ||
| - | } catch(IOException ex) { | ||
| - | ex.printStackTrace(); | ||
| - | } | ||
| - | } | ||
| - | | ||
| - | public | ||
| - | SearchDictionary lu = new SearchDictionary(new File(" | ||
| - | } | ||
| - | } | ||
| - | </ | ||
| - | |||
| - | ==== Χρήση της μεθόδου contains ==== | ||
| - | |||
| - | <code java SearchDictionary.java> | ||
| - | import java.util.*; | ||
| - | import java.io.*; | ||
| - | |||
| - | public class SearchDictionary { | ||
| - | | ||
| - | public SearchDictionary(File dictionary) { | ||
| - | List< | ||
| - | try (FileInputStream fin = new FileInputStream(dictionary) ) { | ||
| - | Scanner fsc = new Scanner(fin); | ||
| - | | ||
| - | while( fsc.hasNext() ) { | ||
| - | myDictionary.add(fsc.next()); | ||
| - | } | ||
| - | System.err.println(" | ||
| - | | ||
| - | Scanner isc = new Scanner(System.in); | ||
| - | String word; | ||
| - | do { | ||
| - | System.out.print(" | ||
| - | word = isc.next(); | ||
| - | | ||
| - | if( myDictionary.contains(word) ) | ||
| - | System.out.println(" | ||
| - | else | ||
| - | System.out.println(" | ||
| - | } while( !word.equals("# | ||
| - | | ||
| - | } catch(IOException ex) { | ||
| - | ex.printStackTrace(); | ||
| - | } | ||
| - | } | ||
| - | | ||
| - | public | ||
| - | SearchDictionary lu = new SearchDictionary(new File(" | ||
| - | } | ||
| - | } | ||
| - | </ | ||
| - | |||
| - | |||
| - | |||
| - | |||
| - | |||
| - | |||
| - | |||
| - | |||
| - | |||