Wat is Java Vector

In deze tutorial wordt alles uitgelegd over de gegevensstructuur van vectoren in Java, met voorbeelden. U leert hoe u een Java-vector in uw programma's kunt maken, initialiseren, sorteren en gebruiken:

Een vector kan worden gedefinieerd als een dynamische matrix die zelf kan groeien of krimpen, d.w.z. de vector groeit wanneer er meer elementen aan worden toegevoegd en krimpt wanneer er elementen uit worden verwijderd.

Dit gedrag is anders dan dat van arrays, die statisch zijn. Maar net als arrays zijn vectorelementen toegankelijk met gehele indices.

Een vector kan worden gezien als een andere dynamische array-gegevensstructuur, ArrayList met uitzondering van de twee onderstaande verschillen:

  • De vector is gesynchroniseerd, d.w.z. alle methoden in de Vector zijn gemarkeerd als "gesynchroniseerd" en dus kan, zodra een methode is aangeroepen, dezelfde methode niet meer worden aangeroepen tenzij de vorige aanroep is beëindigd.
  • De vectorklasse heeft veel methoden die geen deel uitmaken van het raamwerk van de verzamelingen, maar van zijn legacy-methoden.

Java Vector Klasse

Een Vectorklasse maakt deel uit van de " java.util "Een Vector is een array van objecten of een vector van objecten.

Hieronder volgt een klasseverklaring van de klasse Vector:

 public class Vector extends Object implementeert List, Cloneable, Serializable 

Zoals hierboven getoond, breidt een Vectorklasse " java.lang.object " en implementeert de interfaces List, Cloneable en Serializable.

Hoe maak je een vector in Java?

U kunt een Vectorobject creëren met een van de volgende Vectorconstructormethoden.

Constructor Prototype Beschrijving
vector() Dit is de standaardconstructor van de klasse Vector. Hij creëert een lege vector met grootte 10.
vector(int initialCapacity) Deze overloaded constructor construeert een leeg Vectorobject met de capaciteit = initialCapacity.
vector(int initialCapacity, int capacityIncrement) Deze constructormethode creëert een leeg Vectorobject met gespecificeerde initialCapacity en capacityIncrement.
Vector ( Verzameling c) Een Vectorobject wordt gecreëerd met de initiële elementen uit de gespecificeerde verzameling c.

Laten we eens kijken naar elk van de constructeurs om Vectorobjecten te initialiseren.

Initialiseer Vector

(i) Vector()

Dit is de standaardconstructor van de klasse Vector. Wanneer u deze constructor aanroept, wordt een vectorobject van standaardgrootte 10 gecreëerd.

De algemene syntaxis van deze methode is:

Vector object = nieuwe Vector();

Bijvoorbeeld,

 Vector vec1 = nieuwe Vector (); 

Het bovenstaande statement creëert een nieuwe Vector "vec1" met grootte 10.

(ii) Vector(int initialCapacity)

De overloaded constructor van de klasse Vector aanvaardt "initialCapacity" als argument. Deze constructor creëert een Vectorobject met de opgegeven capaciteit.

De algemene syntaxis van de methode is:

Vector object = nieuwe Vector (initialCapacity);

Bijvoorbeeld,

 Vector vec1 = nieuwe Vector (10); 

De bovenstaande programmeeropdracht creëert een Vectorobject "vec1" met een capaciteit van 10 i.e. Deze Vector kan maximaal 10 elementen opslaan.

(iii) Vector(int initialCapacity, int capacityIncrement)

Dit is nog een overloaded constructor van de klasse Vector, die een Vectorobject creëert met de gespecificeerde begincapaciteit en toename voor de capaciteit.

De algemene syntaxis voor deze methode is:

Vector object = nieuwe Vector (initialCapacity, capacityIncrement);

Bijvoorbeeld,

 Vector vec1 = nieuwe Vector(5,10); 

In de bovenstaande verklaring is de initiële capaciteit van de Vector 5 en de verhoging 10. Dit betekent dat wanneer het 6e element in de vector wordt ingevoegd, de capaciteit van de vector zal worden verhoogd tot 15 (5 + 10). Evenzo zal, wanneer het 16e element wordt ingevoegd, de capaciteit van de Vector worden uitgebreid tot 25 (15 +10).

(iv) Vector(Verzameling c)

De laatste overloaded constructor van de klasse Vector neemt een voorgedefinieerde verzameling als argument en creëert een Vector met alle elementen uit deze verzameling als elementen.

De algemene syntaxis is:

Vector object = nieuwe Vector (Verzameling c);

Bijvoorbeeld,

 Vector vec1 = nieuwe Vector(aList); waarbij aList = {1,2,3,4,5}; 

De bovenstaande verklaring creëert een Vector "vec1" met initiële elementen als {1,2,3,4, 5}.

Met al deze beschrijvingen in gedachten kunnen we een Vectorprogramma uitvoeren om deze constructeurs beter te begrijpen.

Vectormethoden in Java

Hieronder volgen de methoden die worden ondersteund door de klasse Vector in Java.

Methode Naam Prototype Beschrijving
voeg toe Boolean add(E e) Voegt gegeven element toe aan het einde van de vector.
Void add(int index, E element) Voegt element toe aan de vector op de opgegeven index.
addAll Booleaanse addAll(Verzameling c) Voegt alle elementen van de gegeven verzameling toe aan het einde van de vector.
Boolean addAll(int index, Collectie c) Voegt alle elementen in de opgegeven verzameling toe op opgegeven index.
addElement void addElement(E obj) Voegt het opgegeven element toe aan het einde van de vector door de vectorgrootte te vergroten.
Capaciteit Int capaciteit() Geeft als resultaat de huidige capaciteit van de vector.
Duidelijk Void clear() Verwijdert de elementen van de vector.
Kloon Object kloon() Kloont de vector.
Bevat Boolean bevat(Object o) Controleert of de vector het opgegeven element bevat.
bevatAlle Boolean containsAll(Collection c) Controleert of de vector alle elementen bevat die aanwezig zijn in de gegeven verzameling.
copyInto Void copyInto(Object[] anArray) Kopieert de vectorelementen naar de opgegeven array.
ElementAt E ElementAt(int index) Geeft vectorelement op opgegeven index.
Elementen Enumeratie-elementen() Geeft opgesomde componenten voor de vector.
ensureCapacity Void ensureCapacity(int minCapacity) Verhoogt de capaciteit van de vector om aan de opgegeven minimumcapaciteit te voldoen.
Methode Naam Prototype Beschrijving
Gelijk aan Booleaanse gelijkenis(Object o) Vergelijkt de huidige vector met de opgegeven vector om te controleren of ze gelijk zijn.
firstElement E firstElement() Geeft het eerste element van de vector op index 0.
Haal E get(int index) Geeft als resultaat het element in de vector op de opgegeven index.
hashCode int hashCode() Geeft de hashcodewaarde voor de Vector.
indexOf int indexOf(Object o) vindt de index van het eerste voorkomen van het gegeven element in de vector; -1 indien element niet aanwezig is in de vector.
int indexOf(Object o, int index) Doorzoekt de vector vanaf de opgegeven index in voorwaartse richting naar het opgegeven element; geeft index terug indien het element is gevonden anders -1 indien het element niet is gevonden.
insertElementAt Void insertElementAt(E obj, int index) Voegt het gegeven voorwerp in de vector in op de gegeven index.
isEmpty Boolean isEmpty() Controleert of de vector leeg is.
Iterator Iteratoriterator() Geeft een iterator terug die wordt gebruikt om de elementen van de vector te doorlopen.
lastElement E lastElement() Geeft het laatste element van de vector.
lastIndexOf Int lastIndexOf(Object o) Zoekt in de vector naar het laatste voorkomen van het opgegeven element en geeft de index terug, of geeft -1 terug als het element niet wordt gevonden.
Int lastIndexOf(Object o, int index) Start het zoeken naar het laatste voorkomen van het opgegeven element vanaf de opgegeven index achterwaarts. Geeft de index terug als het element is gevonden, anders wordt -1 teruggegeven.
lijstIterator LijstIteratorlijstIterator() Geeft een lijst iterator terug over de vectorelementen.
LijstIteratorlistIterator(int index) Geeft een lijst-iterator terug over de vectorelementen vanaf de opgegeven index.
Methode Naam Prototype Beschrijving
Verwijder E remove(int index) Verwijdert element op gegeven index uit de vector.
Boolean remove(Object o) Verwijdert het eerste voorkomen van het gegeven element uit de vector. Als het element niet aanwezig is, gebeurt er niets met de vector.
removeAll Boolean removeAll(Collection c) Verwijdert alle elementen uit de vector die aanwezig zijn in de gegeven verzameling.
void removeAll Elements() Verwijdert alle vectorelementen en verkleint zo de vector tot nul.
removeElement Boolean removeElement(Object obj) Verwijdert het eerste voorkomen van het gegeven element uit de vector.
void removeElementAt(int index) Verwijdert het element op de opgegeven index.
removeRange protected void removeRange(int fromIndex, int toIndex) Verwijdert alle elementen uit de vector in het opgegeven bereik van fromIndex (inclusief), totoIndex (exclusief).
retainAll Boolean retainAll(Collection c) In tegenstelling tot "removeAll" behoudt de methode retainAll elementen in de Vector die overeenkomen met elementen in de gespecificeerde Verzameling.
stel E set(int index, E element) Stelt de waarde op de opgegeven index in met het nieuwe element.
Void set ElementAt(E obj, int index) Stelt de gegeven elementen in op de gegeven index.
setSize Void setSize(int newSize) Stelt de gegeven grootte in voor deze vector.
Maat int size() Geeft als resultaat het aantal elementen in deze vector of de lengte van de vector.
sublijst ListsubList(intfromIndex, inttoIndex) Geeft een weergave of sublijst van de vector van vanIndex tot aanIndex.
toArray Object[] naarArray() Converteert de gegeven vector in een array met alle vectorelementen in gegeven volgorde.
T[] toArray(T[] a) Geeft een matrix terug van het opgegeven type met alle vectorelementen.
toString String toString() Geeft een tekenreeksweergave van de vector.
trimToSize void trimToSize() Snijdt de vector bij tot de huidige grootte.

Vector Uitvoering

Het volgende Java-programma demonstreert het gebruik van alle hierboven beschreven constructormethoden.

 import java.util.*; public class Main{ public static void main(String[] args) { /Creëer vectoren v1, v2,v3 en v4 Vector v1 = nieuwe Vector(); /een vector met standaard constructor Vector v2 = nieuwe Vector(20); //een vector van gegeven Grootte //initialiseer vector v2 met waarden v2.add(10); v2.add(20); v2.add(30); Vector v3 = nieuwe Vector(30, 10); //een vector van gegeven Grootte en Increment //creëer een vector v4 metgegeven verzameling Lijst aList = nieuwe ArrayList(); aList.add("one"); aList.add("two"); Vector v4 = nieuwe Vector(aList); //print inhoud van elke vector System.out.println("Vector v1 Inhoud:" + v1); System.out.println("Vector v2 Inhoud:" + v2); System.out.println("Vector v3 Inhoud:" + v3); System.out.println("Vector v4 Inhoud:" + v4); } }. 

Uitgang:

Het bovenstaande programma bevat vier Vectoren. De eerste v1 wordt gemaakt met een standaardconstructor. De tweede Vector v2 wordt gemaakt met een begincapaciteit van 20. Dan worden enkele elementen toegevoegd aan v2. De derde Vector wordt gemaakt met een begincapaciteit van 30 en verhoging 10.

Vervolgens maken we een ArrayList en creëren we een vierde Vector v4 met de ArrayList als argument. Tenslotte geven we de inhoud van elk van deze Vectoren weer.

Let op de inhoud van de vierde vector v4. Aangezien wij ArrayList als argument hebben gegeven, wordt de inhoud van ArrayList de inhoud van v4.

Voorbeeld van een volledige vector

Laten we nu nog een ander programma implementeren dat... demonstreren het maken van vectoren, het toevoegen van elementen eraan en het weergeven van de inhoud ervan.

 import java.util.*; public class Main { public static void main(String args[]) { /Maak een lege Vector van even getallen Vector evenVector= nieuwe Vector (); //Voeg elementen toe in de 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); /Weergave van de vector System.out.println("Vectorinhoud evenVector: " +evenVector); //verwijder het eerste voorkomen van een element 4 met behulp van verwijdermethode System.out.println("\nEerste voorkomen van element 4 verwijderd:"+evenVector.remove((Integer)4)); /Weergave van de vector System.out.println("\nVector inhoud na verwijderbewerking: " +evenVector)); /Verwijder het element op index 4 & toon de vector System.out.println("\nVerwijder element op index 4:" +evenVector.remove(4)); System.out.println("\nVectorinhoud na verwijderen: " +evenVector); //hashcode voor de vector System.out.println("\nHashcode van de vector ="+evenVector.hashCode()); /Het element op index 1 ophalen System.out.println("\nElement op index 1 is ="+evenVector.get(1)); } }. 

Uitgang:

Laten we een ander vectorvoorbeeld nemen. In dit programma zullen we een stringvector gebruiken Wij manipuleren deze vector door elementen toe te voegen en drukken vervolgens de grootte en capaciteit ervan af.

 import java.util.*; public class Main { public static void main(String args[]) { // maak een vector met initiële capaciteit = 2 Vector fruits_vec = nieuwe Vector(2); // voeg elementen toe aan de vector fruits_vec.addElement("Druiven"); fruits_vec.addElement("Meloen"); fruits_vec.addElement("Kiwi"); fruits_vec.addElement("Appel"); //druk de huidige grootte en capaciteit van de vector af System.out.println("Vectorgrootte:"+fruits_vec.size()); System.out.println("Default Vector capacity increment:"+fruits_vec.capacity()); //voeg meer elementen toe aan de vector fruits_vec.addElement("Orange"); fruits_vec.addElement("Mango"); fruits_vec.addElement("Fig"); //druk opnieuw de huidige grootte en capaciteit af System.out.println("Vector Size after addition:"+fruits_vec.size()); System.out.println("Vector Capacity after increment:"+fruits_vec.capacity()); //print vectorelementen Enumeration fruits_enum = fruits_vec.elements(); System.out.println("\nVector Elements are:"); while(fruits_enum.hasMoreElements()) System.out.print(fruits_enum.nextElement() + " "); } }. 

Uitgang:

Een vector sorteren

U kunt een vector ook sorteren volgens een bepaalde volgorde. Voor het sorteren van een vector moet u de methode Collections.sort () van het Java Collections Framework gebruiken.

Het volgende voorbeeld toont vectorsortering.

 import java.util.*; public class Main { public static void main(String arg[]) { /Creëer een lege vector Vector oddVector = nieuwe Vector(); //Voeg elementen toe aan de vector oddVector.add(1); oddVector.add(11); oddVector.add(7); oddVector.add(3); oddVector.add(5); //print de vectorelementen System.out.println("Vectorelementen:"+oddVector); //sorteer vector met behulp van Collections.sort methodeCollections.sort(oddVector); //print gesorteerde vector System.out.println("Vectorelementen na sortering:"+oddVector); } }. 

Uitgang:

Het bovenstaande programma maakt een Vector van oneven getallen. Vervolgens wordt met de methode Collections.sort() de Vector gesorteerd.

2D (tweedimensionale) Vector

Een 2d Vector is een Vector die elk van zijn elementen als Vector heeft. Hij kan ook worden aangeduid als "Vector van Vectoren".

Een voorbeeld hieronder demonstreert de 2d Vector.

 import java.util.*; public class Main { public static void main(String args[]) { //definieer en initialiseer een vector Vector inner_vec = nieuwe Vector(); inner_vec.add("Software"); inner_vec.add("Testen"); inner_vec.add("Java"); inner_vec.add("Tutorials"); //definieer een andere vector en voeg de eerste vector eraan toe. Vector outer_vec = nieuwe Vector(); outer_vec.add(inner_vec); String str; //geef de inhoud weer vanvector van vectoren System.out.println("Inhoud van vector van vectoren:"); for(int i=0;i 

Uitgang:

In het bovenstaande programma hebben we een Vector van vier elementen. Vervolgens declareren we een andere vector en voegen we de vorige vector als element toe aan de tweede vector. Let op de manier waarop de elementen van de vector worden benaderd. Uit de for-lus kunt u afleiden dat het eerste element van de buitenste vector (op index 0) de eerste of binnenste vector is.

In de lus houden we dus de index van de buitenste vector op 0 en lopen we door de binnenste vector om alle elementen weer te geven.

Vector omzetten naar matrix

Laten we het volgende voorbeeld bekijken van het omzetten van een Vector in een Array. Om een Vector in een Array om te zetten, maken we gebruik van de methode "toArray" van de klasse Vector.

In het volgende programmeervoorbeeld Met de methode toArray van de klasse Vector zetten we de Vector om in een string-array door het string-array-object als argument door te geven.

 import java.util.Vector; public class Main { public static void main(String[] args) { // Maak een Vector van String-elementen Vector color_vector = new Vector(); // Voeg elementen toe aan 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"); //Converteer Vector naarString Array met behulp van toArray-methode String[] colorsArray = color_vector.toArray(new String[color_vector.size()]); //print Array-elementen System.out.println("String Array Elements :"); for(String val:colorsArray){ System.out.print(val + " "); } }. 

Uitgang:

Vector vs Array

Hieronder staan enkele verschillen tussen een Vector en een Array.

Vector Array
Vectoren zijn dynamisch en hun grootte groeit en krimpt naarmate elementen worden toegevoegd of verwijderd. Arrays zijn statisch en de grootte ervan staat vast zodra ze gedeclareerd zijn.
Vectoren kunnen alleen objecten opslaan. Arrays kunnen zowel primitieve types als objecten opslaan.
Het biedt een methode size() om de grootte te bepalen. Geeft lengte-eigenschap om de lengte te bepalen.
Geen conceptuele afmetingen, maar kan worden gemaakt als een vector van vectoren, gewoonlijk 2d vector genoemd. Arrays ondersteunen dimensies.
Vector is gesynchroniseerd. De array is niet gesynchroniseerd.
Vector is langzamer dan de array. Array is sneller.
Reserveert extra opslagruimte wanneer de capaciteit wordt verhoogd. Reserveert geen extra opslagruimte.
Zorgt voor typeveiligheid door generieken te ondersteunen. Geen algemene ondersteuning.

Vector vs ArrayList

Deze paragraaf bespreekt het verschil tussen Vector en ArrayList in Java.

Vector ArrayList
Aanwezig sinds de eerste versie van Java (JDK 1.0 versie). Ingevoerd in Java sinds JDK 1.2
Vector is een oude klasse van Java. ArrayList is een onderdeel van het Java Collections Framework.
Vector wordt dubbel zo groot wanneer zijn capaciteit is bereikt. ArrayList groeit met de helft wanneer zijn capaciteit is bereikt.
Vectormethoden zijn gesynchroniseerd. ArrayList is niet gesynchroniseerd.
Vector gebruikt Enumerator en Iterator voor traverseren. ArrayList gebruikt alleen Iterator.
Vectorbewerkingen zijn langzamer. ArrayList is sneller.
Vector heeft increment size waarmee vector size kan worden vergroot. ArrayList geeft geen increment size.
Vector is thread-safe, wat betekent dat het gebruik van Vector vanuit meerdere threads is toegestaan en veilig is. ArrayList is niet thread-safe.

Vaak gestelde vragen

Vraag 1) Wat is een vector in Java?

Antwoord: In Java kan een Vector worden gedefinieerd als een groeibare array van objecten. Net als arrays kunnen Vectorelementen ook worden benaderd met behulp van indices.

Vraag 2) Is vector geordend in Java?

Antwoord: Ja. Een Vector is geordend en handhaaft de invoegvolgorde voor elementen.

V3) Is Vector thread-safe in Java?

Antwoord: Ja. In Java is de Vectorklasse thread-safe. Omdat de Vectorklasse gesynchroniseerd is, is ze thread-safe, d.w.z. dat u de Vectorklasse vanuit meerdere threads kunt gebruiken en dat ze veilig is.

Vraag 4) Waarom gebruiken we vector in Java?

Antwoord: De belangrijkste reden waarom Vector wordt gebruikt in Java is dat een Vector automatisch groeit en krimpt. Ze zijn dynamisch waardoor ze de voorkeur genieten boven arrays.

V #5) Wat is beter - ArrayList of vector?

Antwoord: Prestatiegewijs is ArrayList sneller in vergelijking met Vector, omdat Vector gesynchroniseerd is en het langzamer maakt.

Conclusie

In deze tutorial zijn we begonnen met de gegevensstructuur Vector in Java. Vectoren lijken bijna op een array waarin de Vector-elementen worden benaderd met behulp van bekende indices. Vectoren worden dynamische arrays genoemd en in tegenstelling tot arrays groeit en krimpt de Vector-grootte automatisch.

Vectoren hebben ook de functies capaciteit en increment die kunnen worden gebruikt om extra opslagruimte te creëren en te reserveren voor toekomstige toevoegingen. Vector is een oudere klasse in het java.util-pakket van Java en is gesynchroniseerd en thread-safe.

We moeten dus de voorkeur geven aan vectoren wanneer we een dynamische grootte nodig hebben en ook wanneer we in een multi-threaded omgeving werken.

Scroll naar boven