User Tools

Site Tools


java:jfc_intf_collection

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
Previous revision
Next revision Both sides next revision
java:jfc_intf_collection [2015/03/22 19:34]
gthanos
java:jfc_intf_collection [2021/05/22 03:38]
gthanos [1ος τρόπος - For-Each Loop]
Line 1: Line 1:
-====== Collection Interface ======+====== Interface java.util.Collection  ======
  
 Το βασικό Interface στην Java το οποίο αποτελεί το ελάχιστον κοινό Interface των //Set//, //List//, //Queue//, //Dequeue//. Το βασικό Interface στην Java το οποίο αποτελεί το ελάχιστον κοινό Interface των //Set//, //List//, //Queue//, //Dequeue//.
Line 5: Line 5:
 ===== Διάτρεξη ενός Collection ===== ===== Διάτρεξη ενός Collection =====
  
-==== 1ος τρόπος - for() ====+To interface [[https://docs.oracle.com/javase/8/docs/api/java/util/Collection.html|java.util.Collection]] είναι απόγονος του interface [[https://docs.oracle.com/javase/8/docs/api/java/lang/Iterable.html|java.lang.Iterable]]. Ως εκ τούτου, η διάτρεξη οποιουδήποτε Collection μπορεί να γίνει με δύο τρόπους  
 +  - μέσω For-Each Loop. 
 +  - με τη βοήθεια ενός [[https://docs.oracle.com/javase/8/docs/api/java/util/Iterator.html|java.util.Iterator]]. 
 + 
 +==== 1ος τρόπος - For-Each Loop ====
  
 <code java StudentCollection.java> <code java StudentCollection.java>
Line 12: Line 16:
  
 public class StudentCollection { public class StudentCollection {
- 
-  private Collection<Student> students; 
      
-  public StudentCollection() { +  public static void iterateCollection(Collection<Student> students) {   
-    students = new LinkedList<Student>(); +    for(Student st: students{ 
-    populateList();+      System.out.println(st.toString()); 
 +    }
   }   }
      
-  public final void populateList() {+  public static void main(String args[]) { 
 +    students = new LinkedList<Student>();
     students.add(new Student("John", "Smith"));     students.add(new Student("John", "Smith"));
     students.add(new Student("Stanley", "Peters"));     students.add(new Student("Stanley", "Peters"));
Line 26: Line 30:
     students.add(new Student("Suzan", "Miles"));     students.add(new Student("Suzan", "Miles"));
     students.add(new Student("Mary", "Poppins"));     students.add(new Student("Mary", "Poppins"));
-  } +    iterateCollection(students);
-   +
-  public void iterateList() {   +
-    for(Student st: students) { +
-    System.out.println(st.toString()); +
-    } +
-  } +
-   +
-  public static void main(String args[]) { +
-    StudentCollection stl = new StudentCollection(); +
-    stl.iterateList();+
   }   }
  
Line 75: Line 69:
  
 public class StudentCollection { public class StudentCollection {
- +    
-  private Collection<Student> students; +  public static void main(String args[]) { 
-   +    Collection<Student> students = new ArrayList<>();
-  public StudentCollection() { +
-    students = new LinkedList<Student>(); +
-    populateList(); +
-  } +
-   +
-  public final void populateList() {+
     students.add(new Student("John", "Smith"));     students.add(new Student("John", "Smith"));
     students.add(new Student("Stanley", "Peters"));     students.add(new Student("Stanley", "Peters"));
Line 89: Line 77:
     students.add(new Student("Suzan", "Miles"));     students.add(new Student("Suzan", "Miles"));
     students.add(new Student("Mary", "Poppins"));     students.add(new Student("Mary", "Poppins"));
-  } +        
-   +
-  public Collection<Student> getStudents() { +
-    return students; +
-  } +
-   +
-  public static void main(String args[]) { +
-    StudentCollection stl = new StudentCollection();     +
-    Collection <Student> sts = stl.getStudents();  // comment out this line and uncomment the following comments +
-     +
-    /*+
     Collection <Student> sts = new LinkedList<Student>();     Collection <Student> sts = new LinkedList<Student>();
     sts.add(new Student("John", "Smith"));     sts.add(new Student("John", "Smith"));
     sts.add(new Student("Stanley", "Peters"));     sts.add(new Student("Stanley", "Peters"));
-    */ 
    
-    if( stl.getStudents().containsAll(sts) ) {+    if( students.containsAll(sts) ) {
        System.out.println("containsAll:TRUE");        System.out.println("containsAll:TRUE");
     }     }
Line 116: Line 93:
 </code> </code>
  
-Στην συνέχεια βάλτε σχόλια στην γραμμή που υποδεικνύουν τα σχόλια και αφαιρέστε το τμήμα του κώδικα που είναι σε σχόλια. Μεταγλωττίστε και τρέξτε. Ποιό είναι το αποτέλεσμα αυτή την φορά; Γιατί συμβαίνει αυτό+<WRAP tip center 80% round > 
- +Απαραίτητη προϋπόθεση για να δουλέψει σωστά η μέθοδος ''containsAll'' είναι η παράμετρος κλάση του Collection να υλοποιεί τις μεθόδους ''equals'' και ''hashCode''Εάν αφαιρέσετε έστω και μία από τις μεθόδους αυτές από την υλοποίηση της κλάσης Student θα παρατηρήσετε ότι η μέθοδος ''containsAll'' δεν αναγνωρίζει τα αντικείμενα της μεταβλητής ''sts'' ως αντίγραφα εκείνων που περιέχονται στην αρχική λίστα φοιτητών ''students''.
-<WRAP center 70% round tip> +
-Όταν συγκρίνονται δύο //Collections// ως προς τα περιεχόμενα τους συγκρίνουμε εάν η πρώτη περιέχει __τα ίδια ακριβώς__ στοιχεία με την δεύτερη, δηλαδή τα ίδια ακριβώς objects. Εάν δημιουργηθούν αντίγραφα των objects της μίας και τοποθετηθούν στην 2η η σύγκριση των περιεχομένων δεν επιστρέφει ισότητα.+
 </WRAP> </WRAP>
  
Line 126: Line 101:
 <code java StudentCollection.java> <code java StudentCollection.java>
 import java.util.*; import java.util.*;
-import java.lang.*; 
-import java.util.*; 
-import java.lang.*; 
  
 public class StudentCollection { public class StudentCollection {
- +    
-  private Collection<Student> students; +  public static void main(String args[]) { 
-   +    Collection<Student> students = new ArrayList<>();
-  public StudentCollection() { +
-    students = new LinkedList<Student>(); +
-    populateList(); +
-  } +
-   +
-  public final void populateList() {+
     students.add(new Student("John", "Smith"));     students.add(new Student("John", "Smith"));
     students.add(new Student("Stanley", "Peters"));     students.add(new Student("Stanley", "Peters"));
Line 145: Line 111:
     students.add(new Student("Suzan", "Miles"));     students.add(new Student("Suzan", "Miles"));
     students.add(new Student("Mary", "Poppins"));     students.add(new Student("Mary", "Poppins"));
-  } +         
-   +    Collection <Student> sts = new LinkedList<Student>(); 
-  public Collection<Student> getStudents() { +    sts.add(new Student("John", "Smith"))
-    return students+    sts.add(new Student("Stanley", "Peters"));
-  }+
    
-  public void iterateList() {   +    students.addAll(sts); 
-    for(Student st: students) { +    print(students); 
-      System.out.println(st.toString()); +    
-    }+
   }   }
      
-  public static void main(String args[]) { +  public static void print(Collection<Student> collection) { 
-    StudentCollection stl = new StudentCollection();     +    Iterator<Student> it collection.iterator(); 
-    Collection <Student> sts new LinkedList<Student>(); +    while(it.hasNext()) 
-    sts.add(new Student("Lena", "Travolta")); +      System.out.println(it.next());
-    sts.add(new Student("George", "Thanos")); +
-     +
-    stl.getStudents().addAll(sts); +
-    stl.iterateList();    +
   }   }
-+}
 </code> </code>
 +
 +<WRAP todo center 80% round >
 +Στον παραπάνω κώδικα αντικαταστήστε την πρώτη γραμμή της ''main'' με
 +<code>
 +Collection<Student> students = new HashSet<>();
 +</code>
 +
 +Τι παρατηρείτε; Γιατί συμβαίνει αυτό;
 +</WRAP>
  
   * **[[https://docs.oracle.com/javase/7/docs/api/java/util/Collection.html#removeAll(java.util.Collection)|removeAll(Collection<?> c)]]** - Αφαιρεί όλες τις εγγραφές που περιέχονται στο Collection ''c''.   * **[[https://docs.oracle.com/javase/7/docs/api/java/util/Collection.html#removeAll(java.util.Collection)|removeAll(Collection<?> c)]]** - Αφαιρεί όλες τις εγγραφές που περιέχονται στο Collection ''c''.
 <code java StudentCollection.java> <code java StudentCollection.java>
 import java.util.*; import java.util.*;
-import java.lang.*; 
- 
-import java.util.*; 
-import java.lang.*; 
  
 public class StudentCollection { public class StudentCollection {
- +    
-  private Collection<Student> students; +  public static void main(String args[]) { 
-   +    Collection<Student> students = new ArrayList<>();
-  public StudentCollection() { +
-    students = new LinkedList<Student>(); +
-    populateList(); +
-  } +
-   +
-  public final void populateList() {+
     students.add(new Student("John", "Smith"));     students.add(new Student("John", "Smith"));
     students.add(new Student("Stanley", "Peters"));     students.add(new Student("Stanley", "Peters"));
Line 192: Line 151:
     students.add(new Student("Suzan", "Miles"));     students.add(new Student("Suzan", "Miles"));
     students.add(new Student("Mary", "Poppins"));     students.add(new Student("Mary", "Poppins"));
-  } +        
-   +
-  public Collection<Student> getStudents() { +
-    return students; +
-  } +
-   +
-  public void iterateList() {   +
-    for(Student st: students) { +
-      System.out.println(st.toString()); +
-    } +
-  } +
-   +
-  public static void main(String args[]) { +
-    StudentCollection stl = new StudentCollection();    +
     Collection <Student> sts = new LinkedList<Student>();     Collection <Student> sts = new LinkedList<Student>();
-     
-    //comment for statement 
-    int i=0; 
-    for(Student st : stl.getStudents()) { 
-      sts.add(st); 
-      if(++i==2) break; 
-    } 
-     
-    //and uncomment this code below 
-    /* 
     sts.add(new Student("John", "Smith"));     sts.add(new Student("John", "Smith"));
     sts.add(new Student("Stanley", "Peters"));     sts.add(new Student("Stanley", "Peters"));
-    */ +  
-     +    students.addAll(sts)
-    stl.getStudents().removeAll(sts); +    students.removeAll(sts); 
-    stl.iterateList();+    print(students);
          
   }   }
-+   
 +  public static void print(Collection<Student> collection) { 
 +    Iterator<Student> it = collection.iterator(); 
 +    while(it.hasNext()) 
 +      System.out.println(it.next()); 
 +  } 
 +}
 </code> </code>
  
-<WRAP center 70% round tip> +Παρατηρήστε ότι η μέθοδος ''removeAll'' αφαιρεί το σύνολο των εγγραφών ακόμη και εάν μία εγγραφή εμφανίζεται περισσότερες από μία φορές.
-Και εδώ ισχύει ότι αναφέραμε παραπάνω αναφορικά με την σύγκριση των //Collections//. Eάν η λίστα //sts// δημιουργηθεί από αντίγραφα των αντικειμένων της λίστας //stl//, η μέθοδος //removeAll// δεν θα αφαιρέσει τίποτα. +
-</WRAP> +
  
 +|Προηγούμενο: [[:java:jfc_interfaces | JCF Interfaces ]] | [[:toc | Περιεχόμενα ]] | Επόμενο: [[:java:jfc_intf_set | Interface java.util.Set ]] |
  
java/jfc_intf_collection.txt · Last modified: 2021/05/22 02:47 (external edit)