scala-04-set操作
Scala Set(集合)是没有重复的对象集合,所有的元素都是唯一的。
Scala 集合分为可变的和不可变的集合。
默认情况下,Scala 使用的是不可变集合,如果你想使用可变集合,需要引用 scala.collection.mutable.Set 包。
1, 获取set集合
def getSet(): Set[String] = {
val mutableSet = Set("", "", "")
println(mutableSet.getClass.getName)
mutableSet
}
2, 添加和删除元素
def addAndRemove(mutableSet: Set[String]): Unit = {
mutableSet.add("eqwr")
mutableSet.remove("eqwr")
mutableSet += "asdf"
}
3, 基础操作
def baseControl(multSet: Set[String]): Unit = {
println("获取第一个个值" + multSet.head)
println("获取第一个之后值" + multSet.tail)
println("是否为空" + multSet.isEmpty)
}
4, 集合连接
def concatSet(set1: Set[String])(set2: Set[String]): Set[String] = {
// 使用 ++ 链接
var site = set1 ++ set2
var site2 = set1.++(set2)
site
}
5, 求最值
def minMax(multSet: Set[Int]): Int = {
println(multSet.max)
println(multSet.min)
multSet.max
}
6, 求交集
def interSec(set1: Set[Int], set2: Set[Int]): Set[Int] = {
var setss = set1.&(set2)
println(setss)
var setsss = set1.intersect(set2)
println(setsss)
setsss
}
常用 api
| 1 |
def +(elem: A): Set[A] 为集合添加新元素,x并创建一个新的集合,除非元素已存在 |
| 2 |
def -(elem: A): Set[A] 移除集合中的元素,并创建一个新的集合 |
| 3 |
def contains(elem: A): Boolean 如果元素在集合中存在,返回 true,否则返回 false。 |
| 4 |
def &(that: Set[A]): Set[A] 返回两个集合的交集 |
| 5 |
def &~(that: Set[A]): Set[A] 返回两个集合的差集 |
| 6 |
def +(elem1: A, elem2: A, elems: A*): Set[A] 通过添加传入指定集合的元素创建一个新的不可变集合 |
| 7 |
def ++(elems: A): Set[A] 合并两个集合 |
| 8 |
def -(elem1: A, elem2: A, elems: A*): Set[A] 通过移除传入指定集合的元素创建一个新的不可变集合 |
| 9 |
def addString(b: StringBuilder): StringBuilder 将不可变集合的所有元素添加到字符串缓冲区 |
| 10 |
def addString(b: StringBuilder, sep: String): StringBuilder 将不可变集合的所有元素添加到字符串缓冲区,并使用指定的分隔符 |
| 11 |
def apply(elem: A) 检测集合中是否包含指定元素 |
| 12 |
def count(p: (A) => Boolean): Int 计算满足指定条件的集合元素个数 |
| 13 |
def copyToArray(xs: Array[A], start: Int, len: Int): Unit 复制不可变集合元素到数组 |
| 14 |
def diff(that: Set[A]): Set[A] 比较两个集合的差集 |
| 15 |
def drop(n: Int): Set[A]] 返回丢弃前n个元素新集合 |
| 16 |
def dropRight(n: Int): Set[A] 返回丢弃最后n个元素新集合 |
| 17 |
def dropWhile(p: (A) => Boolean): Set[A] 从左向右丢弃元素,直到条件p不成立 |
| 18 |
def equals(that: Any): Boolean equals 方法可用于任意序列。用于比较系列是否相等。 |
| 19 |
def exists(p: (A) => Boolean): Boolean 判断不可变集合中指定条件的元素是否存在。 |
| 20 |
def filter(p: (A) => Boolean): Set[A] 输出符合指定条件的所有不可变集合元素。 |
| 21 |
def find(p: (A) => Boolean): Option[A] 查找不可变集合中满足指定条件的第一个元素 |
| 22 |
def forall(p: (A) => Boolean): Boolean 查找不可变集合中满足指定条件的所有元素 |
| 23 |
def foreach(f: (A) => Unit): Unit 将函数应用到不可变集合的所有元素 |
| 24 |
def head: A 获取不可变集合的第一个元素 |
| 25 |
def init: Set[A] 返回所有元素,除了最后一个 |
| 26 |
def intersect(that: Set[A]): Set[A] 计算两个集合的交集 |
| 27 |
def isEmpty: Boolean 判断集合是否为空 |
| 28 |
def iterator: Iterator[A] 创建一个新的迭代器来迭代元素 |
| 29 |
def last: A 返回最后一个元素 |
| 30 |
def map[B](f: (A) => B): immutable.Set[B] 通过给定的方法将所有元素重新计算 |
| 31 |
def max: A 查找最大元素 |
| 32 |
def min: A 查找最小元素 |
| 33 |
def mkString: String 集合所有元素作为字符串显示 |
| 34 |
def mkString(sep: String): String 使用分隔符将集合所有元素作为字符串显示 |
| 35 |
def product: A 返回不可变集合中数字元素的积。 |
| 36 |
def size: Int 返回不可变集合元素的数量 |
| 37 |
def splitAt(n: Int): (Set[A], Set[A]) 把不可变集合拆分为两个容器,第一个由前 n 个元素组成,第二个由剩下的元素组成 |
| 38 |
def subsetOf(that: Set[A]): Boolean 如果集合中含有子集返回 true,否则返回false |
| 39 |
def sum: A 返回不可变集合中所有数字元素之和 |
| 40 |
def tail: Set[A] 返回一个不可变集合中除了第一元素之外的其他元素 |
| 41 |
def take(n: Int): Set[A] 返回前 n 个元素 |
| 42 |
def takeRight(n: Int):Set[A] 返回后 n 个元素 |
| 43 |
def toArray: Array[A] 将集合转换为数字 |
| 44 |
def toBuffer[B >: A]: Buffer[B] 返回缓冲区,包含了不可变集合的所有元素 |
| 45 |
def toList: List[A] 返回 List,包含了不可变集合的所有元素 |
| 46 |
def toMap[T, U]: Map[T, U] 返回 Map,包含了不可变集合的所有元素 |
| 47 |
def toSeq: Seq[A] 返回 Seq,包含了不可变集合的所有元素 |
| 48 |
def toString(): String 返回一个字符串,以对象来表示 |
scala-04-set操作的更多相关文章
- scala 基本类型和操作
Scala基本类型 Scala中的基本数据类型如下图: (来源:Programming in scala) 从上表中可以看出,Scala的基本数据类型与Java中的基本数据类型是一一对应的,不同的是 ...
- Pipeline in scala——给scala添加管道操作
linux系统中管道这一功能相信大家肯定使用过,比如现在想找到用户目录下文件名包含db的所有文件,ls ~的结果,作为grep db的参数: ➜ ~ ls ~ | grep db kv.mv.db ...
- Scala函数高级操作
字符串高级操作:***** 非常重要 将函数赋值给变量/值def sayHello(name:String): Unit = { println(s"Hello:$name")} ...
- Scala的XML操作
8. XML 8.1. 生成 Scala原生支持xml,就如同Java支持String一样,这就让生成xml和xhtml非常easy优雅: val name = "james ...
- scala VS python2 操作shell对比例子
Scala: /** * Created by sunxu on 2015/9/30. */ import scala.sys.process._ import java.io.File //在相应目 ...
- scala文件流操作,生成sparkpv,uv作业文件
package com.bjsxt.scalaspark.core.examples.pvAnduv import java.io.Fileimport java.text.SimpleDateFor ...
- 大数据学习——scala类相关操作
1 类的定义 package com /** * Created by Administrator on 2019/6/3. */ //类并不用声明为public. class Person { // ...
- Ubuntu 16.04下操作iptables的技巧(解决Failed to start iptables.service: Unit iptables.service not found.或者/etc/init.d/iptables: 没有那个文件或目录)
/etc/init.d/iptables网上的解法应该都是基于CentOS 6去实践,而在CentOS 7中又被firewalld给取代,所以操作上的写法基本会改变,但是底层iptables则不会改变 ...
- xBIM 基础04 日志操作
系列目录 [已更新最新开发文章,点击查看详细] xBIM使用Log4Net来记录异常不适合的处理错误和警告.它在xBIM几何引擎中被大量使用来记录所有几何错误.如果您的文件看起来不太正确,则应 ...
- node.js整理 04网络操作
简介 var http = require('http'); http.createServer(function (req, res) { res.writeHead(200, {'Content- ...
随机推荐
- (转)Tomcat(java运行环境)安装及配置教程
转自:http://jingyan.baidu.com/article/870c6fc33e62bcb03fe4be90.html 用来进行web开发的工具有很多,Tomcat是其中一个开源的且免费的 ...
- hdu 4970 trick
http://acm.hdu.edu.cn/showproblem.php?pid=4970 有n个格子在一条线标号1-n上,可以给范围在l到r内的格子架上攻击力为d的攻击塔,有m个怪物,每个怪物有个 ...
- Spring Boot 2 启动时加载properties文件
每个项目从开发到测试再到上线所需要的各种环境是不同的,这就需要维护相应的配置文件,比如properties或yml文件.有了配置文件后就要考虑如何与应用进行集成. 对于云环境来讲,项目发布需要打成镜像 ...
- NODE-WEBKIT教程(6)NATIVE UI API 之MENU(菜单)
node-webkit教程(6)Native UI API 之Menu(菜单) 文/玄魂 目录 node-webkit教程(6)Native UI API 之Menu(菜单) 前言 6.1 Menu ...
- VMware中安装Contos
1 检查BIOS虚拟化支持 2 新建虚拟机 3 新建虚拟机向导 4 创建虚拟空白光盘 5 安装Linux系统对应的CentOS版 6 虚拟机命名和定位磁盘位置 7 处理器配置,看自己是否是双核.多核 ...
- 25_re模块
一.re模块的核心功能 1.findall —— 查找所有,返回list lst = re.findall("m", "mai le fo len, mai ...
- Swift5 语言参考(一) 关于语言参考
本系列文章的这一部分描述了Swift编程语言的形式语法.此处描述的语法旨在帮助您更详细地理解语言,而不是允许您直接实现解析器或编译器. Swift语言相对较小,因为Swift代码中几乎无处不在的许多常 ...
- python进程——生产者消费者
生产者消费者模型介绍 为什么要使用生产者消费者模型 生产者指的是生产数据的任务,消费者指的是处理数据的任务,在并发编程中,如果生产者处理速度很快,而消费者处理速度很慢,那么生产者就必须等待消费者处理完 ...
- 精通CSS 第1章
一 标记简史 1 使用有意义的元素 2 ID和类名:ID是唯一的,而一个类名可以应用于多个元素.在写ID和类名时需要注意区分大小写,并使用统一的命名约定,比如完全小写+连字符分割,例andy-budd ...
- [Leetcode]146.LRU缓存机制
Leetcode难题,题目为: 运用你所掌握的数据结构,设计和实现一个 LRU (最近最少使用) 缓存机制.它应该支持以下操作: 获取数据 get 和 写入数据 put . 获取数据 get(key ...