Dart之集合详解(List、Set、Map)

简介: Dart之集合详解(List、Set、Map)

一、List

main() {
//  定义一个int类型数组
  List list1 = <int>[1, 2];
  print(list1); //[1, 2]
//  length长度
  print(list1.length); //2
// reversed翻转
  print(list1.reversed.toList()); //[2, 1]
// isEmpty 是否为空
  print(list1.isEmpty); //false
//isNotEmpty 是否不为空
  print(list1.isNotEmpty); //true
//add添加
  list1.add(3);
  print(list1); //[1, 2, 3]
//addAll 添加一个数据
  list1.addAll(<int>[4, 5]);
  print(list1); //[1, 2, 3, 4, 5]
//indexOf 查找 传入具体指 找到返回索引,否则返回-1
  print(list1.indexOf(1)); //0
  print(list1.indexOf(90)); //-1
//remove 删除具体值
  list1.remove(4); //[1, 2, 3, 5]
  print(list1);
//removeAt 删除 传入索引
  list1.removeAt(0);
  print(list1); //[2, 3, 5]
//fillRange 修改
  list1.fillRange(1, 2, 89); //[2, 89, 5]
  print(list1);
  //insert 插入值
  list1.insert(2,
      99); //[2, 89, 99, 5] 如果插入位置大于现在拥有的下标-》Invalid value: Not in inclusive range 0..3: 7
  print(list1);
  //insertAll 插入数组
  list1.insertAll(2, <int>[33, 44]);
  print(list1); //[2, 89, 33, 44, 99, 5]
  //toList 其它类型转换为List
  var str = list1.toString();
  print(str); //[2, 89, 33, 44, 99, 5]
  print(str.length); //22
  //join() List转换为字符串
  print(list1.join(":")); //2:89:33:44:99:5
  //split()字符串转换为list
  print("1,2,3".split(",") is List); //true
  //forEach
list1.forEach((element) {print(element);});//2  89  33  44  99  5
 
  //map 遍历每个元素,返回准换后的结果
  list1=list1.map((e) => e*2).toList();
  print(list1); //[4, 178, 66, 88, 198, 10]
  //where 过滤元素,保留满足条件的元素
  list1=list1.where((element) => element>87).toList();
  print(list1);//[178, 88, 198]
  //any 判断集合中是否有一个元素满足条件 element>188
  var condition_1= list1.any((element) => element>188);
  print(condition_1); //true
  //every 判断集合中是否有所有元素满足条件 element>188
  var condition_2= list1.every((element) => element>188);
  print(condition_2); //false
 
}

二、map

main() {
//  键-》值
  Map person = {"name": "zhangsan", 'age': 20};
//  获取长度
  print(person.length); //2
//  判断是否为空
  print(person.isNotEmpty); //true
//  获取运行是类型
  print(person.runtimeType); //_InternalLinkedHashMap<dynamic, dynamic>
//  获取hashCode
  print(person.hashCode); //1018109981
//  获取所有键
  print(person.keys.toList()); //[name, age]
//  获取所有值
  print(person.values.toList()); //[zhangsan, 20]
//添加键值对
  person.addAll({"work": "coding"});
  print(person); //{name: zhangsan, age: 20, work: coding}
//  产出一个键
  person.remove('age');
  print(person); //{name: zhangsan, work: coding}
//  判断是否包含值
  print(person.containsValue("coding")); //true
//  判断是否包含键
  print(person.containsKey("work")); //true
}

三、set

重复方法见List

main(){
  var mySet=new Set();
  mySet.add(1);
  mySet.add(2);
  mySet.add(1);
  print(mySet);//{1, 2}
  print(mySet.toList());//[1, 2]
 
}

四、遍历List

main() {
  List myList = ["a", "b", "c"];
//  for in
  for (var value in myList) {
    print(value);
  }
//  for
  for (int i = 0; i < myList.length; i++) {
    print(myList[i]);
  }
//  forEach
  myList.forEach((element) {
    print(element);
  });
  myList.forEach((element) => print(element));
 
}
相关文章
|
4月前
|
存储 JavaScript Java
(Python基础)新时代语言!一起学习Python吧!(四):dict字典和set类型;切片类型、列表生成式;map和reduce迭代器;filter过滤函数、sorted排序函数;lambda函数
dict字典 Python内置了字典:dict的支持,dict全称dictionary,在其他语言中也称为map,使用键-值(key-value)存储,具有极快的查找速度。 我们可以通过声明JS对象一样的方式声明dict
307 1
|
7月前
|
存储 缓存 JavaScript
Set和Map有什么区别?
Set和Map有什么区别?
528 1
|
4月前
|
存储 算法 容器
set_map的实现+set/map加持秒杀高频算法题锻炼算法思维
`set`基于红黑树实现,支持有序存储、自动去重,增删查效率为O(logN)。通过仿函数可自定义排序规则,配合空间配置器灵活管理内存。不支持修改元素值,迭代器失效需注意。`multiset`允许重复元素。常用于去重、排序及查找场景。
|
8月前
|
存储 JavaScript 前端开发
for...of循环在遍历Set和Map时的注意事项有哪些?
for...of循环在遍历Set和Map时的注意事项有哪些?
392 121
|
8月前
|
安全 Java 数据库连接
让我们讲解一下 Map 集合遍历的方式
我是小假 期待与你的下一次相遇 ~
313 43
|
8月前
|
存储 C++ 容器
unordered_set、unordered_multiset、unordered_map、unordered_multimap的介绍及使用
unordered_set是不按特定顺序存储键值的关联式容器,其允许通过键值快速的索引到对应的元素。在unordered_set中,元素的值同时也是唯一地标识它的key。在内部,unordered_set中的元素没有按照任何特定的顺序排序,为了能在常数范围内找到指定的key,unordered_set将相同哈希值的键值放在相同的桶中。unordered_set容器通过key访问单个元素要比set快,但它通常在遍历元素子集的范围迭代方面效率较低。它的迭代器至少是前向迭代器。前向迭代器的特性。
346 0
|
8月前
|
编译器 C++ 容器
用一棵红黑树同时封装出map和set
再完成上面的代码后,我们的底层代码已经完成了,这时候已经是一个底层STL的红黑树了,已经已符合库里面的要求了,这时候我们是需要给他穿上对应的“衣服”,比如穿上set的“衣服”,那么这个穿上set的“衣服”,那么他就符合库里面set的要求了,同样map一样,这时候我们就需要实现set与map了。因此,上层容器map需要向底层红黑树提供一个仿函数,用于获取T当中的键值Key,这样一来,当底层红黑树当中需要比较两个结点的键值时,就可以通过这个仿函数来获取T当中的键值了。我们就可以使用仿函数了。
111 0
|
8月前
|
存储 编译器 容器
set、map、multiset、multimap的介绍及使用以及区别,注意事项
set是按照一定次序存储元素的容器,使用set的迭代器遍历set中的元素,可以得到有序序列。set当中存储元素的value都是唯一的,不可以重复,因此可以使用set进行去重。set默认是升序的,但是其内部默认不是按照大于比较,而是按照小于比较。set中的元素不能被修改,因为set在底层是用二叉搜索树来实现的,若是对二叉搜索树当中某个结点的值进行了修改,那么这棵树将不再是二叉搜索树。
293 0
|
11月前
使用 entrySet 遍历 Map 类集合 KV
使用 entrySet 遍历 Map 类集合 KV

热门文章

最新文章