java:jfc_intf_list

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revision Previous revision
Next revision Both sides next revision
java:jfc_intf_list [2020/03/16 17:46]
gthanos [java.util.List]
java:jfc_intf_list [2020/03/16 20:00]
gthanos [Υλοποιήσεις]
Line 27: Line 27:
   * Η [[https://docs.oracle.com/javase/8/docs/api/java/util/LinkedList.html|LinkedList]] έχει τις επιπλέον μεθόδους [[https://docs.oracle.com/javase/8/docs/api/java/util/LinkedList.html#addFirst-E-|addFirst]], [[https://docs.oracle.com/javase/8/docs/api/java/util/LinkedList.html#getFirst--|getFirst]], [[https://docs.oracle.com/javase/8/docs/api/java/util/LinkedList.html#removeFirst--|removeFirst]], [[https://docs.oracle.com/javase/8/docs/api/java/util/LinkedList.html#addLast-E-|addLast]], getLast και removeLast.   * Η [[https://docs.oracle.com/javase/8/docs/api/java/util/LinkedList.html|LinkedList]] έχει τις επιπλέον μεθόδους [[https://docs.oracle.com/javase/8/docs/api/java/util/LinkedList.html#addFirst-E-|addFirst]], [[https://docs.oracle.com/javase/8/docs/api/java/util/LinkedList.html#getFirst--|getFirst]], [[https://docs.oracle.com/javase/8/docs/api/java/util/LinkedList.html#removeFirst--|removeFirst]], [[https://docs.oracle.com/javase/8/docs/api/java/util/LinkedList.html#addLast-E-|addLast]], getLast και removeLast.
   * Η [[https://docs.oracle.com/javase/8/docs/api/java/util/LinkedList.html|LinkedList]] υλοποιεί το [[https://docs.oracle.com/javase/8/docs/api/java/util/Queue.html|Queue]] interface.   * Η [[https://docs.oracle.com/javase/8/docs/api/java/util/LinkedList.html|LinkedList]] υλοποιεί το [[https://docs.oracle.com/javase/8/docs/api/java/util/Queue.html|Queue]] interface.
 +
 +===== Παράδειγμα =====
 +
 +Το παράδειγμα που ακολουθεί διαβάζει από ένα αρχείο κειμένου μια σειρά από λέξεις με τη βοήθεια της κλάσης [[https://docs.oracle.com/javase/8/docs/api/java/util/Scanner.html|java.util.Scanner]]. Τα γράμματα κάθε λέξης μετατρέπονται σε πεζά πριν αποθηκευτούν στη λίστα.
 +
 +<code java ListExample.java>
 +import java.util.*;
 +import java.io.*;
 +
 +public class ListExample {
 +
 +  public static void main(String []args) {
 +  
 +    List<String> wordsList = new ArrayList<>();
 +    try(Scanner sc = new Scanner(new File(args[0]))) {
 +      while(sc.hasNext()) {
 +        String word = sc.next().toLowerCase();
 +        wordsList.add(word);
 +      }
 +      
 +      Iterator it = wordsList.iterator();
 +      while(it.hasNext())
 +        System.out.print(it.next()+" ");
 +      System.out.println("");
 +    }
 +    catch(FileNotFoundException ex) {
 +      System.out.println("Unable to open file \""+args[0]+"\"");
 +    }
 +  }
 +}
 +</code>
 +
 +Μια παραλλαγή του παραπάνω κώδικα είναι 
 +  - αντί για τη μέθοδο ''add'' να χρησιμοποιήσετε ένα ListIterator προκειμένου να βάλετε τα στοιχεία στη λίστα
 +  - αντί να εκτυπώσετε τα στοιχεία της λίστας από την αρχή προς το τέλος να τα εκτυπώσετε από το τέλος προς την αρχή, όπως παρακάτω:
 +
 +<code java ListExample.java>
 +import java.util.*;
 +import java.io.*;
 +
 +public class ListExample {
 +
 +  public static void main(String []args) {
 +  
 +    List<String> wordsList = new ArrayList<>();
 +    try(Scanner sc = new Scanner(new File(args[0]))) {
 +      ListIterator<String> it = wordsList.listIterator();
 +      while(sc.hasNext()) {
 +        String word = sc.next().toLowerCase();
 +        it.add(word);
 +      }
 +      
 +      it = wordsList.listIterator(wordsList.size()-1);
 +      while(it.hasPrev())
 +        System.out.print(it.prev()+" ");
 +      System.out.println("");
 +    }
 +    catch(FileNotFoundException ex) {
 +      System.out.println("Unable to open file \""+args[0]+"\"");
 +    }
 +  }
 +}
 +
 +</code>
 +
  
  
java/jfc_intf_list.txt · Last modified: 2021/05/22 03:21 (external edit)