Rumah  >  Artikel  >  Java  >  Apakah kegunaan Collection FrameWork dalam JAVA

Apakah kegunaan Collection FrameWork dalam JAVA

王林
王林ke hadapan
2023-05-09 13:31:071254semak imbas

Koleksi ialah antara muka koleksi yang paling asas A Collection mewakili satu set Objek, iaitu unsur-unsur Koleksi Map menyediakan kunci kepada pemetaan nilai

Perbezaan antara ArrayList dan Vektor. HashMap dan Hashtable
Jawapan: Terdapat dua aspek utama ArrayList dan Vector.
1 Synchronicity: Vector adalah thread-safe, yang bermaksud ia adalah segerak, manakala ArrayList adalah thread-safe dan tidak segerak
2. . Pertumbuhan data: Apabila pertumbuhan diperlukan, Vektor berkembang secara lalai sebanyak satu tahap, manakala ArrayList berkembang separuh daripada saiz asalnya

Terdapat tiga aspek utama HashMap dan HashTable.
1. Sebab sejarah: Hashtable adalah berdasarkan kelas Kamus lama, dan HashMap ialah pelaksanaan antara muka Map yang diperkenalkan dalam Java 1.2
2. Synchronicity: Hashtable selamat untuk benang, yang bermaksud ia adalah segerak dan HashMap ialah program dalam talian yang tidak selamat dan tidak segerak
3. Nilai: Hanya HashMap membenarkan anda menggunakan nilai nol sebagai kunci atau nilai entri jadual

Prestasi storan dan prestasi ArrayList, Ciri Vektor, LinkedList
Kedua-dua ArrayList dan Vector menggunakan tatasusunan untuk menyimpan data Bilangan elemen tatasusunan adalah lebih besar daripada data yang disimpan sebenar supaya elemen boleh ditambah dan disisipkan secara terus mengikut nombor siri. tetapi memasukkan elemen melibatkan operasi memori seperti menggerakkan elemen tatasusunan , jadi mengindeks data adalah pantas tetapi memasukkan data adalah perlahan Oleh kerana Vector menggunakan kaedah yang disegerakkan (keselamatan benang), prestasinya biasanya lebih teruk daripada ArrayList, manakala LinkedList menggunakan senarai terpaut dua kali. untuk melaksanakan storan. Mengindeks data mengikut nombor siri memerlukan lintasan ke hadapan atau ke belakang, tetapi Apabila memasukkan data, anda hanya perlu merekodkan item sebelum dan selepas item ini, jadi kelajuan pemasukan lebih cepat.
8 Reka bentuk 4 utas, dua daripadanya meningkat j sebanyak 1 setiap kali, dan dua utas lagi mengurangkan j sebanyak 1 setiap kali. Tulis program.
Atur cara berikut menggunakan kelas dalaman untuk melaksanakan urutan, dan tidak mengambil kira susunan apabila meningkat atau menurun j.
kelas awam ThreadTest1{
private int j;
public static void main(String args[]){
ThreadTest1 tt=new ThreadTest1();
Inc inc=tt.new Inc( );
Dis dec=tt.baharu Dis();
untuk(int i=0;i<2;i++){
Thread t=new Thread(inc);
t.start ();
t=new Thread(dec);
t.start();
}
}
private synchronized void inc(){
j++;
System .out.println(Thread.currentThread().getName()+"-inc:"+j);
}
pribadi disegerakkan void dec(){
j--;
Sistem. out.println(Thread.currentThread().getName()+"-dec:"+j);
}

class Inc melaksanakan Runnable{
public void run(){
for(int i=0;i<100;i++){
inc();
}
}
}
class Dec melaksanakan Runnable{
public void run(){
untuk(int i=0;i<100;i++){
dec();
}
}
}
}

Atas ialah kandungan terperinci Apakah kegunaan Collection FrameWork dalam JAVA. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Artikel ini dikembalikan pada:yisu.com. Jika ada pelanggaran, sila hubungi admin@php.cn Padam