黑马程序员技术交流社区

标题: 自定义容器 [打印本页]

作者: 微笑的背后3    时间: 2015-9-5 00:12
标题: 自定义容器
class MyContainer
{
        /**实际存放数据的容器*/
        private int[] value = new int[16];
        /**索引/数组的长度*/
        private int index = 0;


        public void add(int val){
                if(index == value.length){
                        int[] temp = new int[value.length*2];
                        for(int i=0; i<value.length; i++){
                                temp[i] = value[i];
                        }
                       
                        value = temp;

                }

                value[index++] = val;
        }

        public int get(int index){
                return value[index];
        }

        public int size(){
                return index;
        }


        public void remove(int index){
                boolean flag = false;//标记if语句是否执行

                for(int i=0; i<value.length; i++){
                        //把下一位替换当前位置
                        if(i>=index && i<this.index-1){
                                value[i] = value[i+1];
                                flag = true;
                        }


                        //当前索引 == 数组的长度-1,如果我删除的是最后一个元素
                        if(index == this.index-1){
                                flag = true;
                        }
                       
                }

                if(flag){
                        this.index--;
                }
               
        }


        public static void main(String[] args){
                MyContainer c = new MyContainer();
               
                //add
                for(int i=0; i<20; i++){
                        c.add(i);

                }
                c.remove(c.size()-1);


               

                for(int i=0; i<c.size(); i++){
                        System.out.println(c.get(i));
                }

                //System.out.println(c.size());
        }


}




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2