User Tools

Site Tools


java:jfc_intf_list

This is an old revision of the document!


java.util.List

Το interface List υλοποιεί μία διπλά διασυνδεδεμένη λίστα. Η βασικές διαφορές σε σχέση με το Set interface είναι ότι ένα αντικείμενο μπορεί να εμφανίζεται περισσότερες από μία φορές μέσα στη λίστα. Επίσης η σειρά των αντικειμένων στη λίστα διατηρείται και είναι η σειρά με την οποία εισήχθησαν (όλα τα νέα αντικείμενα εισάγονται στο τέλος της λίστας). Μπορείτε να σκεφτείτε την λίστα σαν ένα πίνακα, όπου έχετε πρόσβαση στο i-στο στοιχείο του.

Το interface List ορίζει τις εξής επιπλέον μεθόδους σε σχέση με το interface Collection.

  • get(int index) - Επιστρέφει την τιμή στην θέση index.
  • indexOf(Object o) - Επιστρέφει την 1η θέση του αντικειμένου στην λίστα ή -1 αν δεν περιέχεται το αντικείμενο.
  • lastIndexOf(Object o) - Επιστρέφει την τελευταία θέση του αντικειμένου στην λίστα ή -1 αν δεν περιέχεται το αντικείμενο.
  • subList(int fromIndex, int toIndex) - Επιστρέφει μία υπολίστα της αρχικής λίστας, από fromIndex έως toIndex.
  • set(int index, E element) - Αντικαθιστά το αντικείμενο στην θέση index με το element επιστρέφοντας το αντικείμενο που ήταν αρχικά αποθηκευμένο. Εάν το index που δίνεται είναι εκτός των ορίων της λίστας throws IndexOutOfBoundsException.
  • Η μέθοδος listIterator() επιστρέφει ένα ListIterator object που επιτρέπει την διάτρεξη της λίστας από το τέλος προς την αρχή, όπως παρακάτω.
for (ListIterator<Type> it = list.listIterator(list.size()); it.hasPrevious(); ) {
    Type t = it.previous();
    ...
}

Υλοποιήσεις

Υπάρχουν δύο βασικές κλάσεις που υλοποιούν το συγκεκριμένο interface, ArrayList και LinkedList. Κάθε μία υλοποίηση έχει θετικά και αρνητικά σημεία. Συνήθως χρησιμοποιούμε την ArrayList, παρακάτω γίνεται σύντομη απαρίθμηση των θετικών και αρνητικών στοιχείων των δύο υλοποιήσεων.

  • Χρόνος αναζήτησης στοιχείου: Η ArrayList έχει σταθερό χρόνο αναζήτησης, ενώ η LinkedList έχει γραμμικό χρόνο αναζήτησης.
  • Εισαγωγή στοιχείου στο τέλος: Και οι δύο έχουν τον ίδιο χρόνο εισαγωγής.
  • Εισαγωγή στοιχείου στην αρχή ή στην μέση: Η ArrayList έχει γραμμικό χρόνο εισαγωγής ως προς το μέγεθος της λίστας, ενώ η LinkedList έχει σταθερό χρόνο.
  • Η LinkedList έχει τις επιπλέον μεθόδους addFirst, getFirst, removeFirst, addLast, getLast και removeLast.
  • Η LinkedList υλοποιεί το Queue interface.

Παράδειγμα χρήσης

Με δεδομένο ότι έχουμε ένα αρχείο λεξικό που περιέχει όλες τις λέξεις του αγγλικού αλφαβήτου θέλουμε να φτιάξουμε ένα πρόγραμμα που να διαβάζει λέξεις από το πληκτρολόγιο και να μας εκτυπώνει εάν αυτές βρίσκονται ή όχι μέσα στο λεξικό που έχουμε δώσει στο πρόγραμμα.

Αρχικά καλούμαστε να φτιάξουμε μία λίστα με όλες τις λέξεις του αρχείου λεξικού. Στη συνέχεια για κάθε λέξη που διαβάζουμε εξετάζουμε εάν βρίσκεται μέσα στην λίστα. Θα επιτύχουμε το ίδιο αποτέλεσμα α) χρησιμοποιώντας ένα iterator για να διατρέξουμε τη λίστα και β) χρησιμοποιώντας την μέθοδο contains που μας δίνει το interface Collection.

Χρήση iterator

SearchDictionary.java
import java.util.*;
import java.io.*;
 
public class SearchDictionary {
 
  public SearchDictionary(File dictionary) {
    List<String> myDictionary = new ArrayList<>();
    try (FileInputStream fin = new FileInputStream(dictionary) ) {
      Scanner fsc = new Scanner(fin);
 
      while( fsc.hasNext() ) {
        myDictionary.add(fsc.next());
      }
      System.err.println("Finished reading dictionary!");
 
      Scanner isc = new Scanner(System.in);
      String word;
      do {
        System.out.print("Enter word to search for: ");
        word = isc.next();
        Iterator<String> it = myDictionary.iterator();
        boolean wordFound = false;
        while( it.hasNext() ) {
          String entry = it.next();
          if( entry.equals(word) ) {
            wordFound = true;
            break;
          }
        }
 
        if( wordFound )
          System.out.println("Word found!");
        else 
          System.out.println("Word missing!");
      } while( !word.equals("#quit") );
 
    } catch(IOException ex) {
      ex.printStackTrace();
    }
  }
 
  public  static void main(String [] args) {
    SearchDictionary lu = new SearchDictionary(new File("largedict.txt"));
  }  
}
java/jfc_intf_list.1583852565.txt.gz · Last modified: 2020/03/10 15:02 (external edit)