JAVA先进-设置(1)

时间:2021-09-26 19:29:37

>Arrays

基本阵列

1.常见的数组产生于main() 函数,数组下标的索引不能超过0到int的范围

2.当程序试图訪问数组的第一个或者最后一个数据的时候,会发生ArrayIndexOutOfBoundsException异常。

(相当于链表)

3.遗憾的是,数组没有java源码。它是由Object对象组成的带有顺序的集合。

声明/初始化

1.数组的类型有基本类型。Object类型。对于数组的声明仅仅须要添加[]

2.能够是int[] test , int []test , int test[] 三种形式。

3.数组的定义必须声明个数。定义完数组通常使用循环或者一个个赋值。

原始类型/对象类型的数组

原始类型的数组维护着数据的顺序列表,而对象数据则把数据存在对象中,数组仅仅是引用了对象的地址。

多维数组

1.像数组引用对象,如果要维护多个连续的数组 这时候就须要多维数组。

2.多维数组的初始化也要指定长度。比方2维数组,第1个下标表示维护多少个数组,第2个下标表示维护

数组里面的个数。

3.多维数组的值必须由多个维度共同确定。

变量初始化:当类型数组指定个数时,内存会为数组指定内存 

并给默认的变量,一般依据类型指定,如int指定为0,double为0.0d,String为null;



为方法传递数组以及获取返回值:

当传递參数的时候,系统给方法传递的是数组的引用,因此你能够在数组改变其值.



Copying 和 Cloning 数组:

由于数组在初始化已经固定,当你想为数组扩容的时候,就必须使用复制或者克隆.

系统为Copy提供了一个工具方法,该方法提供源流的目标。開始位置和复制长度;

当数据长度不够复制时抛出ArrayIndexOutOfBoundsException

System.arraycopy(original,0, resultArray,0,original.length);

系统相同提供了拷贝方法array.clone();来实现复制。

在类型数组中,拷贝是复制值,而在对象数组中,仅仅是对对象做了一次浅拷贝;

/**
* @author Lean @date:2014-10-16
*/
public class CopyAndCloneArrays { public static void main(String[] args) throws CloneNotSupportedException {
copyingArray(); } private static void copyingArray() throws CloneNotSupportedException {
int[] array1={1,2,3,4,5};
int[] array2={1,2,3,4,5,6,7,8,9};
// System.out.println(array1.length+" "+doubleArray(array1).length);
// System.out.println(array2
// .length+" "+doubleArray(array2).length);
Book[] array3={new Book(new Price(20)),new Book(new Price(30))};
Book[] array4=doubleArray(array3);
array3[0].price.value=18;
System.out.println(array3[0].price);
System.out.println(array4[0].price); } static int[] doubleArray(int[] original){
int[] resultArray=new int[original.length*2];
System.arraycopy(original,0, resultArray,0,original.length);
return resultArray;
} static Book[] doubleBookArray(Book[] original){
Book[] resultArray=new Book[original.length*2];
System.arraycopy(original,0, resultArray,0,original.length);
return resultArray;
} static Book[] doubleArray(Book[] original){
return (Book[])original.clone();
} } class Price implements Cloneable{ public int value; public Price(int value) {
this.value = value;
} @Override
protected Object clone() throws CloneNotSupportedException {
Price obj=null;
try {
obj=(Price)super.clone();
} catch (Exception e) {
System.out.println(e.getMessage());
}
return obj; } @Override
public String toString() {
return value+"";
} } class Book implements Cloneable{ public Book(Price price) {
this.price = price;
} public Price price; @Override
protected Object clone() throws CloneNotSupportedException {
Book obj=null;
try {
obj=(Book)super.clone();
} catch (Exception e) {
System.out.println(e.getMessage());
}
obj.price=(Price) price.clone();
return obj;
}
}

数组引用和相等的推断:

>当一个变量引用一个数组,比方a引用arrray1,那么把a赋值给变量b,b相同引用array1. 

>当两个对象同一时候引用一个数组,那么推断他们能够使用a==b;当两个对象通过

克隆复制得到一个数组,那么他们引用不同内存地址,仅仅能使用equals();



数组与字符串:

在C中,总是把char[]数组来表示string,而在Java中,数组跟字符串是能够互转的

string1.toByteArray()把字符串转化成数组。

new String(byte[])能够建立字符串;

数组反射:

/**
* @author Lean @date:2014-10-16
*/
public class ArrayReflection { public static void main(String[] args) {
// checkArray();
// 定义数组
// reflectNewInstance();
// 存取值
// tryGetSet();
} private static void tryGetSet() {
int[] data={1,2,3,4};
Array.setInt(data,2, 12);
Array.setInt(data,4, 12);
System.out.println(Array.get(data, 2));
} private static void reflectNewInstance() {
float[][] bowling=(float[][]) Array.newInstance(float[].class,4);
for (int i = 0; i < bowling.length; i++) {
bowling[i]=(float[]) Array.newInstance(Float.TYPE, i+1);
}
System.out.println(bowling[2].length);
} private static void checkArray() {
final int[] a={1,2,3};
Class objClass=a.getClass();
if (objClass.isArray()) {
Class componentClass=objClass.getComponentType();
System.out.println(componentClass.getName());
System.out.println(Array.getLength(a));
}
} }

>The Vector Classes

----Vector----

1.创建Vector能够指定初始容量和增幅,也能够把包装还有一个List,如:

Vector v=new Victor(Arrays.asList(array));

2.Vector遵循队列的标准

能够同过add(obj)/addElement()加入到队列末尾,

能够通过索引add(index,obj)/insertElement(obj,index)加入索引所在的位置

也能够将一个Collection队列所有加入到末尾addAll(list);

3.由于该Vector不能加入原始类型,在新版本号的jdk中,系统会为我们自己主动装箱;打印

Vector使用toString();

4.删除Vector能够

通过引用删除remove(obj)/removeElementAt(index);

通过索引删除remove(index)/removeElementAt(index);

通过删除部分removeAll(list)/removeRange(from,to);

所有删除clear()/removeAllElement();

保留Collection所选 删除其它 retainAll(list)

5.替换set(index,obj)/setElement(obj,index)

6.查看/设置队列大小 size()/setSize()

7.存储容量:容量是用来应对动态队列的频繁增减;假使队列容量太小,就应该在添加

队列之前使用ensureCapacity(int minCapacity)先扩容;如果容量不够 一般

添加1倍的容量;与size()不同,size代表当前的个数。容量代表能放多少。当

对队列操作完成。你能够调用trimToSize()来优化降低空间。

8.Vector的不变性:

如果有一个变量仅做阅读,为防止变化Collections提供了unmodifiableList(v);

9.对元素进行枚举

public Enumeration elements()。

while (e.hasMoreElements()) {

process(e.nextElement());

}

扩展AbstractList

Iterator i = v.iterator();

while (i.hasNext()) {

process(e.next());

}

10.多维Vector的迭代取值:

MyType o = (MyType)((Vector)vector.elementAt(3)).elementAt(2);



11.检验Vector元素:

推断存在:contains(obj)/containsAll(list);

索引:indexOf(obj)假设存在2个 得到的是顺序的第1个的索引

反向索引:lastIndexOf(obj)如上反向

12.Copy和clone

调用clone()直接复制或者copyInto(array)先转换成数组再间接复制



13.截取Vector.

public List subList(int fromIndex, int toIndex)

14.使用equals()推断Vector内容是否相等;

版权声明:本文博客原创文章,博客,未经同意,不得转载。