java集合之Vector向量基础
Vector向量:
vector类似动态数组,向量和数组类似,但是数组容量一旦确定不可更改,而向量的容量可变。向量只可以保存任何类型对象且容量不限制,数组对元素类型无限制但是容量有限。
适用场合:向量适用频繁增删元素且元素数组不确定情况、元素都是对象、
数组适合对象数目确定、基础数据类型的元素。
构造方法:
public Vector();
public Vector(int initialCapacity);指定初始容量,超过容量系统自动增加一倍
public Vector(int initialCapacity,int CapacityIncrement);指定初始容量和增长增量,CapacityIncrement为0是默认自动增加一倍(向量的自动增长多于所需内存空间的)
public Vector(Collection<? extends E> c);指定集合构造vector
属性:
protected int capacityIncrement 向量的增量
protected int elementCount 向量的元素个数
protected Object elementData[] 向量成员的缓冲区
常用方法:
void addElement(Object obj);添加到尾部,容量增1
int capacity()返回向量容量
boolean contains(Object obj)判断向量是否包含指定元素
void copyInfo(Object Array[])将向量复制到数组
synchronized Object elementAt(int index)返回指定位置元素,下标非法时抛出ArrayIndexOutOfBoundsException异常
void ensureCapacity(int size)设置向量最小容量为size
synchronized Object firstElement()返回第一个元素,向量为空时抛出NoSuchElementException异常
int indexOf(Object element)返回元素下标,不存在时返回-1
int indexOf(Object element,int start)指定位置开始搜索元素,返回下标值,不存在时返回-1
void insertElementAt(Object obj,int index)指定位置插入,此位置后的内容往后移动1
boolean isEmpty()判断向量是否为空
synchronized Object lastElement()返回向量的最后一个元素,向量为空时抛出NoSuchElementException
int lastIndexOf(Object element)从向量尾开始搜索,返回元素下标
int lastIndexOf(Object element,int start)从指定位置开始向前搜索,返回元素下标
boolean removeElement(Object obj)删除指定元素,若有多个只删除第一个
void removeAllElements()删除所有,容量变为0
void removeElementAt(int index)删除指定位置元素
void setElementAt(Object obj,int index)替换指定位置内容
void setSize(int size)将向量长度设置为size,新长度小于原长度则元素丢失,大于原长度,则自动置为null
int size()返回向量中元素个数
String toString()向量转换为字符串
示例:
package test;
import java.util.Arrays;
import java.util.*;
public class VectorTest {
public static void main(String[] args) {
Vector<String> vector = new Vector<String>();
vector.add("vector1");
vector.addElement("vector2");
vector.add("向量3");
vector.addElement("向量4");
vector.insertElementAt("向量5插入", 2);
System.out.println("1-向量:"+vector);
vector.setElementAt("向量替换1", 1);
System.out.println("2-向量:"+vector+vector.size());
System.out.println("3-向量:"+vector.lastElement());
System.out.println("4-向量:"+vector.lastIndexOf("vector1"));
//不存在元素vector2
if(vector.indexOf("vector2")==-1){
System.out.println("5-向量:"+vector.indexOf("vector2"));
}
System.out.println("6-向量:"+vector.contains("向量4"));
String[] arr= new String[5];
//向量复制到数组
vector.copyInto(arr);
System.out.println("7-数组打印:"+Arrays.toString(arr));
vector.removeAllElements();
System.out.println("8-向量:"+vector.isEmpty());
vector = new Vector<String>(Arrays.asList(arr));
System.out.println("9-向量:"+vector);
System.out.println("10-向量toString打印:"+vector.toString());
for(String vec : vector){
System.out.println(vec);
}
}
}
java集合之Vector向量基础的更多相关文章
- Java基础系列 - JAVA集合ArrayList,Vector,HashMap,HashTable等使用
package com.test4; import java.util.*; /** * JAVA集合ArrayList,Vector,HashMap,HashTable等使用 */ public c ...
- java集合之vector容器
学完ArrayList和LinkedList之后,我们接着学习Vector.第1部分 Vector介绍第2部分 Vector数据结构第3部分 Vector源码解析(基于JDK1.6.0_45)第4部分 ...
- Java集合之Vector
Vector是矢量队列,它继承了AbstractList,实现了List. RandomAccess, Cloneable, java.io.Serializable接口. Vector接口依赖图: ...
- java集合之ArrayList链表基础
ArrayList可变数组 : arrayList继承AbstractList抽象类,实现list接口,底层基于数组实现.可存放null,除了非同步的之外,大致等同Vector.适用快速访问,复制.序 ...
- Java集合之Vector源码分析
概述 Vector与ArrayLIst类似, 内部同样维护一个数组, Vector是线程安全的. 方法与ArrayList大体一致, 只是加上 synchronized 关键字, 保证线程安全, 下面 ...
- java集合之Stack栈基础
Stack堆栈: 是后进先出(LIFO)的对象堆栈,继承Vector—AbstractList--AbstractCollection类,底层是通过数组实现, boolean empty() 判断堆栈 ...
- java 集合(Vector)不做重点
Vector: 底层也是维护了一个Object数组,实现与ArrayList是一样的, 但其线程是安全的,效率低.除了比较老的系统,是不会用到的. 笔试题:ArrayList 和 Vector 的区别 ...
- java集合之linkedList链表基础
LinkedList链表: List接口的链接列表实现.允许存储所有元素(包含null).使用频繁增删元素. linkedList方法: void addFirst(E e) 指定元素插入列表的开头 ...
- Java集合详解1:一文读懂ArrayList,Vector与Stack使用方法和实现原理
本文非常详尽地介绍了Java中的三个集合类 ArrayList,Vector与Stack <Java集合详解系列>是我在完成夯实Java基础篇的系列博客后准备开始写的新系列. 这些文章将整 ...
随机推荐
- eos bp节点 超级节点搭建
搭建eos BP节点 环境搭建与配置 安装最新版本 $ wget https://github.com/eosio/eos/releases/download/v1.8.1/eosio-1 ...
- Linux 笔记 - 第十章 Shell 基础知识
博客地址:http://www.moonxy.com 一.前言 Shell 是系统的用户界面,提供了用户与内核进行交互操作的一种接口,它接收用户输入的命令并把它送入内核去执行.实际上 Shell 是一 ...
- [Boost库] noncopyable——禁止拷贝的类
1.noncopyable允许程序轻松地实现一个禁止拷贝的类,在头文件<boost/noncopyable.hpp>中 2.实现原理很简单:noncopyable的实现就是用了C++中 ...
- Spring框架学习笔记(2)——面向切面编程AOP
介绍 概念 面向切面编程AOP与面向对象编程OOP有所不同,AOP不是对OOP的替换,而是对OOP的一种补充,AOP增强了OOP. 假设我们有几个业务代码,都调用了某个方法,按照OOP的思想,我们就会 ...
- 基于windows的Redis后台服务安装卸载管理
首先,需要你进入你的Redis解压根目录,例如,类似于我下图的这样子: 接着打开你的cmd,使用cd命令切换到该目录,或者直接在上图的地址栏输入“cmd”并回车.这里为什么让你先使用资源管理器找到你的 ...
- 将CDH中的hive和hbase相互整合使用
一..hbase与hive的兼容版本: hive0.90与hbase0.92是兼容的,早期的hive版本与hbase0.89/0.90兼容,不需要自己编译. hive1.x与hbase0.98.x或则 ...
- Linux 中文打字软件 gtypist 光标错位解决
在windows 下有 金山打字和其他的跟打软件,在Linux下找到了 gtypist 为练习中文打字,该软件分为练习模式的速度测试模式,在gtypist-2.9.5版中会出现以下几个问题: 一是在练 ...
- 【爬虫小程序:爬取斗鱼所有房间信息】Xpath(多线程版)
# 本程序亲测有效,用于理解爬虫相关的基础知识,不足之处希望大家批评指正 from queue import Queue import requests from lxml import etree ...
- 学 Java 网络爬虫,需要哪些基础知识?
说起网络爬虫,大家想起的估计都是 Python ,诚然爬虫已经是 Python 的代名词之一,相比 Java 来说就要逊色不少.有不少人都不知道 Java 可以做网络爬虫,其实 Java 也能做网络爬 ...
- 03-css的继承性和层叠性
一.继承性 css中所谓的继承,就是子集继承父级的属性. 可以继承的属性:color.font-xxx.text-xxx.line-xxx.(主要是文本级的标签元素) 但是,像一些盒子元素属性,定位的 ...