Java设计模式_Iterator(迭代容器)
来源:互联网 发布:ubuntu安装万能五笔 编辑:程序博客网 时间:2024/05/29 18:37
方法一:
采用ArrayList类实现.
/**
* 此数组类可动态扩展(方法一)
* @author tfq
*
*/
public class ArrayList {
Object[] objects=new Object[10];
int index=0;
/**
* 父类引用指向子类对象
* @param o
*/
public void add(Object o){
if(index==objects.length){
Object[] newObjects=new Object[objects.length*2];
System.arraycopy(objects, 0, newObjects, 0, objects.length);
objects=newObjects;
}
objects[index]=o;
index++;
}
/**
* 获取数组的长度
* @return
*/
public int size(){
return index;
}
}
/*
*
*辅助类
/
public class Dog {
private int id;
public Dog(int id){
super();
this.id=id;
}
}
public class Test {
public static void main(String[] args) {
ArrayList arr=new ArrayList();
for(int i=0;i<1000;i++){
arr.add((Object)new Dog(10));
}
System.out.println(arr.size());
}
}
打印出数组的长度:1000
方法二:
采用动态链表方式
public class LinkedList {
Node head=null;
Node tail=null;
int index=0;
public void add(Object o){
Node n=new Node(o,null);
if(head==null){
head=n;
tail=n;
}
tail.setNext(n);
tail=n;
index++;
}
public int size(){
return index;
}
}
///结点类
public class Node {
private Object data;
private Node next;
public Node(Object data, Node next) {
super();
this.data = data;
this.next = next;
}
public Object getData() {
return data;
}
public void setData(Object data) {
this.data = data;
}
public Node getNext() {
return next;
}
public void setNext(Node next) {
this.next = next;
}
}
public class Test {
public static void main(String[] args) {
LinkedList lkl=new LinkedList();
for(int i=0;i<1000;i++){
lkl.add((Object)new Dog(10));
}
System.out.println(lkl.size());
}
}
打印采用链表方式生成的Iterator长度:1000
- Java设计模式_Iterator(迭代容器)
- java设计模式_iterator
- java设计模式进阶_iterator
- 《Java设计模式》之迭代模式
- java设计模式_迭代模式
- JAVA设计模式(十六)----迭代模式
- 设计模式--行为模式--迭代模式--Java
- 设计模式——迭代器模式_Iterator Pattern
- Java设计模式之二十(迭代模式)
- JAVA设计模式(十八)——迭代模式
- Java设计模式_(行为型)_迭代模式
- Java 类集 _Iterator 接口
- Java基础_Iterator
- java设计模式--AOP容器
- 设计模式之Iterator迭代模式
- 设计模式——迭代模式
- (1) 设计模式笔记[迭代模式]
- iterator设计模式(迭代模式)
- iexplore.exe 应用程序错误 该内存不能为"read"
- Java链表
- The selected server is enabled 解决办法
- [USACO 2011Jan Gold]道路与航线
- 离别
- Java设计模式_Iterator(迭代容器)
- register_chrdev_region函数源码分析
- oracle 递归查询 start with connect by prior
- NSUInteger 和 NSInteger 区别和联系
- 在listview的前面或后面添加布局控件
- libgdx-demos
- 我也实现全C++的IE容器了
- 如何修改Linux系统的文件权限
- Linux移植之驱动编译出现的问题