Maison >php教程 >php手册 >java学习随笔--- 捣蛋vector,java随笔---vector

java学习随笔--- 捣蛋vector,java随笔---vector

WBOY
WBOYoriginal
2016-06-13 08:49:421207parcourir

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>

 

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn