zoukankan      html  css  js  c++  java
  • Scala 函数入门之过程、lazy值和异常

    Scala 过程 

    Scala中,定义函数时,如果函数体直接包裹在了花括号里面,而没有使用=连接,则函数的返回值类型就是Unit。这样的函数就被称之为过程。过程通常用于不需要返回值的函数。

    过程还有一种写法,就是将函数的返回值类型定义为Unit

    def sayHello(name: String) = "Hello, " + name

    def sayHello(name: String) { print("Hello, " + name); "Hello, " + name }

    def sayHello(name: String): Unit = "Hello, " + name

     lazy

    Scala中,提供了lazy值的特性,也就是说,如果将一个变量声明为lazy,则只有在第一次使用该变量时,变量对应的表达式才会发生计算。这种特性对于特别耗时的计算操作特别有用,比如打开文件进行IO,进行网络IO等。

    import scala.io.Source._

    lazy val lines = fromFile("C://Users//Administrator//Desktop//test.txt").mkString

    即使文件不存在,也不会报错,只有第一个使用变量时会报错,证明了表达式计算的lazy特性。

    val lines = fromFile("C://Users//Administrator//Desktop//test.txt").mkString

    lazy val lines = fromFile("C://Users//Administrator//Desktop//test.txt").mkString

    def lines = fromFile("C://Users//Administrator//Desktop//test.txt").mkString

    异常

    Scala中,异常处理和捕获机制与Java是非常相似的。

    try {

      throw new IllegalArgumentException("x should not be negative")

    } catch {

      case _: IllegalArgumentException => println("Illegal Argument!")

    } finally {

      print("release resources!")

    }

    try {

      throw new IOException("user defined exception")

    } catch {

      case e1: IllegalArgumentException => println("illegal argument")

      case e2: IOException => println("io exception")

    }

  • 相关阅读:
    10 给予scrapy-redis的分布式爬虫
    pandas 01 序列和数据库昂
    如何控制分布式爬虫结束
    动态导入模块
    docker
    09 scrapy中间件
    scrapy 获取settings中的内容
    session对象的cookies
    文本检测-1-MSER
    CTW1500数据集介绍
  • 原文地址:https://www.cnblogs.com/YuanWeiBlogger/p/11415539.html
Copyright © 2011-2022 走看看