1. 程式人生 > >ES6-----學習系列十(set-map數據結構)

ES6-----學習系列十(set-map數據結構)

trie for strong 沒有 類型轉化 數組去重 foreach 生效 nbsp

一、set數據結構 (使用 new來創建一個set集合 通過add方法添加元素 通過size來獲取set集合的長度) 

{
  let list = new Set();
  list.add(5);
  list.add(7);

  console.log(‘size‘,list.size);
}

  還有另外一種初始化的方式(通過直接把數組傳遞進去)

{
  let arr = [1,2,3,4,5];
  let list = new Set(arr);

  console.log(‘size‘,list.size);
}

  set裏面的元素不可以重復(可以通過set的這個特性進行數組去重,註意:轉化過程中不會進行 數據類型轉化)

{
  let list = new Set();
  list.add(1);
  list.add(2);
  list.add(1);//不會報錯 只是不會生效

  console.log(‘list‘,list);

  let arr=[1,2,3,1,‘2‘];
  let list2=new Set(arr);

  console.log(‘unique‘,list2);
}

  set的一些方法(add ,delete,clear,has) 

{
  let arr=[‘add‘,‘delete‘,‘clear‘,‘has‘];
  let list=new Set(arr);

  console.log(
‘has‘,list.has(‘add‘));//是否包含 console.log(‘delete‘,list.delete(‘add‘),list);//清空 list.clear(); console.log(‘list‘,list); }

  set的遍歷(keys和values返回的都是set裏面的值)

{
  let arr=[‘add‘,‘delete‘,‘clear‘,‘has‘];
  let list=new Set(arr);

  for(let key of list.keys()){
    console.log(‘keys‘,key);
  }
  for
(let value of list.values()){ console.log(‘value‘,value); } for(let [key,value] of list.entries()){ console.log(‘entries‘,key,value); } list.forEach(function(item){console.log(item);}) }

  WeakSet(裏面的元素只能是對象,並且不會檢測所添加的對象是否在別處引用,沒有size clear 不支持遍歷)

{
  let weakList=new WeakSet();

  let arg={};

  weakList.add(arg);

  // weakList.add(2);

  console.log(‘weakList‘,weakList);
}

二、Map數據結構(Map是通過key/value進行設置的,所以設置用set方法,獲取使用get方法)  

{
  let map = new Map();
  let arr=[‘123‘];

  map.set(arr,456);

  console.log(‘map‘,map,map.get(arr));
}

  Map的另外一種定義方式(同時size delete clear方法一樣)

{
  let map = new Map([[‘a‘,123],[‘b‘,456]]);
  console.log(‘map args‘,map);
  console.log(‘size‘,map.size);
  console.log(‘delete‘,map.delete(‘a‘),map);
  console.log(‘clear‘,map.clear(),map);
}

  weakMap數據結構(和setMap的特性一致)

{
  let weakmap=new WeakMap();

  let o={};
  weakmap.set(o,123);
  console.log(weakmap.get(o));
}

    

ES6-----學習系列十(set-map數據結構)