scala日常学习笔记--函数式方法来处理数据交互的问题(部分引用,笔记持续添加...)

Option: 解决null(空指针)问题
Either: 解决返回值不确定(返回两个值的其中一个)问题
Try: 解决函数可能会抛出异常问题

1、option

Option实际上有3个类型:Option、Some和None,Some和None都是Option的子类型,Some和None。Option表示可选的值,它的返回类型是 scala.Some或 scala.None 。Some代表返回有效数据,None代表返回空值。最常用的使用方式是把scala.Option。当作集合或单子(monad)使用,可以调用它的map、flatMap、filter或foreach方法
1)Option的多种赋值方式

val y: Option[String] = Option(null)
val x: Option[String] = Option("name")
val name: Option[String] = Some(" name  “)

2)在定义方法中返回Option类型的函数
该函数以String对象作为输入,如果String对象被正确转换为Int对象,返回Sone[Int];否则返回None:

def toInt(s: String): Option[Int] = {
     try { Some(Integer.parseInt(s.trim)) 
} catch { 
    case e : Exception => None 
	} 
}

3)在集合类中使用Option
假设有一个字符串列表,我们希望得到该列表中所有的整数,通过将toInt方法传入List对象的map方法中,将列表元素转换成Some或None值:

scala> val bag = List("1", "2", "foo", "4", "bar")
bag: List[String] = List(1, 2, foo, 4, bar)
//通过flatten将原来的Option对象列表转换为整数列表
//由于Option是一个含有一个元素或0个元素(None)的集合,故能做出该转换
scala> bag.map(toInt).flatten
res1: List[Int] = List(1, 2, 4)
//通过flatMap实现相同的转换
scala> bag.flatMap(toInt)
res2: List[Int] = List(1, 2, 4)
//通过collect方法实现同样的功能
scala> bag.map(toInt).collect{case Some(i) => i}
res12: List[Int] = List(1, 2, 4)

4)使用 getOrElse 方法获取实际的数据
这个方法包含一个参数,当Option为None时将返回传入的参数值。

scala> val upper = name map { _.trim } filter { _.length != 0 } map { _.toUpperCase }
upper: Option[String] = None

scala> println(upper getOrElse "-")
-

2、Either

程序设计中经常会有这样的需求,一个函数(或方法)在传入不同参数时会返回不同的值。返回值是两个不相关的类型,分别为: Left 和 Right 。惯例中我们一般认为 Left 包含错误或无效值, Right包含正确或有效值。
在Scala 2.10之前,Either/Right/Left类和Try/Success/Failure类是相似的效果。

def readfile(): Either[IOException, String] = try {
  Right("羊八井好帅 ^_^!")
} catch {
  case e: IOException => Left(e)
}

println(readfile match {
  case Right(msg) => msg
  case Left(e) => e.getMessage
})

1)除了使用match case方式来获取数据,我们还可以分别使用 .right.get 和 .left.get 方法,当然你需要使用 .isRight 或 .isLeft 先判断一下。Left或Right类型也有 filter, flatMap, foreach, get, getOrElse, map 方法,它们还有toOption, toSeq 方法,分别返回一个Option或Seq 。

3、Try

对于有可能抛出异常的操作。我们可以使用Try来包裹它,得到Try的子类Success或者Failure,如果计算成功,返回Success的实例,如果抛出异常,返回Failure并携带相关信息。

import scala.util.{Try, Success, Failure}

def divideBy(x: Int, y: Int): Try[Int] = {
  Try(x / y)
}

println(divideBy(1, 1).getOrElse(0)) // 1
println(divideBy(1, 0).getOrElse(0)) //0
divideBy(1, 1).foreach(println) // 1
divideBy(1, 0).foreach(println) // no print

divideBy(1, 0) match {
  case Success(i) => println(s"Success, value is: $i")
  case Failure(s) => println(s"Failed, message is: $s")
} 
//Failed, message is: java.lang.ArithmeticException: / by zero

2)打印文章
如果该方法返回成功,将打印/etc/passwd文件的内容;如果出现异常,将打印错误信息,java.io.FileNotFoundException: Foo.bar (No such file or directory)

def readTextFile(filename: String): Try[List[String]] = {
  Try(Source.fromFile(filename).getLines.toList)
}

val filename = "/etc/passwd"
readTextFile(filename) match {
  case Success(lines) => lines.foreach(println)
  case Failure(f) => println(f)
  }
}

部分转载链接:
https://blog.csdn.net/JasonDing1354/article/details/46822417
https://www.yangbajing.me/2013/02/16/Option-Either-Try/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
目标检测(Object Detection)是计算机视觉领域的一个核心问题,其主要任务是找出图像中所有感兴趣的目标(物体),并确定它们的类别和位置。以下是对目标检测的详细阐述: 一、基本概念 目标检测的任务是解决“在哪里?是什么?”的问题,即定位出图像中目标的位置并识别出目标的类别。由于各类物体具有不同的外观、形状和姿态,加上成像时光照、遮挡等因素的干扰,目标检测一直是计算机视觉领域最具挑战性的任务之一。 二、核心问题 目标检测涉及以下几个核心问题: 分类问题:判断图像中的目标属于哪个类别。 定位问题:确定目标在图像中的具体位置。 大小问题:目标可能具有不同的大小。 形状问题:目标可能具有不同的形状。 三、算法分类 基于深度学习的目标检测算法主要分为两大类: Two-stage算法:先进行区域生成(Region Proposal),生成有可能包含待检物体的预选框(Region Proposal),再通过卷积神经网络进行样本分类。常见的Two-stage算法包括R-CNN、Fast R-CNN、Faster R-CNN等。 One-stage算法:不用生成区域提议,直接在网络中提取特征来预测物体分类和位置。常见的One-stage算法包括YOLO系列(YOLOv1、YOLOv2、YOLOv3、YOLOv4、YOLOv5等)、SSD和RetinaNet等。 四、算法原理 以YOLO系列为例,YOLO将目标检测视为回归问题,将输入图像一次性划分为多个区域,直接在输出层预测边界框和类别概率。YOLO采用卷积网络来提取特征,使用全连接层来得到预测值。其网络结构通常包含多个卷积层和全连接层,通过卷积层提取图像特征,通过全连接层输出预测结果。 五、应用领域 目标检测技术已经广泛应用于各个领域,为人们的生活带来了极大的便利。以下是一些主要的应用领域: 安全监控:在商场、银行
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值