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));
 
}
相关文章
|
1月前
|
存储 JavaScript Java
(Python基础)新时代语言!一起学习Python吧!(四):dict字典和set类型;切片类型、列表生成式;map和reduce迭代器;filter过滤函数、sorted排序函数;lambda函数
dict字典 Python内置了字典:dict的支持,dict全称dictionary,在其他语言中也称为map,使用键-值(key-value)存储,具有极快的查找速度。 我们可以通过声明JS对象一样的方式声明dict
128 1
|
4月前
|
存储 缓存 JavaScript
Set和Map有什么区别?
Set和Map有什么区别?
353 1
|
27天前
|
存储 算法 容器
set_map的实现+set/map加持秒杀高频算法题锻炼算法思维
`set`基于红黑树实现,支持有序存储、自动去重,增删查效率为O(logN)。通过仿函数可自定义排序规则,配合空间配置器灵活管理内存。不支持修改元素值,迭代器失效需注意。`multiset`允许重复元素。常用于去重、排序及查找场景。
|
1月前
|
存储 Java 索引
(Python基础)新时代语言!一起学习Python吧!(二):字符编码由来;Python字符串、字符串格式化;list集合和tuple元组区别
字符编码 我们要清楚,计算机最开始的表达都是由二进制而来 我们要想通过二进制来表示我们熟知的字符看看以下的变化 例如: 1 的二进制编码为 0000 0001 我们通过A这个字符,让其在计算机内部存储(现如今,A 字符在地址通常表示为65) 现在拿A举例: 在计算机内部 A字符,它本身表示为 65这个数,在计算机底层会转为二进制码 也意味着A字符在底层表示为 1000001 通过这样的字符表示进行转换,逐步发展为拥有127个字符的编码存储到计算机中,这个编码表也被称为ASCII编码。 但随时代变迁,ASCII编码逐渐暴露短板,全球有上百种语言,光是ASCII编码并不能够满足需求
113 4
|
5月前
|
存储 JavaScript 前端开发
for...of循环在遍历Set和Map时的注意事项有哪些?
for...of循环在遍历Set和Map时的注意事项有哪些?
301 121
|
4月前
|
并行计算 Java API
Java List 集合结合 Java 17 新特性与现代开发实践的深度解析及实战指南 Java List 集合
本文深入解析Java 17中List集合的现代用法,结合函数式编程、Stream API、密封类、模式匹配等新特性,通过实操案例讲解数据处理、并行计算、响应式编程等场景下的高级应用,帮助开发者提升集合操作效率与代码质量。
203 1
|
4月前
|
存储 安全 Java
Java 学习路线 35 掌握 List 集合从入门到精通的 List 集合核心知识
本文详细解析Java中List集合的原理、常用实现类(如ArrayList、LinkedList)、核心方法及遍历方式,并结合数据去重、排序等实际应用场景,帮助开发者掌握List在不同业务场景下的高效使用,提升Java编程能力。
369 0
|
5月前
|
存储 C++ 容器
unordered_set、unordered_multiset、unordered_map、unordered_multimap的介绍及使用
unordered_set是不按特定顺序存储键值的关联式容器,其允许通过键值快速的索引到对应的元素。在unordered_set中,元素的值同时也是唯一地标识它的key。在内部,unordered_set中的元素没有按照任何特定的顺序排序,为了能在常数范围内找到指定的key,unordered_set将相同哈希值的键值放在相同的桶中。unordered_set容器通过key访问单个元素要比set快,但它通常在遍历元素子集的范围迭代方面效率较低。它的迭代器至少是前向迭代器。前向迭代器的特性。
239 0
|
8月前
|
编译器 C++ 容器
【c++丨STL】基于红黑树模拟实现set和map(附源码)
本文基于红黑树的实现,模拟了STL中的`set`和`map`容器。通过封装同一棵红黑树并进行适配修改,实现了两种容器的功能。主要步骤包括:1) 修改红黑树节点结构以支持不同数据类型;2) 使用仿函数适配键值比较逻辑;3) 实现双向迭代器支持遍历操作;4) 封装`insert`、`find`等接口,并为`map`实现`operator[]`。最终,通过测试代码验证了功能的正确性。此实现减少了代码冗余,展示了模板与仿函数的强大灵活性。
220 2