国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發(fā)設計 > 正文

java學習隨筆---搗蛋vector

2019-11-14 13:24:37
字體:
來源:轉載
供稿:網友

 

最近比較有時間啦,有時間搞下java,個人覺得學這門語言語法太多啦,不一一去學習啦,心血來潮,掛了個struct2的源代碼,一入深似海啊,看得我天花繚亂,從最簡單的開始吧

 

 1 public static void main(String[] args) { 2          3         Vector v = new Vector(4); 4  5         //向Vector中添加元素 靜態(tài)數(shù)組+動態(tài)擴展 6         //使用add方法直接添加元素  7         v.add("Test0");  8         v.add("Test1");  9         v.add("Test0"); 10         v.add("Test2"); 11         v.add("Test2");12 13         //從Vector中刪除元素 14         v.remove("Test0"); //刪除指定內容的元素 15         v.remove(0); //按照索引號刪除元素16 17         //獲得Vector中已有元素的個數(shù) 18         int size = v.size(); 19         System.out. size);20 21         //遍歷Vector中的元素 22         for(int i = 0;i < v.size();i++){ 23         System.out.println(v.get(i)); 24         } 25 }

代碼很簡單啦,學過數(shù)據(jù)結構的都知道,簡單的新增改查啦,不過我們要深入一下了解,這玩意跟數(shù)組有什么區(qū)別

構造函數(shù)如下,意思是說你可以初始化一個容量的數(shù),多少你自己決定

 

我們接著來看,java的構造函數(shù)可真的比php強大,支持不同參數(shù)調用,換php的話早就報錯啦

 1     /** 2      * Constructs an empty vector with the specified initial capacity and 3      * capacity increment. 4      * 5      * @param   initialCapacity     the initial capacity of the vector 6      * @param   capacityIncrement   the amount by which the capacity is 7      *                              increased when the vector overflows 8      * @throws IllegalArgumentException if the specified initial capacity 9      *         is negative10      */11     public Vector(int initialCapacity, int capacityIncrement) {12     super();13         if (initialCapacity < 0)14             throw new IllegalArgumentException("Illegal Capacity: "+15                                                initialCapacity);16     this.elementData = new Object[initialCapacity];17     this.capacityIncrement = capacityIncrement;18     }

代碼是不是很簡單,簡單的初始化一個對象數(shù)組,連我一個高中生的看出來啦,注意到第二個參數(shù),這個是控制數(shù)組填滿了之后要怎么增加,可以理解為一個策略吧

我們來看看添加元素是怎樣實現(xiàn)的

 1   /** 2      * Appends the specified element to the end of this Vector. 3      * 4      * @param e element to be appended to this Vector 5      * @return {@code true} (as specified by {@link Collection#add}) 6      * @since 1.2 7      */ 8     public synchronized boolean add(E e) { 9     modCount++;10     ensureCapacityHelper(elementCount + 1);11     elementData[elementCount++] = e;12         return true;13     }
synchronized 這玩意就是多線程安全的時候用的,防止多個線程同事操作

關鍵是 ensureCapacityHelper 這個函數(shù)

 1 /** 2      * This implements the unsynchronized semantics of ensureCapacity. 3      * Synchronized methods in this class can internally call this 4      * method for ensuring capacity without incurring the cost of an 5      * extra synchronization. 6      * 7      * @see #ensureCapacity(int) 8      */ 9     private void ensureCapacityHelper(int minCapacity) {10     int oldCapacity = elementData.length;11     if (minCapacity > oldCapacity) {12         Object[] oldData = elementData;13         int newCapacity = (capacityIncrement > 0) ?14         (oldCapacity + capacityIncrement) : (oldCapacity * 2);15             if (newCapacity < minCapacity) {16         newCapacity = minCapacity;17         }18             elementData = Arrays.copyOf(elementData, newCapacity);19     }20     }

 


可以這么理解吧,上面這段代碼就是看看數(shù)組滿了沒有,如果滿了就動態(tài)的增加,還記得我們上面說的那個參數(shù)嗎,就是可以理解為擴展因子,如果沒有定義的話就double增加,就是這么簡單,貌似跟c語言的動態(tài)數(shù)組好像啊

總結一下

上面我們學到的知識點

1. synchronized  同步用的,相當于一個鎖吧

2. Arrays.copyOf 這函數(shù)是從一個數(shù)組復制到一個新數(shù)組里面,新數(shù)組容量可以自己定義

3. java 的構造函數(shù)可以支持多個,前提你每個構造函數(shù)的參數(shù)都不同

4. vector 這東西跟數(shù)組沒什么區(qū)別,只不過它比靜態(tài)數(shù)組可以自動擴展罷了
今天就到這里吧




 


發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 翁牛特旗| 合山市| 井研县| 滦平县| 宁化县| 云林县| 平阳县| 丰顺县| 广昌县| 商都县| 雷山县| 五指山市| 新郑市| 曲阜市| 武宁县| 桃源县| 湘西| 江城| 永顺县| 达日县| 纳雍县| 寻甸| 商河县| 湖南省| 安新县| 汝州市| 安康市| 新龙县| 蓬安县| 武功县| 葫芦岛市| 泰宁县| 甘南县| 古田县| 扶沟县| 丹阳市| 安龙县| 宁河县| 东山县| 易门县| 双柏县|