1.元组

定义方式:val tp=("nana',1,1.1)

特点:集合中的数据可以是不同类型的

最多只能放22个元素

取值:通过角标取值,这里的角标是从1开始的,元组名称._角标   tp._1   ("nana")

当出现数组长度不相同时,报错

对偶元组:val tp=("nana",1) 两个元素

拉链操作: zip

当出现数组长度不想同时,一一匹配,无则不匹配

2.数组

数组分为:不可变数组:长度不变,内容可变Array

可变数组:长度内容都可以改变 ArrayBuffer

不可变数组

定义:

val array1=Array(1,3,5,7)

val array2=new Array[Int](5)  初始值都为0,需要指定长度

取值:通过角标,从1开始  array1(1)  []指泛型

赋值:

array1(0)=333  赋值是从0开始的

可变数组

导包jar   import scala.collection.mutable.ArrayBuffer

定义

val array3=ArrayBuffer(11,22,33,44)

val array4=new ArrayBuffer[Int](5)

取值、赋值和不可变数组一样

可变数组的运算符号

+=  添加单个值  array3+=2222

++= 添加数组     array3++=array4

-=  删除单个值   array3-=44

--= 删除多个值   array3--=array1

数组的常用方法

数组的反转:reverse     array3.reverse

数组的截取:slice(from,until)    array3.slice(1,2)  左闭右开

数组的去重:distinct   array3.distinct

3.List

不可变的 List   长度,内容都是不可以改变的

可变的 ListBuffer 长度,内容都是可变的

创建不可变的List

val list1=List[int](1,2,44,55)

构建List的另一种方法  ::Nil

8::9::44::Nil    Nil空列表

::该方法被称为cons,以为构造,向队列的头部追加数据,创建新的列表,用法为x::list,其中x为加入头部的元素,无论x是列表与否,他都只将成为新生成列表的第一个元素

添加元素

:+在尾部追加元素  list1 :+1

+:在头部追加元素(:要朝向集合) 1+:list1

++ 该方法用于连接两个集合 list1++list2

:::只能用于链接两个List类型的集合

对于不可变类型集合的操作,生成了一个新的集合,元集合并没有被改变

可变的List

导包jar  import scala.collection.mutable.ListBuffer

val list1=ListBuffer(11,22,34,55)

val list2=new ListBuffer[int]() 不设置数组大小

+= ++= -= --=

List的集合由两部分组成

hade  list1.head   List集合的第一个元素

tail     list1.tail       List集合除去第一个元素的其他元素

List集合的转换

toList   array3.toList

toArray  list3.toAreray

4.Map

定义

(1)val map1=Map(("nana",12),("jingjing",23))

(2)  val  map2=Map("nana"->1,"jingjing"->2)

循环

map1.keys.foreach{

i =>print("key=“+i)

printIn("value="+map1(i))

map的几种方法

contains(包含) Boolean  判断是否存在key

map1("nana")  返回value     map1("nan") 报错

map1.get("nana")  返回Opint[Int]=Some(12)     Scala Option(选项)类型用来表示一个值是可选的(有值或无值)。

map1.getOrElse("nana",-1)    Int=12 你可以使用 getOrElse() 方法来获取元组中存在的元素或者使用其默认的值,如果不存在的话则返回-1(可以自己定义)

5.Set

set实际上是Map集合上的key,set存储的元素是唯一的,不重复的,会自动去除掉重复的

val set=Set(1,2,3,1)

6.集合上常用的方法

map : 一对一映射  也就是对原来的集合中的每一个元素,执行某一项操作(该操作取决于函数的内容)

(自己的理解:万能转化器(自己想要什么格式,就转成什么格式)  array3.map(_*2)   array3.map(tp=>tp*2)

filter 过滤出满足条件的元素  array3.filter(_>22)  array3.filter(tp=>tp>33&&tp<543)

filterNot 过滤出不满足条件的

flatten 压平

Unit 类型,没有返回值的类型(返回值为空)

sorted 排序

7.集合框架中常用方法

交集 array1.instersect(array3)

差集 array1.diff(array3)

并集 array1.union(array3)

Scala的集合框架的更多相关文章

  1. 【scala】集合框架

  2. 一起学 Java(三) 集合框架、数据结构、泛型

    一.Java 集合框架 集合框架是一个用来代表和操纵集合的统一架构.所有的集合框架都包含如下内容: 接口:是代表集合的抽象数据类型.接口允许集合独立操纵其代表的细节.在面向对象的语言,接口通常形成一个 ...

  3. 【目录】JUC集合框架目录

    JUC集合框架的目录整理如下: 1. [JUC]JUC集合框架综述 2. [JUC]JDK1.8源码分析之ConcurrentHashMap(一) 3. [JUC]JDK1.8源码分析之Concurr ...

  4. java面试题——集合框架

    先来看一下集合框架关系图 Collection FrameWork 如下: Collection ├List │├LinkedList │├ArrayList │└Vector │ └Stack └S ...

  5. Java使用实现面向对象编程:第七章集合框架的解读=>重中之重

    对于集合框架,是非常重要的知识,是程序员必须要知道的知识点. 但是我们为什么要引入集合框架呢? 我们之前用过数组存储数据,但是采用数组存储存在了很多的缺陷.而现在我们引用了集合框架,可以完全弥补了数组 ...

  6. Java集合框架List,Map,Set等全面介绍

    Java集合框架的基本接口/类层次结构: java.util.Collection [I]+--java.util.List [I]   +--java.util.ArrayList [C]   +- ...

  7. Java集合框架练习-计算表达式的值

    最近在看<算法>这本书,正好看到一个计算表达式的问题,于是就打算写一下,也正好熟悉一下Java集合框架的使用,大致测试了一下,没啥问题. import java.util.*; /* * ...

  8. Java 之 集合框架(JCF)

    1.集合框架 a.框架:为了实现某一目的或功能,而预先提供的一系列封装好的.具有继承或实现关系的类与集合 b.集合:①定义:Java中对一些数据结构和算法进行封装,即封装(集合也是一种对象) ②特点: ...

  9. 【集合框架】Java集合框架综述

    一.前言 现笔者打算做关于Java集合框架的教程,具体是打算分析Java源码,因为平时在写程序的过程中用Java集合特别频繁,但是对于里面一些具体的原理还没有进行很好的梳理,所以拟从源码的角度去熟悉梳 ...

随机推荐

  1. Linux 学习 (一)

    最常用的7个Linux命令: cd:切换目录. pwd:查看当前所在目录. ls:查看目录下的文件. touch:没有文件则创建文件. mkdir:创建目录. mr:remove删除.         ...

  2. ceph对接openstack

    一.使用rbd方式提供存储如下数据: (1)image(glance):保存glanc中的image: (2)volume(cinder)存储:保存cinder的volume:保存创建虚拟机时选择创建 ...

  3. 总结下Nginx的功能模块

    nginx-1.10.3]# ./configure  \ --prefix=/usr/local/nginx   \        #指定安装路径 --user=nginx --group=ngin ...

  4. DNS记录

    转载于:https://www.cnblogs.com/sddai/p/5703394.html 类型 SOA NS A AAAA PTR CNAME MX --------------------- ...

  5. 折半搜索+Hash表+状态压缩 | [Usaco2012 Open]Balanced Cow Subsets | BZOJ 2679 | Luogu SP11469

    题面:SP11469 SUBSET - Balanced Cow Subsets 题解: 对于任意一个数,它要么属于集合A,要么属于集合B,要么不选它.对应以上三种情况设置三个系数1.-1.0,于是将 ...

  6. HMM 传统后向算法

    HMM 传统后向算法,已实现,仅供参考. package jxutcm.edu.cn.hmm.model; import jxutcm.edu.cn.hmm.bean.HMMHelper; impor ...

  7. vs2017 mvc 启动时经常出现调用的目标发生异常

    1.vs  2017 调试web 程序时老是出现调用的目标发生异常 本人眼拙,基本上看了网站说的一些方法,设置环境变量是无效的,只有一个办法,卸载重装. 1.0 卸载过程 打开计算机-卸载或更改软件- ...

  8. python操作 windows 锁屏与锁屏状态判断

    pip install ctypes from ctypes import * while True: u = windll.LoadLibrary('user32.dll') result = u. ...

  9. JAVA笔记19-容器之三 Set接口、List接口、Collections类、Comparable接口(重要)

    一.Set接口 //HashSet综合举例 import java.util.*; public class Test{ public static void main(String[] args){ ...

  10. 【清华集训2014】mex

    题目 有一个长度为n的数组{a1,a2,...,an}.m次询问,每次询问一个区间内最小没有出现过的自然数. 分析 显然,当\(a_i>n\)时,对答案没有影响,所以全部视为n+1. 有两种方法 ...