Java小记 Vector


概述

  • Vector类实现的是动态数组,与ArrayList类似;
  • Vector为同步访问
  • Vector可灵活改变数组大小

构造方法

方法1

  • 默认大小为10
Vector()

方法2

  • 大小为指定值size
Vector(int size)

方法3

  • 指定大小size,指定增量incr
Vector(int size, int incr)

方法4

  • 以集合c为基础创建
Vector(Collection c)

常用方法

方法返回值说明
add(int index, Object element)void在此向量的指定位置插入指定的元素。
add(Object o)boolean将指定元素添加到此向量的末尾。
addAll(Collection c)boolean将指定 Collection 中的所有元素添加到此向量的末尾,按照指定 collection 的迭代器所返回的顺序添加这些元素。
addAll(int index, Collection c)boolean在指定位置将指定 Collection 中的所有元素插入到此向量中。
addElement(Object obj)void将指定的组件添加到此向量的末尾,将其大小增加 1。
insertElementAt(Object obj, int index)void将指定对象作为此向量中的组件插入到指定的 index 处。
remove(int index)Object移除此向量中指定位置的元素。
remove(Object o)boolean移除此向量中指定元素的第一个匹配项,如果向量不包含该元素,则元素保持不变。
removeAll(Collection c)boolean从此向量中移除包含在指定 Collection 中的所有元素。
removeAllElements()void从此向量中移除全部组件,并将其大小设置为零。
removeElement(Object obj)boolean从此向量中移除变量的第一个(索引最小的)匹配项。
removeElementAt(int index)void删除指定索引处的组件。
removeRange(int fromIndex, int toIndex)protected从此 List 中移除其索引位于 fromIndex(包括)与 toIndex(不包括)之间的所有元素。
capacity()int返回此向量的当前容量。
size()int返回此向量中的组件数。
hashCode()int返回此向量的哈希码值。
clear()void从此向量中移除所有元素。
isEmpty()boolean测试此向量是否不包含组件。
lastIndexOf(Object elem)int返回此向量中最后一次出现的指定元素的索引;如果此向量不包含该元素,则返回 -1。
lastIndexOf(Object elem, int index)int返回此向量中最后一次出现的指定元素的索引,从 index 处逆向搜索,如果未找到该元素,则返回 -1。
lastElement()Object返回此向量的最后一个组件。
firstElement()Object返回此向量的第一个组件(位于索引 0) 处的项)。
elementAt(int index)Object返回指定索引处的组件。
elements()Enumeration返回此向量的组件的枚举。
indexOf(Object elem)int返回此向量中第一次出现的指定元素的索引,如果此向量不包含该元素,则返回 -1。
indexOf(Object elem, int index)int返回此向量中第一次出现的指定元素的索引,从 index 处正向搜索,如果未找到该元素,则返回 -1。
get(int index)Object返回向量中指定位置的元素。
set(int index, Object element)Object用指定的元素替换此向量中指定位置处的元素。
setSize(int newSize)void设置此向量的大小。
setElementAt(Object obj, int index)void将此向量指定 index 处的组件设置为指定的对象。
clone()Object返回向量的一个副本。
copyInto(Object[] anArray)void将此向量的组件复制到指定的数组中。
subList(int fromIndex, int toIndex)List返回此 List 的部分视图,元素范围为从 fromIndex(包括)到 toIndex(不包括)。
contains(Object elem)boolean如果此向量包含指定的元素,则返回 true。
containsAll(Collection c)boolean如果此向量包含指定 Collection 中的所有元素,则返回 true。
ensureCapacity(int minCapacity)void增加此向量的容量(如有必要),以确保其至少能够保存最小容量参数指定的组件数。
equals(Object o)boolean比较指定对象与此向量的相等性。
retainAll(Collection c)boolean在此向量中仅保留包含在指定 Collection 中的元素。
toArray()Object[]返回一个数组,包含此向量中以恰当顺序存放的所有元素。
toArray(Object[] a)Object[]返回一个数组,包含此向量中以恰当顺序存放的所有元素;返回数组的运行时类型为指定数组的类型。
toString()String返回此向量的字符串表示形式,其中包含每个元素的 String 表示形式。
trimToSize()void对此向量的容量进行微调,使其等于向量的当前大小。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Protobuf是一种高效的序列化协议,可以用于数据交换和数据存储。它的主要优势是大小小,速度快,可扩展性强。下面是使用Protobuf的一些小记: 1. 定义消息格式 首先,需要定义消息格式,以便Protobuf可以将数据序列化和反序列化。消息格式定义在.proto文件中,使用protobuf语言编写。例如,下面是一个简单的消息格式定义: ``` syntax = "proto3"; message Person { string name = 1; int32 age = 2; } ``` 这个消息格式定义了一个名为Person的消息,包含两个字段:name和age。 2. 生成代码 一旦消息格式定义好,就可以使用Protobuf编译器生成代码。编译器将根据消息格式定义生成相应的代码,包括消息类、序列化和反序列化方法等。可以使用以下命令生成代码: ``` protoc --java_out=. message.proto ``` 这将生成一个名为message.pb.javaJava类,该类包含Person消息的定义以及相关方法。 3. 序列化和反序列化 一旦生成了代码,就可以使用Protobuf序列化和反序列化数据。例如,下面是一个示例代码,将一个Person对象序列化为字节数组,并将其反序列化为另一个Person对象: ``` Person person = Person.newBuilder() .setName("Alice") .setAge(25) .build(); byte[] bytes = person.toByteArray(); Person deserializedPerson = Person.parseFrom(bytes); ``` 这个示例代码创建了一个Person对象,将其序列化为字节数组,然后将其反序列化为另一个Person对象。在这个过程中,Protobuf使用生成的代码执行序列化和反序列化操作。 以上是使用Protobuf的一些基本步骤和注意事项,希望对你有所帮助!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

薛定谔的壳

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值