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

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

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)

Heiße Themen



Alipay PHP ...

JWT ist ein offener Standard, der auf JSON basiert und zur sicheren Übertragung von Informationen zwischen Parteien verwendet wird, hauptsächlich für die Identitätsauthentifizierung und den Informationsaustausch. 1. JWT besteht aus drei Teilen: Header, Nutzlast und Signatur. 2. Das Arbeitsprinzip von JWT enthält drei Schritte: Generierung von JWT, Überprüfung von JWT und Parsingnayload. 3. Bei Verwendung von JWT zur Authentifizierung in PHP kann JWT generiert und überprüft werden, und die Funktionen und Berechtigungsinformationen der Benutzer können in die erweiterte Verwendung aufgenommen werden. 4. Häufige Fehler sind Signaturüberprüfungsfehler, Token -Ablauf und übergroße Nutzlast. Zu Debugging -Fähigkeiten gehört die Verwendung von Debugging -Tools und Protokollierung. 5. Leistungsoptimierung und Best Practices umfassen die Verwendung geeigneter Signaturalgorithmen, das Einstellen von Gültigkeitsperioden angemessen.

Die Anwendung des soliden Prinzips in der PHP -Entwicklung umfasst: 1. Prinzip der Einzelverantwortung (SRP): Jede Klasse ist nur für eine Funktion verantwortlich. 2. Open and Close Principle (OCP): Änderungen werden eher durch Erweiterung als durch Modifikation erreicht. 3.. Lischs Substitutionsprinzip (LSP): Unterklassen können Basisklassen ersetzen, ohne die Programmgenauigkeit zu beeinträchtigen. 4. Schnittstellen-Isolationsprinzip (ISP): Verwenden Sie feinkörnige Schnittstellen, um Abhängigkeiten und nicht verwendete Methoden zu vermeiden. 5. Abhängigkeitsinversionsprinzip (DIP): Hoch- und niedrige Module beruhen auf der Abstraktion und werden durch Abhängigkeitsinjektion implementiert.

So setzen Sie die Berechtigungen von Unixsocket automatisch nach dem Neustart des Systems. Jedes Mal, wenn das System neu startet, müssen wir den folgenden Befehl ausführen, um die Berechtigungen von Unixsocket: sudo ...

In Artikel wird die in PHP 5.3 eingeführte LSB -Bindung (LSB) erörtert, die die Laufzeitauflösung der statischen Methode ermöglicht, um eine flexiblere Vererbung zu erfordern. Die praktischen Anwendungen und potenziellen Perfo von LSB

Senden von JSON -Daten mithilfe der Curl -Bibliothek von PHP in der PHP -Entwicklung müssen häufig mit externen APIs interagieren. Eine der gängigen Möglichkeiten besteht darin, die Curl Library zu verwenden, um Post � ...

In Artikel werden wichtige Sicherheitsfunktionen in Frameworks erörtert, um vor Schwachstellen zu schützen, einschließlich Eingabevalidierung, Authentifizierung und regelmäßigen Aktualisierungen.

Wie debugge ich den CLI -Modus in PhpStorm? Bei der Entwicklung mit PHPSTORM müssen wir manchmal den PHP im CLI -Modus (COMS -Zeilenschnittstellen) debuggen ...
