国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

在JavaScript中構建ArrayList示例代碼

2024-05-06 16:08:54
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了在JavaScript中構建ArrayList,很實用,需要的朋友可以參考下
前面我們介紹了JavaScript Array 的API,在JavaScript 中 數組 本身就非常強大,可以存儲任意類型,且長度自動擴容,又提供 遍歷, 過濾,等多個操作數組的方法。
簡直完爆Java的的數組(長度固定,單一類型)。而Java中的集合類 就是彌補數組不足,其底層大多使用Object [] 存儲,只是提供動態擴容的策略,當然JDK的 API 之豐富,是其他語言難以匹敵的。
但是不妨礙我對Java、JavaScript的喜愛。
Java就像 一個中年老婦女,你總能在JDK中 看到她的 風韻猶存,在構建 大型分布式 系統,就能體現出她的 諄諄教導;
而JavaScript 就是含苞待放的 少女 ,每一次綻放 ,就會激起你 內心的 漣漪,得小心調教,才能為你所用。
好吧 原諒我不恰當的比喻,來點干貨。
 
/**
*@class ArrayList
*@description
*@time 2014-09-16 21:59
*@author StarZou
**/

function ArrayList(arr) {
this._elementData = arr || [];
}

var arrayListPrototype = {

'_arrayPrototype': Array.prototype,

'_getData': function () {
return this._elementData;
},

'size': function () {
return this._getData().length;
},

'isEmpty': function () {
return this.size() === 0;
},

'contains': function (obj) {
return this.indexOf(obj) > -1;
},

'indexOf': function (obj) {
var i , data = this._getData(), length = data.length;
for (i = 0; i < length; i++) {
if (obj === data[i]) {
return i;
}
}
return -1;
},

'lastIndexOf': function (obj) {
var i , data = this._getData(), length = data.length;
for (i = length - 1; i > -1; i--) {
if (obj === data[i]) {
return i;
}
}
return -1;
},

'get': function (index) {
return this._getData()[index];
},

'set': function (index, element) {
this._getData()[index] = element;
},

'add': function (index, element) {
if (element) {
this.set(index, element);
} else {
return this._getData().push(index);
}
},

'remove': function (index) {
var oldValue = this._getData()[index];
this._getData()[index] = null;
return oldValue;
},

'clear': function () {
this._getData().length = 0;
},

'addAll': function (index, array) {
if (array) {
this._getData().splice(index, 0, array);
} else {
this._arrayPrototype.push.apply(this._getData(), index);
}
}

};

ArrayList.prototype = arrayListPrototype;
 
// Test 代碼
var arr = new ArrayList([3, 6, 5, 'xyz', 'foo', 'xyz']);

console.log(arr.contains('xyz'));
console.log(arr.indexOf('xyz'));
console.log(arr.lastIndexOf('xyz'));
console.log(arr.get(2));
arr.addAll([1, 2, 3]);
console.log(arr);

上面代碼實現了 一部分 ,還有優化地方,
以后 有時間 寫 JavaScript 模擬 實現 Tree , Stack ,Queue ,Map 等數據結構的類。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 嘉善县| 山阴县| 黑龙江省| 兴文县| 琼中| 酉阳| 松桃| 张家界市| 庆阳市| 江都市| 宁阳县| 固阳县| 利川市| 普格县| 万荣县| 乌兰察布市| 弥渡县| 阿勒泰市| 安福县| 丹东市| 习水县| 江华| 玉林市| 翁牛特旗| 金沙县| 崇文区| 谷城县| 洪江市| 南靖县| 青浦区| 通河县| 辉南县| 休宁县| 灵石县| 青龙| 岢岚县| 绥江县| 抚州市| 孝感市| 武山县| 太仆寺旗|