java学习随笔--- 捣蛋vector,java随笔---vector_PHP教程
java学习随笔--- 捣蛋vector,java随笔---vector
最近比较有时间啦,有时间搞下java,个人觉得学这门语言语法太多啦,不一一去学习啦,心血来潮,挂了个struct2的源代码,一入深似海啊,看得我天花缭乱,从最简单的开始吧
<span> 1</span> <span>public</span> <span>static</span> <span>void</span><span> main(String[] args) {
</span><span> 2</span>
<span> 3</span> Vector v = <span>new</span> Vector(4<span>);
</span><span> 4</span>
<span> 5</span> <span>//</span><span>向Vector中添加元素 静态数组+动态扩展
</span><span> 6</span> <span>//</span><span>使用add方法直接添加元素 </span>
<span> 7</span> v.add("Test0"<span>);
</span><span> 8</span> v.add("Test1"<span>);
</span><span> 9</span> v.add("Test0"<span>);
</span><span>10</span> v.add("Test2"<span>);
</span><span>11</span> v.add("Test2"<span>);
</span><span>12</span>
<span>13</span> <span>//</span><span>从Vector中删除元素 </span>
<span>14</span> v.remove("Test0"); <span>//</span><span>删除指定内容的元素 </span>
<span>15</span> v.remove(0); <span>//</span><span>按照索引号删除元素
</span><span>16</span>
<span>17</span> <span>//</span><span>获得Vector中已有元素的个数 </span>
<span>18</span> <span>int</span> size =<span> v.size();
</span><span>19</span> System.out.println("size:" +<span> size);
</span><span>20</span>
<span>21</span> <span>//</span><span>遍历Vector中的元素 </span>
<span>22</span> <span>for</span>(<span>int</span> i = 0;i < v.size();i++<span>){
</span><span>23</span> <span> System.out.println(v.get(i));
</span><span>24</span> <span> }
</span><span>25</span> }
代码很简单啦,学过数据结构的都知道,简单的新增改查啦,不过我们要深入一下了解,这玩意跟数组有什么区别
构造函数如下,意思是说你可以初始化一个容量的数,多少你自己决定
<span> 1</span> <span>/**</span>
<span> 2</span> <span> * Constructs an empty vector with the specified initial capacity and
</span><span> 3</span> <span> * with its capacity increment equal to zero.
</span><span> 4</span> <span> *
</span><span> 5</span> <span> * </span><span>@param</span><span> initialCapacity the initial capacity of the vector
</span><span> 6</span> <span> * </span><span>@throws</span><span> IllegalArgumentException if the specified initial capacity
</span><span> 7</span> <span> * is negative
</span><span> 8</span> <span>*/</span>
<span> 9</span> <span>public</span> Vector(<span>int</span><span> initialCapacity) {
</span><span>10</span> <span>this</span>(initialCapacity, 0<span>);
</span><span>11</span> }
我们接着来看,java的构造函数可真的比php强大,支持不同参数调用,换php的话早就报错啦
<span> 1</span> <span>/**</span>
<span> 2</span> <span> * Constructs an empty vector with the specified initial capacity and
</span><span> 3</span> <span> * capacity increment.
</span><span> 4</span> <span> *
</span><span> 5</span> <span> * </span><span>@param</span><span> initialCapacity the initial capacity of the vector
</span><span> 6</span> <span> * </span><span>@param</span><span> capacityIncrement the amount by which the capacity is
</span><span> 7</span> <span> * increased when the vector overflows
</span><span> 8</span> <span> * </span><span>@throws</span><span> IllegalArgumentException if the specified initial capacity
</span><span> 9</span> <span> * is negative
</span><span>10</span> <span>*/</span>
<span>11</span> <span>public</span> Vector(<span>int</span> initialCapacity, <span>int</span><span> capacityIncrement) {
</span><span>12</span> <span>super</span><span>();
</span><span>13</span> <span>if</span> (initialCapacity < 0<span>)
</span><span>14</span> <span>throw</span> <span>new</span> IllegalArgumentException("Illegal Capacity: "+
<span>15</span> <span> initialCapacity);
</span><span>16</span> <span>this</span>.elementData = <span>new</span><span> Object[initialCapacity];
</span><span>17</span> <span>this</span>.capacityIncrement =<span> capacityIncrement;
</span><span>18</span> }
代码是不是很简单,简单的初始化一个对象数组,连我一个高中生的看出来啦,注意到第二个参数,这个是控制数组填满了之后要怎么增加,可以理解为一个策略吧
我们来看看添加元素是怎样实现的
<span> 1</span> <span>/**</span>
<span> 2</span> <span> * Appends the specified element to the end of this Vector.
</span><span> 3</span> <span> *
</span><span> 4</span> <span> * </span><span>@param</span><span> e element to be appended to this Vector
</span><span> 5</span> <span> * </span><span>@return</span><span> {</span><span>@code</span><span> true} (as specified by {</span><span>@link</span><span> Collection#add})
</span><span> 6</span> <span> * </span><span>@since</span><span> 1.2
</span><span> 7</span> <span>*/</span>
<span> 8</span> <span>public</span> <span>synchronized</span> <span>boolean</span><span> add(E e) {
</span><span> 9</span> modCount++<span>;
</span><span>10</span> ensureCapacityHelper(elementCount + 1<span>);
</span><span>11</span> elementData[elementCount++] =<span> e;
</span><span>12</span> <span>return</span> <span>true</span><span>;
</span><span>13</span> }
<span>synchronized 这玩意就是多线程安全的时候用的,防止多个线程同事操作</span><br /><br /><span>关键是 ensureCapacityHelper 这个函数<br /><br /></span>
<span> 1</span> <span>/**</span>
<span> 2</span> <span> * This implements the unsynchronized semantics of ensureCapacity.
</span><span> 3</span> <span> * Synchronized methods in this class can internally call this
</span><span> 4</span> <span> * method for ensuring capacity without incurring the cost of an
</span><span> 5</span> <span> * extra synchronization.
</span><span> 6</span> <span> *
</span><span> 7</span> <span> * </span><span>@see</span><span> #ensureCapacity(int)
</span><span> 8</span> <span>*/</span>
<span> 9</span> <span>private</span> <span>void</span> ensureCapacityHelper(<span>int</span><span> minCapacity) {
</span><span>10</span> <span>int</span> oldCapacity =<span> elementData.length;
</span><span>11</span> <span>if</span> (minCapacity ><span> oldCapacity) {
</span><span>12</span> Object[] oldData =<span> elementData;
</span><span>13</span> <span>int</span> newCapacity = (capacityIncrement > 0) ?
<span>14</span> (oldCapacity + capacityIncrement) : (oldCapacity * 2<span>);
</span><span>15</span> <span>if</span> (newCapacity <<span> minCapacity) {
</span><span>16</span> newCapacity =<span> minCapacity;
</span><span>17</span> <span> }
</span><span>18</span> elementData =<span> Arrays.copyOf(elementData, newCapacity);
</span><span>19</span> <span> }
</span><span>20</span> }
<span><br />可以这么理解吧,上面这段代码就是看看数组满了没有,如果满了就动态的增加,还记得我们上面说的那个参数吗,就是可以理解为扩展因子,如果没有定义的话就double增加,就是这么简单,貌似跟c语言的动态数组好像啊<br /><br />总结一下<br /><br />上面我们学到的知识点<br /><br /></span>
1. synchronized 同步用的,相当于一个锁吧
<span><br />2. Arrays.copyOf 这函数是从一个数组复制到一个新数组里面,新数组容量可以自己定义<br /><br />3. java 的构造函数可以支持多个,前提你每个构造函数的参数都不同<br /><br />4. vector 这东西跟数组没什么区别,只不过它比静态数组可以自动扩展罢了<br />今天就到这里吧</span>
<span><br /><br /></span>
<span><br /><br /></span>
Heiße KI -Werkzeuge
Undress AI Tool
Ausziehbilder kostenlos
AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.
Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos
Stock Market GPT
KI-gestützte Anlageforschung für intelligentere Entscheidungen
Heißer Artikel
Beliebtes Werkzeug
Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor
SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen
Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung
Dreamweaver CS6
Visuelle Webentwicklungstools
SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)
Löschen Sie den Vektor in Java mit der Methode „removeAllElements()' der Klasse „Vector'.
Jul 24, 2023 am 11:45 AM
Verwenden Sie die Methode „removeAllElements()“ der Vector-Klasse, um den Vektor in Java zu löschen. In der Java-Programmierung ist die Vector-Klasse eine dynamische Array-Klasse, die Elemente am Ende des Arrays hinzufügen und dessen Größe automatisch ändern kann. Wenn wir die Vector-Klasse verwenden, um eine große Datenmenge zu speichern, müssen wir manchmal alle Elemente im Vektor löschen. In diesem Fall können wir die Methode „removeAllElements()“ der Klasse „Vector“ verwenden, um den Löschvorgang zu implementieren. Vektor
Deal | Der Gaming-Laptop MSI Vector GP68HX mit RTX 4090 und 32 GB RAM ist heute 600 US-Dollar günstiger
Jun 13, 2024 pm 06:00 PM
Aufgrund der jüngsten Preissenkungen sind die Zeiten, in denen High-End-Gamer mehr als 3.000 US-Dollar für einen Laptop mit RTX 4090 zahlen mussten, glücklicherweise vorbei. Mehrere Geräte haben diese wichtige Preisschwelle bereits unterschritten, und der MSIVector GP68HX rückt nun ebenfalls näher
C -Vektor der Saiten Beispiel
Aug 21, 2025 am 04:02 AM
Die grundlegende Nutzung von std :: vector umfasst: 1. Declare Vector; 2. Fügen Sie Elemente mit push_back () hinzu; 3.. Initialisieren Sie mit der Initialisierungsliste; 4. Schleifenquelle mit Reichweite für; 5. Zugriffselemente über Index oder zurück (); 6. Direkte Zuordnung von Werten zur Änderung von Elementen; 7. Löschen Sie die Endelemente mit pop_back (); 8. Anrufgröße (), um die Anzahl der Elemente zu erhalten; Es wird empfohlen, Constauto zu verwenden und zu vermeiden, dass das Kopieren vorhanden ist, Reserve () vor dem Allocal () zur Verbesserung der Leistung und zur Beachtung der Überprüfung achten, ob es vor dem Zugriff nicht leer ist. Diese Datenstruktur ist eine effiziente und bevorzugte Methode, um String -Listen zu verarbeiten.
So verwenden Sie die Löschfunktion von Vector in C
Feb 18, 2024 am 11:29 AM
Für die Entfernung der Verwendung von Vektoren in C sind bestimmte Codebeispiele erforderlich: Vektoren sind in der C-Sprache ein dynamisches Array, dessen Größe zur Laufzeit angepasst werden kann. Es handelt sich um eine sehr häufig verwendete Datenstruktur zum Speichern und Bearbeiten mehrerer Objekte. In praktischen Anwendungen müssen wir häufig neue Elemente in Vektoren einfügen oder vorhandene Elemente löschen. In diesem Artikel wird die Verwendung von Vector Remove in der C-Sprache ausführlich vorgestellt und entsprechende Codebeispiele gegeben. Prototyp der Entfernungsfunktion des Vektors: v
C Vektor Erhalten Sie das erste Element
Jul 25, 2025 am 12:35 AM
Es gibt vier gängige Methoden, um das erste Element von STD :: Vektor zu erhalten: 1. Verwenden Sie die Front () -Methode, um sicherzustellen, dass der Vektor nicht leer ist, klare Semantik hat und für den täglichen Gebrauch empfohlen wird. 2. Verwenden Sie das Index [0], und es muss auch leer beurteilt werden, wobei die Leistung mit vorne () vergleichbar ist, aber etwas schwächerer Semantik; 3.. Verwenden Sie *begin (), das für generische Programmier- und STL -Algorithmen geeignet ist; V. Die beste Praxis besteht darin, zuerst leer () anzurufen, um zu überprüfen, ob es leer ist, und dann mit der vorderen () -Methode das erste Element zu erhalten, um undefiniertes Verhalten zu vermeiden.
C löschen vom Vektor während der Iteration
Aug 05, 2025 am 09:16 AM
Wenn es beim Löschen eines Elements iteriert wird, müssen Sie vermeiden, einen fehlgeschlagenen Iterator zu verwenden. ①Die korrekt ist es, es zu verwenden. ② Die empfohlene "Erase-Remove" -Diom für die Stapeldeletion: vec.erase (std :: remove_if (vec.begin (), vec.end (), Zustand), vec.end ()), die sicher und effizient ist; ③ Sie können mit einem umgekehrten Iterator von hinten nach vorne löschen. Die Logik ist klar, aber Sie müssen auf die Bedingungsrichtung achten. Schlussfolgerung: Aktualisieren Sie den Iterator immer mit dem Return -Wert der Löschrückgabe und verbieten die Vorgänge auf dem fehlgeschlagenen Iterator, ansonsten werden undefiniertes Verhalten entstehen.
C finden Sie im Vektorbeispiel
Aug 02, 2025 am 08:40 AM
Die häufigste Methode, um Vektorelemente in C zu finden, besteht darin, STD :: Find zu verwenden. 1. Verwenden Sie STD :: Finden Sie, um mit dem Iteratorbereich und dem Zielwert zu suchen. Durch den Vergleich, ob der zurückgegebene Iterator gleich End () ist, können wir beurteilen, ob er gefunden wird. 2. Für benutzerdefinierte Typen oder komplexe Bedingungen sollte std :: find_if verwendet werden und Prädikatfunktionen oder Lambda -Ausdrücke sollten übergeben werden. 3. Bei der Suche nach Standardtypen wie Zeichenfolgen können Sie die Zielzeichenfolge direkt übergeben. 4. Die Komplexität jeder Suche ist O (n), die für kleine Daten geeignet ist. Für häufige Suchanfragen sollten Sie in Betracht ziehen, std :: set oder std :: unconded_set zu verwenden. Diese Methode ist einfach, effektiv und weit verbreitet für verschiedene Suchszenarien.
So füllen Sie einen Vektor mit einem Wert c
Sep 02, 2025 am 07:10 AM
UsetheConstructorstd :: VectorVec (n, val) tofillavecturingingInitialization withnelements ofValueval.2.Usestd :: fill (vec.begin (), vec.end (), val) zuverwriteAllelementsofanalready-SizeVector-TorePector-TorePectaTePeconten.





