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>

PHP主要是過程式編程,但也支持面向對象編程(OOP);Python支持多種範式,包括OOP、函數式和過程式編程。 PHP適合web開發,Python適用於多種應用,如數據分析和機器學習。

PHP起源於1994年,由RasmusLerdorf開發,最初用於跟踪網站訪問者,逐漸演變為服務器端腳本語言,廣泛應用於網頁開發。 Python由GuidovanRossum於1980年代末開發,1991年首次發布,強調代碼可讀性和簡潔性,適用於科學計算、數據分析等領域。

PHP適合網頁開發和快速原型開發,Python適用於數據科學和機器學習。 1.PHP用於動態網頁開發,語法簡單,適合快速開發。 2.Python語法簡潔,適用於多領域,庫生態系統強大。

PHP在現代化進程中仍然重要,因為它支持大量網站和應用,並通過框架適應開發需求。 1.PHP7提升了性能並引入了新功能。 2.現代框架如Laravel、Symfony和CodeIgniter簡化開發,提高代碼質量。 3.性能優化和最佳實踐進一步提升應用效率。

PHPhassignificantlyimpactedwebdevelopmentandextendsbeyondit.1)ItpowersmajorplatformslikeWordPressandexcelsindatabaseinteractions.2)PHP'sadaptabilityallowsittoscaleforlargeapplicationsusingframeworkslikeLaravel.3)Beyondweb,PHPisusedincommand-linescrip

PHP類型提示提升代碼質量和可讀性。 1)標量類型提示:自PHP7.0起,允許在函數參數中指定基本數據類型,如int、float等。 2)返回類型提示:確保函數返回值類型的一致性。 3)聯合類型提示:自PHP8.0起,允許在函數參數或返回值中指定多個類型。 4)可空類型提示:允許包含null值,處理可能返回空值的函數。

PHP中使用clone關鍵字創建對象副本,並通過\_\_clone魔法方法定制克隆行為。 1.使用clone關鍵字進行淺拷貝,克隆對象的屬性但不克隆對象屬性內的對象。 2.通過\_\_clone方法可以深拷貝嵌套對象,避免淺拷貝問題。 3.注意避免克隆中的循環引用和性能問題,優化克隆操作以提高效率。

PHP適用於Web開發和內容管理系統,Python適合數據科學、機器學習和自動化腳本。 1.PHP在構建快速、可擴展的網站和應用程序方面表現出色,常用於WordPress等CMS。 2.Python在數據科學和機器學習領域表現卓越,擁有豐富的庫如NumPy和TensorFlow。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器

記事本++7.3.1
好用且免費的程式碼編輯器

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

WebStorm Mac版
好用的JavaScript開發工具

SublimeText3 Linux新版
SublimeText3 Linux最新版