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- ...
随机推荐
- (转)转一份在 51testing 上的讨论——如何测试一个门户网站是否可以支持10万用户同时在线?
转自:http://www.cnblogs.com/jackei/archive/2006/11/16/561846.html 这个帖子的内容比较典型,大家有兴趣可以也思考一下. 先是楼主提出问题: ...
- MapServer和GeoServer对比
https://blog.csdn.net/theonegis/article/details/45823099
- include require include_once require_once
include 使用方法: include "test.php"; 一般是放在流程控制的处理部分中使用,将文件内容引入.PHP程序在遇到include语句时,才将它读进来,这种方式 ...
- bootstrap代码(一)
一般在个人博客上使用的较为频繁,用于显示代码的风格.在Bootstrap主要提供了三种代码风格:1.使用<code></code>来显示单行内联代码2.使用<pre> ...
- JPA Annotation注解
JPA & Hibernate 注解 先说说JPA和Hibernate的关系 JPA(Java Persistence API),是Java EE 5的标准ORM接口,也是ejb3规范的一部分 ...
- [leet code 198]House Robber
1 题目 You are a professional robber planning to rob houses along a street. Each house has a certain a ...
- JS学习笔记7_表单脚本
1.获取表单及表单元素引用的方式 var mForm = document.forms[formName];获取表单引用 mForm.elements[elemName]获取表单元素,如有同名的,则得 ...
- VIM 实现tab标签页及分屏,切换命令
1,在一个窗口中,VIM 的小tab标签页命令: :tabnew [++opt选项] [+cmd] 文件 建立对指定文件新的tab :tabc 关闭当前的tab ...
- 【DirectX】 AudioVideoPlayback 中的事件BUG
当访问 Video 中的 Audio 属性时,会造成 Video 的所有事件失效.经过反汇查看源码,原来在访问Audio属性时,Audio会通过当前Video对象创建一个新实例.而这个新实例会覆盖掉当 ...
- (zxing.net)二维码Aztec的简介、实现与解码
一.简介 Aztec Code是1995年,由Hand HeldProducts公司的Dr. Andrew Longacre设计.它是一种高容量的二维条形码格式.它可以对ASCII和扩展ASCII码进 ...