zoukankan      html  css  js  c++  java
  • Scala:(三) 字符串、集合(Array、List、Set、Map)、元组(tuple)

    本文意在精简,掌握最常用的,最基本的用法,不断完善,一招鲜而吃遍天

    字符串

    在 Scala 中,字符串的类型实际上是 Java String,它本身没有 String 类,定义一个string类,其类型就是 String (java.lang.String)。
    在 Scala 中,String 是一个不可变的对象,所以该对象不可被修改。这就意味着你如果修改字符串就会产生一个新的字符串对象。

    由于scala中的String类和Java中的是同一个,所以其自带方法是相同的。常用方法如下所示:
    常用string自带方法

    返回值 方法 注释
    String concat(String str) 将指定字符串连接到此字符串的结尾
    boolean contentEquals(StringBuffer sb) 将此字符串与指定的 StringBuffer 比较。
    boolean endsWith(String suffix) 测试此字符串是否以指定的后缀结束 ,同理还有startsWith
    boolean equals(Object anObject) 将此字符串与指定的对象比较
    boolean equalsIgnoreCase(String anotherString) 将此 String 与另一个 String 比较,不考虑大小写
    int indexOf(String str, int fromIndex) 返回指定子字符串在此字符串中第一次出现处的索引,从指定的索引开始,后一个参数可为空
    int length() 返回此字符串的长度
    boolean matches(String regex) 告知此字符串是否匹配给定的正则表达式
    String replace(char oldChar, char newChar) 返回一个新的字符串,它是通过用 newChar 替换此字符串中出现的所有 oldChar 得到的
    String replaceAll(String regex, String replacement) 使用给定的 replacement 替换此字符串所有匹配给定的正则表达式的子字符串
    String[] split(String regex) 根据给定正则表达式的匹配拆分此字符串
    String substring(int beginIndex, int endIndex) 返回一个新的字符串,它是此字符串的一个子字符串,后一个参数可为空
    String toLowerCase() 使用默认语言环境的规则将此 String 中的所有字符都转换为小写
    String toUpperCase() 使用默认语言环境的规则将此 String 中的所有字符都转换为大写
    String toUpperCase(Locale locale) 使用给定 Locale 的规则将此 String 中的所有字符都转换为大写
    String trim() 删除指定字符串的首尾空白符
    string String.valueOf(x) 返回指定类型参数的字符串表示形式
    ... ... 其他方法在此不一一列举
    StringBuilder

    集合


    scala的集合设计,整体上分为三大类,所有的集合都扩展自Iterable特质:

    1. Seq,序列。是一组有序的元素。 诸如Array,List
    2. Set,集。 是一组无序的,没有重复元素的集合。 诸如:
    3. Map,映射。是一组k-v对。key不可重复 诸如:

    在Scala中集合有可变(mutable)和不可变(immutable)两种类型,immutable类型的集合初始化后就不能改变了(注意与val修饰的变量进行区别)

    Array

    Scala 语言中提供的数组是用来存储固定大小的同类型元素,数组中某个指定的元素是通过索引来访问的,元素索引从0开始。
    创建数组

    // 创建数组有两种方式:
    // 1. 直接new Array[Int](3) 此种是定长数组,括号内必须填长度
    val array1 = new Array[Int](2)
        array1(0) = 1
        array1(1) = 1
        array1(2) = 1 //此行会报错,因为创建的是定长的数组,只有两个元素
    // 2.  创建Int类型的数组,直接赋值
    val array2=Array[Int](1,2,3)
    

    如要看到数组里的全部内容,除了遍历外,还可以使用toBuffer

    其实也可不加泛型

    数组的遍历

    // 遍历的两种方式
    //直接for循环
        for(i <- array2){
          println(i)
        }
        // foreach
        array2.foreach(i => {
          println(i)
        })
    


    多维数组的定义和遍历

     val array3 = new Array[Array[String]](2)
        array3(0)=Array("1","2")
        array3(1)=Array("4","5")
        for(i <- 0 until array3.length){
          for(j <- 0 until array3(i).length){
            print(array3(i)(j)+"	")
          }
          println()
        }
    
        array3.foreach(i =>{
          println(i.toBuffer)
          i.foreach(j => {
            println(j)
          })
        })
    


    数组的常用方法

    数组结合yield 或者 map,filter等使用(map filter等的用法,详见函数与方法一章)


    数组求求和,最大最小值,排序

    拉链操作

    注意:拉链操作是将两个序列组合到一起,若两者长度不同,则生成的长度为较短的那个序列的长度

    序列

    Scala的集合有三大类:序列Seq、集Set、映射Map,所有的集合都扩展自Iterable特质
    在Scala中集合有可变(mutable)和不可变(immutable)两种类型,immutable类型的集合初始化后就不能改变了(注意与val修饰的变量进行区别)

    不可变序列

    不可变的序列 import scala.collection.immutable._
    在Scala中列表要么为空(Nil表示空列表)要么是一个head元素加上一个tail列表。
    List可添加元素,但添加元素后返回的其实是一个新的list

    可变序列

    可变的序列 import scala.collection.mutable._
    ListBuffer可添加元素,但返回的其实还是原来那个listBuffer
    类似于String和StringBuilder

    list的创建

    // 创建不可变序列
    val list1 = List(1,2,3,4,5)
    

    list的遍历

     // for
      val list = List(1,2,3,4,5)
        for(x <- list){
          print(x)
        }
      // foreach
     list.foreach { x => println(x)}
    

    可变序列的创建及元素增减
    如下也可

    //构建一个可变列表,初始有3个元素1,2,3
      val list = ListBuffer[Int](1,2,3)
    
    /创建一个空的可变列表
      val lst1 = new ListBuffer[Int]
      //向lst1中追加元素,注意:没有生成新的集合
      lst1 += 4
      lst1.append(5)
    
      //将lst1中的元素最近到lst0中, 注意:没有生成新的集合
      lst0 ++= lst1
    
      //将lst0和lst1合并成一个新的ListBuffer 注意:生成了一个集合
      val lst2= lst0 ++ lst1
    
      //将元素追加到lst0的后面生成一个新的集合
      val lst3 = lst0 :+ 5
    
    

    list的常用方法
    注意:list是可以添加元素的,但其实list是一个不可变序列,其添加后返回的是一个新的集合

    # :: 操作符是将给定的头和尾创建一个新的列表,:: 操作符是右结合的,如9 :: 5 :: 2 :: Nil相当于 9 :: (5 :: (2 :: Nil))
    
        //将0插入到lst1的前面生成一个新的List
        val list2 = 0 :: list1
        val list3 = list1.::(0)
        val list4 = 0 +: list1
        val list5 = list1.+:(0)
    
        //将一个元素添加到lst1的后面产生一个新的集合
        val list6 = list1 :+ 3
    
        val list0 = List(4,5,6)
        //将2个list合并成一个新的List
        val list7 = list1 ++ list0
        //将lst1插入到lst0前面生成一个新的集合
        val list8 = list1 ++: list0
    
        //将lst0插入到lst1前面生成一个新的集合
        val list9 = list1.:::(list0)
        
        // count,map,filter函数
        //filter
        val list1  = list.filter { x => x>3 }
        list1.foreach { println}
        
        //count
        val value = list1.count { x => x>3 }
        println(value)
        
        //map
        val nameList = List(
        		"hello beijing",
        		"hello shanghai",
        		"hello shenzhen"
            )
        val mapResult:List[Array[String]] = nameList.map{ x => x.split(" ") }
        mapResult.foreach{println}    
        
        //flatmap
        val flatMapResult : List[String] = nameList.flatMap{ x => x.split(" ") }
        flatMapResult.foreach { println }
    

    Set

    同样的,对于set,同样分为可变Set和不可变Set,set会自动去重
    set的创建和遍历

    // 不可变set
    import scala.collection.immutable.HashSet
     val set1 = new HashSet[Int]()
      //将元素和set1合并生成一个新的set,原有set不变
      val set2 = set1 + 4
      //set中元素不能重复
      val set3 = set1 ++ Set(5, 6, 7)
      val set0 = Set(1,3,4) ++ set1
      println(set0.getClass)
    
    // 可变set
    import scala.collection.mutable
     //创建一个可变的HashSet
      val set1 = new mutable.HashSet[Int]()
      //向HashSet中添加元素
      set1 += 2
      //add等价于+=
      set1.add(4)
      set1 ++= Set(1,3,5)
      println(set1)
      //删除一个元素
      set1 -= 5
      set1.remove(2)
      println(set1)
    

    set的遍历

        val set1 = Set(1,2,3,4,4) //set会自动去重
        val set2 = Set(1,2,5)
      // set 的遍历
      //foreach方式
      set1.foreach { println}
      //for循环的方式
       for(s <- set1){
          println(s)
        }
    

    set的常用方法
    最大最小count,交并差集,转化为list转化为string

      //set的交并差集,对于非Set集合,在做交集、并集、差集时必须转换为Set,否则元素不去重没有意义,对于非Set类型集合元素去重,可用distinct
      //交集
      val set3 = set1.intersect(set2)
      val set4 = set1.&(set2)
      //并集
      Set(1,2,3) ++ Set(2,4)
      Set(1,2,3) | Set(2,4)   // |方法等同于union方法
      Set(1,2,3) union Set(2,4)
      //差集
      set1.diff(set2).foreach { println }
      set1.&~(set2).foreach { println }
      //子集
      set1.subsetOf(set2)
    

    Map

    map是key-value的结构,其key不可重复,如key重复的话,前面对应的value会被后面的替换掉(还是挺实用的)
    map的创建

      Map(1 -> "hello")
      Map(2,"world")
     //如下可以看到,map的初始化还是挺灵活的
    val map = Map(
         "1" -> "hello",
          2 -> "world",
          (3,"scala")
    )
    

    map的遍历和取值

    map.get(“1”) 返回some(hello),是否有值
    map.get(“1”).get返回hello,具体值
    map.get(4).getOrElse(“no value”):如果map中没有对应项,赋值为getOrElse传的值。
    遍历仍是for 和foreach两种方式

      //map遍历
        for(x <- map){
          println("key:"+x._1+",  value:"+x._2)
        }
    
        map.foreach(f => {
          println("key:"+ f._1+",  value:"+f._2)
        })
    
      //遍历key和value
      //遍历key
        val keyIterable = map.keys
        keyIterable.foreach { key => {
          println("key:"+key+", value:"+map.get(key).get)
        } }
      //遍历values
        val valueIterable = map.values
        valueIterable.foreach { value => {
          println("value: "+ value)
        } }
    

    map的常用方法

      // map的合并,合并后相同key的value会被覆盖掉
      map1.++(map2)    // map1中加入map2
      map1.++:(map2)   // map2中加入map1
      //map的filter过滤
       map.filter(_._2.equals("shsxt")).foreach(println)
      //map的count方法
       val count1  = map.count(p => {
          p._2.equals("scala")   //第二个元素是否是scala,返回个数【map的value是可重复】
        })
      //map是否包含某个key
      map.contains(2)
      //判断map中符合条件的记录是否存在
      println(map.exists(x =>{
          x._2.equals("scala")
        }))
    

    元组 tuple

    scala tuple与列表类似,也是不可变的,但与列表不同的是元组可以包含不同类型的元素。
    元组的值是通过将单个的值包含在圆括号中构成的,目前 Scala 支持的元组最大长度为 22。对于更大长度你可以使用集合,或者扩展元组。
    tuple也是不可变的,有句话形容tuple很合适,那就是 身有残疾的只读列表 。
    tuple的创建

      val  tuple = new Tuple(1)
      val tuple2  = Tuple2(1,2)
      val tuple3 = Tuple3(1,2,3)
      // 最大支持到tuple22
    

    tuple的遍历和取值

      // tuple.productIterator得到迭代器,进而遍历
      val tupleIterator = tuple10.productIterator
        while(tupleIterator.hasNext){
          println(tupleIterator.next())
        }
      //tuple的取值,使用._XX来获取值
      val tuple2tuple2 = Tuple2((1,2),("hello","scala"))
      println(tuple2tuple2._1._2)
    

    tuple的常用方法

      // swap元素翻转,只针对tuple2
      tuple2.swap
      //toString  终于有个支持tostring的了
      println(tuple3.toString())
    

  • 相关阅读:
    Appium问题解决方案(2)- AttributeError:module 'appium.webdriver' has no attribute 'Remote'
    Azure Messaging-ServiceBus Messaging消息队列技术系列8-服务总线配额
    Azure Messaging-ServiceBus Messaging消息队列技术系列7-消息事务
    Azure Messaging-ServiceBus Messaging消息队列技术系列6-消息回执
    Azure Messaging-ServiceBus Messaging消息队列技术系列5-重复消息:at-least-once at-most-once
    Azure Messaging-ServiceBus Messaging消息队列技术系列4-复杂对象消息是否需要支持序列化和消息持久化
    Azure Messaging-ServiceBus Messaging消息队列技术系列3-消息顺序保证
    [博客迁移]探索Windows Azure 监控和自动伸缩系列3
    [博客迁移]探索Windows Azure 监控和自动伸缩系列2
    [博客迁移]探索Windows Azure 监控和自动伸缩系列1
  • 原文地址:https://www.cnblogs.com/missedyou/p/13276729.html
Copyright © 2011-2022 走看看