Java vektor nədir

Bu Dərslik Nümunələrlə Java-da Vektor Məlumat Strukturu haqqında hər şeyi izah edir. Yaratmağı, İlkin, Çeşidləmə və amp; Proqramlarınızda Java Vektorundan istifadə edin:

Vektor öz-özünə böyüyə və ya kiçilə bilən dinamik massiv kimi müəyyən edilə bilər, yəni vektor ona daha çox element əlavə olunduqda böyüyəcək və elementlər azaldıqda kiçiləcək. ondan silinir.

Bu davranış statik olan massivlərdən fərqlidir. Lakin massivlərə bənzər, vektor elementlərinə tam ədəd indekslərindən istifadə etməklə daxil olmaq olar.

Vektora digər dinamik massiv məlumat strukturuna oxşar olaraq baxmaq olar, ArrayList istisna olmaqla iki aşağıda fərq var:

  • Vektor sinxronlaşdırılıb, yəni Vektor-dakı bütün metodlar "sinxronlaşdırılmış" olaraq qeyd olunur və beləliklə, bir üsul çağırıldıqdan sonra əvvəlki çağırış olmadıqda, eyni metod çağırıla bilməz. sona çatdı.
  • Vektor sinfində kolleksiyalar çərçivəsinin bir hissəsi olmayan, lakin onun köhnə üsulları olan bir çox metod var.

Java Vektor Sinfi

Vektor sinfi “ java.util ” paketindən başqa və List interfeysini həyata keçirir. Vektor obyektlərin massivi və ya obyektlərin vektorudur.

Vektor sinfinin sinif bəyannaməsi aşağıda verilmişdir:

 public class Vector extends Object implements List, Cloneable, Serializable 

Yuxarıda göstərildiyi kimi, Vektor sinfi genişlənir “ java.lang.object ” və Siyahı, Klonlana bilən və Seriallaşdırıla bilən interfeysləri həyata keçirir.

Java-da Vektoru Necə Yaratmaq olar?

Siz edə bilərsinizAşağıdakı Vektor konstruktor üsullarından hər hansı birini istifadə edərək Vektor obyekti yaradın.

Konstruktor Prototipi Təsvir
vector() Bu, Vector sinfinin standart konstruktorudur. O, ölçüsü 10 olan boş vektor yaradır.
vector(int initialCapacity) Bu həddən artıq yüklənmiş konstruktor = tutumu olan boş Vektor obyekti qurur. initialCapacity.
vector(int initialCapacity, int capacityIncrement) Bu konstruktor metodu müəyyən edilmiş initialCapacity və capacityIncrement ilə boş Vektor obyekti yaradır.
Vektor( Kolleksiya c) Vektor obyekti müəyyən edilmiş c kolleksiyasının ilkin elementləri ilə yaradılmışdır.

Vektor obyektlərini işə salmaq üçün konstruktorların hər birinə nəzər salaq.

Vektoru işə salın

(i) Vector()

Bu, Vector sinifinin standart konstruktorudur. Bu konstruktoru çağırdığınız zaman 10 standart ölçüsü olan Vector obyekti yaradılır.

Bu metodun ümumi sintaksisi:

Vektor obyekti = new Vector();

Məsələn,

Vector vec1 = new Vector ();

Yuxarıdakı ifadə 10 ölçüsü olan yeni 'vec1' vektoru yaradır.

(ii) Vector(int initialCapacity)

Vektor sinifinin həddən artıq yüklənmiş konstruktoru arqument kimi 'initialCapacity' qəbul edir. Bu konstruktor vektor yaradırmüəyyən edilmiş tutumlu obyekt.

Metodun ümumi sintaksisi:

Vektor obyekti = new Vector (initialCapacity);

Məsələn,

Vector vec1 = new Vector (10);

Yuxarıdakı proqramlaşdırma ifadəsi 10 tutumlu 'vec1' Vektor obyekti yaradacaq, yəni bu Vektor 10-a qədər saxlaya bilər. elementləri.

(iii) Vector(int initialCapacity, int capacityIncrement)

Bu, Vektor sinifinin daha bir həddən artıq yüklənmiş konstruktorudur və müəyyən edilmiş başlanğıc ilə Vektor obyekti yaradır. tutum üçün tutum və artım.

Bu metodun ümumi sintaksisi:

Vektor obyekti = yeni Vektor (initialCapacity, capacityIncrement);

Məsələn,

Vector vec1 = new Vector(5,10);

Yuxarıdakı ifadədə vektorun ilkin tutumu 5, artım isə 10-dur. Bu o deməkdir ki, 6-cı element vektora daxil edilir, vektorun tutumu 15-ə (5 + 10) qədər artırılacaqdır. Eynilə, 16-cı element daxil edildikdə, Vektorun vektor tutumu 25-ə (15 +10) qədər artırılacaq.

(iv) Vektor(Kolleksiya c)

Vektor sinfinin həddən artıq yüklənmiş sonuncu konstruktoru əvvəlcədən təyin edilmiş kolleksiyanı arqument kimi qəbul edir və onun elementləri kimi bu kolleksiyanın bütün elementləri ilə Vektor yaradır.

Ümumi sintaksis:

Vektor obyekt = yeni Vektor (Kolleksiya c);

Məsələn,

Vector vec1 = new Vector(aList); where aList = {1,2,3,4,5};

Theyuxarıdakı ifadə {1,2,3,4, 5} kimi ilkin elementləri olan 'vec1' Vektoru yaradacaq.

Bütün bu təsvirləri yadda saxlamaq bu konstruktorları daha yaxşı başa düşmək üçün Vektor proqramını həyata keçirməyə imkan verəcək.

Java-da Vektor Metodları

Aşağıdakılar Java-da Vector sinfi tərəfindən dəstəklənən metodlardır.

Metodun adı Prototip Təsvir
add Boolean add(E e) Vektorun sonuna verilmiş elementi əlavə edir.
Void add(int index, E element) Göstərilən indeksdə vektora element əlavə edin.
addAll Boolean addAll(Kolleksiya c) Verilmiş kolleksiyadan vektorun sonuna bütün elementləri əlavə edir.
Boolean addAll(int index, Collection c) Bütün elementləri əlavə edir müəyyən edilmiş indeksdə göstərilən kolleksiyada.
addElement void addElement(E obj) Göstərilən elementi əlavə edir vektor ölçüsünü artırmaqla vektorun sonu.
Tütmə Int capacity() Cari tutumunu qaytarır. vektor.
Clear Void clear() Elementlərinin vektorunu təmizləyir.
Klon Obyekt klonu() Vektoru klonlayır.
Tərkibindədir Boolean ehtiva edir(Object o) Vektorun olub olmadığını yoxlayırmüəyyən edilmiş element.
containsAll Boolean containsAll(Collection c) Vektorda mövcud olan bütün elementlərin olub olmadığını yoxlayır. verilmiş kolleksiya.
copyInto Void copyInto(Object[] anArray) Vektor elementlərini verilmiş massivə köçürür.
ElementAt E ElementAt(int index) Vektor elementini müəyyən edilmiş indeksdə qaytarır.
Elementlər Enumerationelements() Vektor üçün sadalanan komponentləri qaytarır.
provideCapacity Void ensureCapacity(int minCapacity) Göstərilən minimum tutuma cavab vermək üçün vektorun tutumunu artırır.
Metodun adı Prototip Təsvir
Bərabərdir Boolean bərabərdir(Object o) Bərabər olub-olmadığını yoxlamaq üçün cari vektoru müəyyən edilmiş vektorla müqayisə edir.
firstElement E firstElement() 0 indeksində vektorun ilk elementini qaytarır.
Get E get(int index) Vektordakı elementi göstərilən indeksdə qaytarır.
hashCode int hashCode() Vektor üçün hash kodu dəyərini qaytarır.
indexOf int indexOf(Object o) Vektorda verilmiş elementin ilk dəfə rast gəlinməsinin indeksini tapır; -1 əgərelement vektorda yoxdur.
int indexOf(Object o, int index) Belirilmiş element üçün irəli istiqamətdə verilmiş indeksdən vektoru axtarır;qaytarır index əgər element tapılsa başqa -1 element tapılmadıqda.
insertElementAt Void insertElementAt(E obj, int index) Verilmiş obyekti verilmiş indeksdə vektora daxil edir.
isEmpty Boolean isEmpty() Vektorun boş olub olmadığını yoxlayır.
İterator İterator() İteratoru qaytarır. vektorun elementləri üzərindən keçin.
lastElement E lastElement() Vektorun sonuncu elementini qaytarır .
lastIndexOf Int lastIndexOf(Object o) Verilmiş elementin sonuncu baş verməsi üçün vektoru axtarır və qaytarır indeksi və ya elementin tapılmadığını -1 qaytarır.
Int lastIndexOf(Object o, int index) Verilmiş elementin son baş verməsini axtarmağa başlayır. verilmiş indeksi geriyə doğru. Element tapılarsa indeksi qaytarır, əks halda -1 qaytarır.
listIterator ListIteratorlistIterator() Siyahı iteratorunu qaytarır vektor elementləri üzərində.
ListIteratorlistIterator(int index) Vektor elementləri üzərində verilmiş siyahı təkrarlayıcısını qaytarır.indeks.
Metodun adı Prototip Təsvir
Sil E remove(int index) Vektordan verilmiş indeksdəki elementi silir.
Boolean aradan qaldırılması(Object o) Vektordan verilmiş elementin ilk baş verməsini silir. Element mövcud deyilsə, vektorda heç nə baş vermir
removeAll Boolean removeAll(Collection c) Vektordan bütün elementləri silir. verilmiş kolleksiyada mövcuddur.
void removeAll Elements() Bütün vektor elementlərini silərək onu sıfıra endirir.
removeElement Boolean removeElement(Object obyekt) Vektordan verilmiş elementin ilk baş verməsini aradan qaldırır.
void removeElementAt(int) index) Verilmiş indeksdəki elementi silir.
removeRange qorunan void removeRange(int fromIndex, int toIndex) Vektordan verilən diapazondakı bütün elementləri fromIndex (daxil olmaqla), totoIndex (eksklüziv) silir.
retainAll Boolean retainAll(Kolleksiya c) RemoveAll metodundan fərqli olaraq retainAll metodu Vektorda göstərilən Kolleksiyadakı elementlərə uyğun gələn elementləri saxlayır.
set E set(int index) , E element) Yeni elementlə verilmiş indeksdə dəyəri təyin edirtəmin edilmişdir.
Void set ElementAt(E obj, int index) Void elementləri verilmiş indeksdə təyin edir.
setSize Void setSize(int newSize) Bu vektor üçün verilmiş ölçüsü təyin edir.
Size int size() Bu vektordakı elementlərin sayını və ya vektorun uzunluğunu qaytarır.
alt Siyahı ListsubList(intfromIndex, inttoIndex) İndeksdən İndeksə qədər dəyişən vektorun görünüşünü və ya alt siyahısını qaytarır.
toArray Obyekt[] toArray () Verilmiş vektoru verilmiş ardıcıllıqla bütün vektor elementlərini ehtiva edən massivə çevirir.
T[] toArray(T[] a) Bütün vektor elementlərini ehtiva edən müəyyən edilmiş tipli massivi qaytarır.
toString String toString() Vektorun sətir təsvirini qaytarır.
trimToSize void trimToSize() Cari ölçüsü uyğunlaşdırmaq üçün vektoru kəsir.

Vektor İcrası

Aşağıdakı Java proqramı yuxarıda təsvir edilən bütün konstruktor metodlarının istifadəsini nümayiş etdirir.

 import java.util.*; public class Main{ public static void main(String[] args) { //Create vectors v1, v2,v3 and v4 Vector v1 = new Vector(); //a vector with default constructor Vector v2 = new Vector(20); // a vector of given Size //initialize vector v2 with values v2.add(10); v2.add(20); v2.add(30); Vector v3 = new Vector(30, 10); // a vector of given Size and Increment // create a vector v4 with given collection List aList = new ArrayList(); aList.add("one"); aList.add("two"); Vector v4 = new Vector(aList); //print contents of each vector System.out.println("Vector v1 Contents:" + v1); System.out.println("Vector v2 Contents:" + v2); System.out.println("Vector v3 Contents:" + v3); System.out.println("Vector v4 Contents:" + v4); } } 

Çıxış:

Yuxarıdakı proqramda dörd Vektor var. İlk v1 standart konstruktorla yaradılmışdır. İkinci Vektor v2 ilkin tutumu 20 ilə yaradılmışdır. Sonra v2-yə bir neçə element əlavə olunur. Üçüncü Vektor ilkin tutumu 30 və artımla yaradılmışdır10.

Sonra, biz ArrayList yaradırıq və ArrayList arqumenti ilə dördüncü Vektor v4 yaradırıq. Nəhayət, biz bu Vektorların hər birinin məzmununu göstəririk.

Dördüncü Vektor v4-ün məzmununa diqqət yetirin. ArrayList-i arqument kimi təqdim etdiyimiz üçün ArrayList-in məzmunu v4-ün məzmununa çevrilir.

Tam Vektor Misal

İndi isə vektorların yaradılmasını nümayiş etdirəcək başqa bir proqramı həyata keçirək. , ona elementlər əlavə etmək və onun məzmununu göstərmək.

 import java.util.*; public class Main { public static void main(String args[]) { //Create an empty Vector of even numbers Vector  evenVector= new Vector  (); //Add elements in the vector evenVector.add(2); evenVector.add(4); evenVector.add(6); evenVector.add(8); evenVector.add(10); evenVector.add(12); evenVector.add(14); evenVector.add(16); //Display the vector System.out.println("Vector evenVector contents: " +evenVector); //delete the first occurence of an element 4 using remove method System.out.println("\nFirstoccurence of element 4 removed: "+evenVector.remove((Integer)4)); //Display the vector System.out.println("\nVector contents after remove operation: " +evenVector); //Remove the element at index 4 & display the vector System.out.println("\nRemove element at index 4: " +evenVector.remove(4)); System.out.println("\nVector contents after remove: " +evenVector); //hashcode for the vector System.out.println("\nHash code of the vector = "+evenVector.hashCode()); //Get the element at index 1 System.out.println("\nElement at index 1 is = "+evenVector.get(1)); } } 

Çıxış:

Başqa vektor nümunəsini götürək. Bu proqramda biz sətir vektorundan istifadə edəcəyik. Biz elementləri əlavə etməklə bu vektoru manipulyasiya edirik və sonra onun ölçüsünü və tutumunu çap edirik.

 import java.util.*; public class Main { public static void main(String args[]) { // create a vector with initial capacity = 2 Vector fruits_vec = new Vector(2); //add elements to the vector fruits_vec.addElement("Grapes"); fruits_vec.addElement("Melon"); fruits_vec.addElement("Kiwi"); fruits_vec.addElement("Apple"); //print current size and capacity of the vector System.out.println("Vector Size: "+fruits_vec.size()); System.out.println("Default Vector capacity increment: "+fruits_vec.capacity()); //add more elements to the vector fruits_vec.addElement("Orange"); fruits_vec.addElement("Mango"); fruits_vec.addElement("Fig"); //print current size and capacity again System.out.println("Vector Size after addition: "+fruits_vec.size()); System.out.println("Vector Capacity after increment: "+fruits_vec.capacity()); //print vector elements Enumeration fruits_enum = fruits_vec.elements(); System.out.println("\nVector Elements are:"); while(fruits_enum.hasMoreElements()) System.out.print(fruits_enum.nextElement() + " "); } }

Çıxış:

Vektoru çeşidləyin

Siz həmçinin vektoru xüsusi sıraya görə çeşidləyə bilərsiniz. Vektoru çeşidləmək üçün Java Collections Framework-ün Collections.sort () metodundan istifadə etməlisiniz.

Aşağıdakı nümunə vektor çeşidlənməsini göstərir.

 import java.util.*; public class Main { public static void main(String arg[]) { //Create an empty vector Vector oddVector = new Vector(); //Add elements to the vector oddVector.add(1); oddVector.add(11); oddVector.add(7); oddVector.add(3); oddVector.add(5); //print the vector elements System.out.println("Vector elements: "+oddVector); //sort vector using Collections.sort method Collections.sort(oddVector); //print sorted vector System.out.println("Vector elements after sorting: "+oddVector); } } 

Nəticə:

Yuxarıdakı proqram tək ədədlərdən ibarət vektor yaradır. Sonra Collections.sort() metodundan istifadə edərək Vektor çeşidlənir.

2D (İkiölçülü) Vektor

2D Vektor elementlərinin hər biri Vektor kimi olan Vektordur. Onu “Vektorlar vektoru” kimi də adlandırmaq olar.

Aşağıdakı nümunə 2d Vektoru nümayiş etdirir.

 import java.util.*; public class Main { public static void main(String args[]) { //define and initialize a vector Vector inner_vec = new Vector(); inner_vec.add("Software"); inner_vec.add("Testing"); inner_vec.add("Java"); inner_vec.add("Tutorials"); //define another vector and add first vector to it. Vector outer_vec = new Vector(); outer_vec.add(inner_vec); String str; //display the contents of vector of vectors System.out.println("Contents of vector of vectors:"); for(int i=0;i

Output:

In the above program, we have a Vector of four elements. Then, we declare another vector and add the previous vector as an element to the second vector. Note the way the elements of the vector is accessed. Form the for loop, you can conclude that the outer vector’s first element (at index 0) is the first or inner vector.

Thus, in the loop, we keep the index of the outer vector as 0 and loop through the inner vector to display all the elements.

Convert Vector To Array

Let’s consider the following example of converting a Vector to an array. To convert a Vector to an Array, we make use of the ‘toArray’ method of the Vector class.

In the following programming example , we declare a string Vector and add elements to it. Then using the toArray method of the Vector class, we convert the Vector to a String array by passing the string array object as an argument.

 import java.util.Vector; public class Main { public static void main(String[] args) { // Create a Vector of String elements Vector color_vector = new Vector(); // Add elements to Vector color_vector.add("Violet"); color_vector.add("Indigo"); color_vector.add("Blue"); color_vector.add("Green"); color_vector.add("Yellow"); color_vector.add("Orange"); color_vector.add("Red"); //Convert Vector to String Array using toArray method String[] colorsArray = color_vector.toArray(new String[color_vector.size()]); //print Array Elements System.out.println("String Array Elements :"); for(String val:colorsArray){ System.out.print(val + " "); } } }

Output:

Vector vs Array

Enlisted below are some of the differences between a Vector and an Array.

VectorArray
Vector is dynamic and its size grows and shrinks as elements are added or removed.Arrays are static and its size remains fixed once declared.
Vectors can store only objects.Arrays can store primitive types as well as objects.
It provides a size() method to determine the size.Provides length property to determine the length.
No concept dimensions but can be created as a vector of vectors, normally called 2d vector.Arrays support dimensions.
Vector is synchronized.The array is not synchronized.
Vector is slower than the array.Array is faster.
Reserves additional storage when capacity is incremented.Does not reserve any additional storage.
Ensures type safety by supporting generics.No generic support.

Vector vs ArrayList

This section discusses the difference between Vector and ArrayList in Java.

VectorArrayList
Present since the initial version of Java(JDK 1.0 version).Introduced in Java since JDK 1.2
Vector is a legacy class of Java.ArrayList is a part of the Java Collections Framework.
Vector grows double its size when its capacity is reached.ArrayList grows by half the size when its capacity is reached.
Vector methods are synchronized.ArrayList is not synchronized.
Vector uses Enumerator and Iterator for traversing.ArrayList uses only Iterator.
Vector operations are slower.ArrayList is faster.
Vector has increment size using which vector size can be increased.ArrayList does not provide increment size.
Vector is thread-safe which means using Vector from multiple threads is permitted and is safe.ArrayList is not thread-safe.

Frequently Asked Questions

Q #1) What is a Vector in Java?

Answer: In Java, a Vector can be defined as a growable array of objects. Similar to arrays, Vector elements can also be accessed using indices.

Q #2) Is vector ordered in Java?

Answer: Yes. A Vector is ordered and maintains the inserting order for elements.

Q #3) Is Vector thread-safe in Java?

Answer: Yes. In Java the Vector class is thread-safe. As the Vector class is synchronized, it makes it thread-safe i.e. you can use the Vector class from multiple threads and it is safe.

Q #4) Why do we use vector in Java?

Answer: The most important reason for which Vector is used in Java is that a Vector grows and shrinks automatically. They are dynamic because of which they are preferred over arrays.

Q #5) Which is better – ArrayList or vector?

Answer: Performance-wise ArrayList is faster when compared to Vector as Vector is synchronized and makes it slower.

Conclusion

In this tutorial, we started with the Vector data structure in Java. Vectors are almost similar to an array in which the Vector elements are accessed using familiar indices. Vectors are called dynamic array and unlike arrays, the Vector size grows and shrinks automatically.

Vectors also have the capacity and increment features that can be used to create and reserve additional storage for future additions. Vector is a legacy class in java.util package of Java and is synchronized as well as thread-safe.

Thus, we should prefer vectors when we need dynamic size and also while we are working in a multi-threaded environment.

Yuxarıya keç