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仍然流行的原因是其易用性、灵活性和强大的生态系统。1)易用性和简单语法使其成为初学者的首选。2)与web开发紧密结合,处理HTTP请求和数据库交互出色。3)庞大的生态系统提供了丰富的工具和库。4)活跃的社区和开源性质使其适应新需求和技术趋势。

PHP和Python都是高层次的编程语言,广泛应用于Web开发、数据处理和自动化任务。1.PHP常用于构建动态网站和内容管理系统,而Python常用于构建Web框架和数据科学。2.PHP使用echo输出内容,Python使用print。3.两者都支持面向对象编程,但语法和关键字不同。4.PHP支持弱类型转换,Python则更严格。5.PHP性能优化包括使用OPcache和异步编程,Python则使用cProfile和异步编程。

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值,处理可能返回空值的函数。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SecLists
SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

PhpStorm Mac 版本
最新(2018.2.1 )专业的PHP集成开发工具

Atom编辑器mac版下载
最流行的的开源编辑器

ZendStudio 13.5.1 Mac
功能强大的PHP集成开发环境