亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

數組(二):ArrayList的實現和Arrays類的使用

2019-11-10 17:59:01
字體:
來源:轉載
供稿:網友

一、數組是否可以變長?

我們都知道,數組時定長的,初始化時一定要給定長度,由于這個長度的問題,我們在實際的開發中,會更傾向于使用容器,如ArrayList等,使用容器類時,無需考慮長度問題,因為容器已經幫我們處理了,那么數組就沒有辦法變長了嗎?當然不是,ArrayList就是基于數組實現的,我們可以看看ArrayList是如何處理的

二、ArrayList的實現原理

ArrayList用一個Object數組作為其內部操作,并有一個成員變量size代表容器的長度

PRivate transient Object[] elementData; private int size;

添加數據時,調用add()方法:

public boolean add(E e) { ensureCapacityInternal(size + 1); // Increments modCount!! elementData[size++] = e; return true; }

調用add時,首先調用ensureCapacityInternal方法,該方法的目的是擴容,將數組的長度增加1

private void ensureCapacityInternal(int minCapacity) { modCount++; // overflow-conscious code if (minCapacity - elementData.length > 0) grow(minCapacity);}

而在ensureCapacityInternal中,首先判斷擴容是否有溢出問題,沒有溢出問題,就調用grow,進行擴容

private void grow(int minCapacity) { // 溢出處理 int oldCapacity = elementData.length; int newCapacity = oldCapacity + (oldCapacity >> 1); if (newCapacity - minCapacity < 0) newCapacity = minCapacity; if (newCapacity - MAX_ARRAY_SIZE > 0) newCapacity = hugeCapacity(minCapacity); // 擴容處理 elementData = Arrays.copyOf(elementData, newCapacity); }

這是擴容的核心代碼,前面代碼都是溢出處理,關鍵在于最后一句

elementData = Arrays.copyOf(elementData, newCapacity)

API文檔的解釋是:復制指定的數組,截取或用 null 或 0 填充(如有必要),以使副本具有指定的長度

也就是說,通過Arrays.copyOf,將數組elementData的長度擴大到newCapacity,擴大的部分填充由數組類型決定

例如:

int[] a = new int[]{1,2}; System.out.println("擴容前長度:" + a.length); a = Arrays.copyOf(a, 3); System.out.println("擴容后長度:" + a.length); System.out.println("填充的數據:" + a[2]);

輸出: 擴容前長度:2 擴容后長度:3 填充的數據:0

三、Arrays類的使用

Arrays類包含用來操作數組(比如排序和搜索)的各種方法,這個類是必須熟練使用的! 該類的常用方法有:

方法 解釋
asList(T… a) 返回一個受指定數組支持的固定大小的列表
copyOf(int[] original,int newLength) 復制指定的數組,填充的數據由數組類型決定,以使副本具有指定的長度
copyOfRange(long[] original, int from, int to) 將指定數組的指定范圍復制到一個新數組
equals(int[] a, int[] a2) 如果兩個指定的 int 型數組彼此相等,則返回 true
fill(int[] a, int val) 將指定的 int 值分配給指定 int 型數組的每個元素
sort(int[] a) 對指定的 int 型數組按數字升序進行排序
以上只用int類型數組做為example,同理其他類型數組同樣的操作

四、數組的淺拷貝,copyOf的問題

當數組類型不是基本數據類型時,數組內存放的是對象的引用,因此在copyOf復制對象數組時,千萬要注意,復制的對象的引用而不是對象本身!

class Person{ int age; public int getAge() { return age; } public void setAge(int age) { this.age = age; }}public class Array2 { public static void main(String[] args) { Person p = new Person(); p.setAge(20); Person[] a = new Person[]{p}; Person[] b = Arrays.copyOf(a, a.length); a[0].setAge(30); System.out.println("a的年齡:" + a[0].getAge()); System.out.println("b的年齡:" + b[0].getAge()); }}

輸出: a的年齡:30 b的年齡:30

可以看見,a改變其值后,連b的值都改變了,這就是淺拷貝問題

有關于深淺拷貝的博文,參考: 漸析java的淺拷貝和深拷貝:http://www.cnblogs.com/chenssy/p/3308489.html。


上一篇:demo

下一篇:valgrind的使用

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久久久久亚洲| 亚洲最大av网站| 国产精品爽黄69| 欧美日韩高清在线观看| 91精品国产综合久久久久久蜜臀| 91国产在线精品| 国自产精品手机在线观看视频| 国产亚洲精品久久久久久| 中文字幕av一区中文字幕天堂| 成人国产精品久久久| 日韩欧美中文免费| 欧美激情xxxxx| 色播久久人人爽人人爽人人片视av| 国产精品久久久久久一区二区| 久久影视电视剧免费网站清宫辞电视| 欧美一区二三区| 欧美黄色性视频| 亚洲美女又黄又爽在线观看| 伊人久久久久久久久久久久久| 亚洲欧洲成视频免费观看| 色偷偷亚洲男人天堂| 日韩成人在线免费观看| 国产精品国内视频| 成人av资源在线播放| 国产欧美韩国高清| 亚洲国产精品电影在线观看| 成人av在线亚洲| 欧美高清在线播放| 国产一区二中文字幕在线看| 亚洲女人被黑人巨大进入| 欧美劲爆第一页| 国产精品视频99| 国产亚洲成av人片在线观看桃| 在线电影欧美日韩一区二区私密| 亚洲福利在线播放| 亚洲深夜福利视频| 久久久久久久久久婷婷| 日韩在线视频线视频免费网站| 国产精品视频免费在线观看| 久久天天躁狠狠躁夜夜躁2014| 韩国日本不卡在线| 欧美精品在线免费| 欧美刺激性大交免费视频| 亚洲美女自拍视频| 精品成人在线视频| 国产精品第七影院| 中文字幕亚洲色图| 亚州成人av在线| 国产精品自拍网| 亚洲精品午夜精品| 欧美激情视频在线免费观看 欧美视频免费一| 欧美插天视频在线播放| 色婷婷综合久久久久| 欧美日韩一区二区三区| 国产自产女人91一区在线观看| 性欧美亚洲xxxx乳在线观看| 日韩的一区二区| 中文字幕日韩综合av| 国产精品av在线| 亚洲aaa激情| 国产精品自产拍高潮在线观看| 久久精品夜夜夜夜夜久久| 国产成人精品999| 国产午夜精品一区二区三区| 欧美高清自拍一区| 日韩av在线免费播放| 日本亚洲欧美三级| 91成人精品网站| 欧美日韩激情小视频| 亚洲电影免费观看高清| 欧美激情精品久久久久久蜜臀| 91精品久久久久久久久中文字幕| 日韩av在线网页| 欧美日韩一区二区三区| 日韩成人久久久| 亚洲国产成人久久综合| 久久久久久久久爱| 在线播放国产一区二区三区| 操日韩av在线电影| 国a精品视频大全| 国产精品日韩专区| 欧美裸体xxxxx| 日韩精品免费在线播放| 国产精品久久久久久av下载红粉| 久久av.com| 91国偷自产一区二区三区的观看方式| 性欧美在线看片a免费观看| 亚洲国产另类 国产精品国产免费| 2021国产精品视频| 亚洲午夜国产成人av电影男同| 精品欧美国产一区二区三区| 国产成人一区二区在线| 亚洲一区二区三区在线免费观看| 国产精品网址在线| 福利一区福利二区微拍刺激| 欧美日韩国产精品一区二区不卡中文| 亚洲国产欧美一区二区丝袜黑人| 日韩av三级在线观看| 成人精品久久av网站| 亚洲一区二区久久久久久| 亚洲在线免费观看| 亚洲乱码一区二区| 中文字幕久久精品| 欧美黄色三级网站| 91香蕉国产在线观看| 国产精品免费小视频| 国产精品免费一区二区三区都可以| 国产视频精品免费播放| 国产在线播放不卡| 国产精品视频成人| 亚洲国产精品久久久久| 久久久久久久久久久成人| 欧美极品少妇xxxxⅹ免费视频| 日韩免费av在线| 久久综合国产精品台湾中文娱乐网| 亚洲欧美色图片| 中文字幕亚洲一区在线观看| 丰满岳妇乱一区二区三区| 欧美另类xxx| 日日骚av一区| 国产一区二区三区在线视频| 3344国产精品免费看| 国内精品久久久久伊人av| www.亚洲一二| 国产网站欧美日韩免费精品在线观看| 亚洲色图美腿丝袜| 精品国产老师黑色丝袜高跟鞋| 性色av一区二区三区红粉影视| 国产成人精品一区二区在线| 国产激情999| 国产一区二区美女视频| 成人免费在线视频网址| 亚洲天堂视频在线观看| 亚洲欧美另类中文字幕| 精品女同一区二区三区在线播放| 久久99热精品| 日韩经典中文字幕| 91精品久久久久久| 欧美最近摘花xxxx摘花| 国产欧美精品va在线观看| 精品国产欧美成人夜夜嗨| 久久视频在线看| 国产精品一区二区三区久久| 疯狂蹂躏欧美一区二区精品| 人人爽久久涩噜噜噜网站| 中文字幕欧美日韩va免费视频| 久久伊人精品视频| 日韩av中文字幕在线播放| 992tv在线成人免费观看| 国产精品对白刺激| 国产欧美亚洲精品| 日韩一区二区在线视频| 亚洲美女av在线| 日韩福利视频在线观看| 亚洲成av人片在线观看香蕉| 久久av红桃一区二区小说| 91久久久在线| 欧美性极品少妇精品网站| 久久久免费观看| 中文字幕一精品亚洲无线一区| 91精品视频免费| 情事1991在线| 久久中文字幕在线视频| 亚洲黄色免费三级|