자바 에서 AyyarList 류 의 기본 실현
2351 단어 자바 노트
LinkedList:링크 를 바탕 으로 이 루어 지고 스 레 드 가 안전 하지 않 으 며 효율 이 높 습 니 다.그래서 조회 가 느 리 고 삽입,삭제 가 빠르다.
Vector:배열 기반 구현.스 레 드 는 안전 하고 효율 이 낮다.다 중 스 레 드 상황 에서 만 Vector 를 사용 합 니 다.
/**
* ArrayList, ArrayList
* @author Administrator
*
*/
public class MyArrayList {
private Object[] elementData;
private int size;
public MyArrayList(){
this(10); // 10
}
public MyArrayList(int initialCapacity){
if(initialCapacity<0)
try {
throw new Exception();
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
elementData = new Object[initialCapacity];
}
public int size(){
return size;
}
public void ensureCapacity(){
// ,
if(size==elementData.length){
Object[] newArray = new Object[size*2];
System.arraycopy(elementData, 0, newArray, 0, elementData.length);
elementData = newArray;
}
}
public void add(Object o){
ensureCapacity();
elementData[size]=o;
size++;
}
public void add(int index, Object obj){
rangeCheck(index);
ensureCapacity();
for(int i=size-1;i>=index;i--){
elementData[i+1]=elementData[i];
}
elementData[index]=obj;
size++;
}
public boolean isEmpty(){
return size==0;
}
public Object get(int index){
rangeCheck(index);
return elementData[index];
}
public Object remove(int index){
rangeCheck(index);
Object deletedObject = elementData[index];
//int numMoved = size-index-1;
//System.arraycopy(elementData, index+1, elementData, index, numMoved);
for(int i=index+1; i= size){
try {
throw new Exception();
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
public static void main(String[] args) {
// TODO Auto-generated method stub
MyArrayList list = new MyArrayList(3);
list.add(123);
list.add("haha");
list.add("wxxyy");
list.add("you");
System.out.println(list.get(3));
}
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
JAVA Blue Bridge 컵(4) Excel 주소 변환문제 설명 Excel은 가장 자주 사용하는 사무용 소프트웨어입니다.모든 칸에는 유일한 주소 표시가 있다.예를 들어 12행 4열은 "D12", 5행 255열은 "IU5"를 나타냅니다.사실 Excel은 두 가지 주소 표...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.