Collection ist die grundlegendste Sammlungsschnittstelle, das heißt, die Elemente der Collection Map stellen den Schlüssel zur Wertezuordnung dar.
Der Unterschied zwischen ArrayList und Vector, der Unterschied zwischen HashMap und Hashtable. ArrayList und Vector Hauptsächlich aus zwei Aspekten
1. Synchronizität: Vector ist threadsicher, was bedeutet, dass es synchron ist, während ArrayList threadsicher und nicht synchron ist
2. Datenwachstum: Wenn Wachstum erforderlich ist, ist Vector das Standardwachstum eine Ebene, während ArrayList die Hälfte der ursprünglichen Größe hat
1. Historische Gründe: Hashtable basiert auf der alten Dictionary-Klasse und HashMap ist eine Implementierung der in Java 1.2 eingeführten Map-Schnittstelle.
2 Synchronizität: Hashtable ist threadsicher, während HashMap eine ist Thread-Programm. Unsicher, nicht synchron
3. Wert: Nur HashMap ermöglicht die Verwendung eines Nullwerts als Schlüssel oder Wert eines Tabelleneintrags
ArrayList und Vector Arrays speichern Daten. Die Anzahl der Elemente in diesem Array ist größer als die tatsächlich gespeicherten Daten, sodass Elemente hinzugefügt und eingefügt werden können. Sie alle ermöglichen die direkte Indizierung von Elementen nach Seriennummer, das Einfügen von Elementen erfordert jedoch Speicheroperationen wie das Verschieben von Array-Elementen Daher ist die Indizierung von Daten schnell, das Einfügen von Daten jedoch langsam, da die synchronisierte Methode (Thread-Sicherheit) normalerweise eine schlechtere Leistung aufweist als ArrayList. Die Indizierung von Daten nach Seriennummer ist erforderlich Vorwärts- oder Rückwärtsdurchlauf, aber beim Einfügen von Daten müssen nur die Vorher- und Nachher-Elemente dieses Elements aufgezeichnet werden, sodass die Einfügegeschwindigkeit schneller ist.
8 Entwerfen Sie 4 Threads, von denen zwei j jedes Mal um 1 erhöhen und die anderen beiden Threads j jedes Mal um 1 verringern. Schreiben Sie das Programm.
Das folgende Programm verwendet interne Klassen zum Implementieren von Threads und berücksichtigt nicht die Reihenfolge beim Erhöhen oder Verringern von j.
public class ThreadTest1{
private int j;
public static void main(String args[]){
ThreadTest1 tt=new ThreadTest1();
Inc inc=tt.new Inc();
Dec dec=tt.new Dec ();
for(int i=0;i<2;i++){
Thread t=new Thread(inc);
t.start();
t=new Thread(dec);
t.start() ;
}
}
private synchronisiert void inc(){
j++;
System.out.println(Thread.currentThread().getName()+"-inc:"+j);
}
private synchronisiert void dec( ){
j--;
System.out.println(Thread.currentThread().getName()+"-dec:"+j);
}
class Inc implementiert Runnable{
public void run(){
for(int i=0;i<100;i++){
inc();
}
}
}
class Dec implementiert Runnable{
public void run(){
for(int i=0;i<100; i++){
dec();
}
}
}
}
Das obige ist der detaillierte Inhalt vonWozu dient Collection FrameWork in JAVA?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!