视图界定的介绍应用实例1 | 学习笔记

简介: 快速学习视图界定的介绍应用实例1

开发者学堂课程【Scala 核心编程 - 进阶视图界定的介绍应用实例1学习笔记,与课程紧密连接,让用户快速学习知识。

课程地址https://developer.aliyun.com/learning/course/610/detail/9155


视图界定的介绍应用实例1


内容介绍

一、视图界定基本介绍

二.视图界定应用案例1


视图界定基本介绍

视图界定仍然属于类型约束的一种,叫view bounds。

% 的意思是“view bounds”(视界),它比<:适用的范围更广,除了所有的子类型,还允许隐式转换类型。

可以这么理解:

在进行上界传入的时候,隐式转换也会生效。这个语法现象就比较多样化了,这就是为什么最终scala有些初学者学完了之后看不懂了。

def method [A<%Bl(arglist): R=….等价于:

def method [A](arglist)(implicit viewAB: A => B): R=.…或等价于:

implicit def conver(a:A): B = ...

method方法a是一个泛型,图界定B。后面有个arglilst,它等价于下面的两种写法。大家可能现在看不懂,那么就案例完了后再回头看

% 除了方法使用之外,class 声明类型参数时也可使用: class A[T <% Int]

视图界定除了方法之外还可以使用在的声明和参数中也能用,如果是类里面要用就是这样用的,这是泛型视图界定int。


二.视图界定应用案例1

obiect ViewBoundsDemo{

def main(args:Array[String]):Unit={

//方式1val compareComm1=newCompareComm(2030) printin(compareComm1.greater)

//同时,也支持前面学习过的上界使用的各种方式.看后面代码

}

}

class CompareComm[T <% Comparable[T]](obj1: Tobj2: T){

def greater =if(obj1.compareTo(obj2)>0)obj1 else obj2

}

还用比较Int和float的大小来讲这里 compare common试图界定comparable T

Comparable是一个接口,那么就可以用它的compare方法,最起码唯一变化就在这里,那么当写的东西写成数据鉴定过后发现,直接传的整数可以直接用了,而以前是不行的。

先来建个包:

image.png

image.png

package com.atguigu.chapter18.viewbounds

object viewBoundsDemo01 {

def main(args: Array[string]): Unit = {

//使用了隐式转换

val compareComm01=newCompareComm(1,20)

printin(compareComme1.greater)

}

}

//说明

//1. T<%Comparable[T]说明 T是Comparable子类型

//2. T<% Comparable[T] 和 T<:Comparable[T]区别就是视图界定支持隐式转换

//3. 视图界定不但支持以前上界的写法,同时支持简洁的写法

class CompareComm[T <% Comparable[T]](obj1:T,obj2:T){

def greater = if(obj1.compareTo(obj2) > 0) obj1 else obj2

}

点击运行:

image.png

为什么会成功?

原因是使用了隐式转换。那么隐式转换在哪里发生?视图界定会发生一个隐式转换,就是会在进行传int的时候会直接调用。

不用写他就会去找到一个这样的方法,这是它的一个使用,而且在看这段代码之前写的转换,是有这种写法val compareComm2 =new CompareCommlntegervalueOf20)IntegervalueOf30) printin(compareComm2.greater)

//以前<:上界val compareComm4 =new CompareCommjava lang Float(201.9f30.1f) printin(compareComm4.greater)

//上面的小数比较,在视图界定的情况下,就可以这样写了

//这里会进行隐式转换

val compareComm5=

new CompareComm(201.9f310.1f )

printin(compareComm5.qreater)

点击运行:

image.png

成功。

这就是视图界定案例1的讲解。

相关文章
|
3天前
|
数据采集 人工智能 安全
|
13天前
|
云安全 监控 安全
|
4天前
|
自然语言处理 API
万相 Wan2.6 全新升级发布!人人都能当导演的时代来了
通义万相2.6全新升级,支持文生图、图生视频、文生视频,打造电影级创作体验。智能分镜、角色扮演、音画同步,让创意一键成片,大众也能轻松制作高质量短视频。
1085 152
|
18天前
|
机器学习/深度学习 人工智能 自然语言处理
Z-Image:冲击体验上限的下一代图像生成模型
通义实验室推出全新文生图模型Z-Image,以6B参数实现“快、稳、轻、准”突破。Turbo版本仅需8步亚秒级生成,支持16GB显存设备,中英双语理解与文字渲染尤为出色,真实感和美学表现媲美国际顶尖模型,被誉为“最值得关注的开源生图模型之一”。
1751 9
|
9天前
|
人工智能 自然语言处理 API
一句话生成拓扑图!AI+Draw.io 封神开源组合,工具让你的效率爆炸
一句话生成拓扑图!next-ai-draw-io 结合 AI 与 Draw.io,通过自然语言秒出架构图,支持私有部署、免费大模型接口,彻底解放生产力,绘图效率直接爆炸。
694 152
|
11天前
|
人工智能 安全 前端开发
AgentScope Java v1.0 发布,让 Java 开发者轻松构建企业级 Agentic 应用
AgentScope 重磅发布 Java 版本,拥抱企业开发主流技术栈。
660 14
|
6天前
|
SQL 自然语言处理 调度
Agent Skills 的一次工程实践
**本文采用 Agent Skills 实现整体智能体**,开发框架采用 AgentScope,模型使用 **qwen3-max**。Agent Skills 是 Anthropic 新推出的一种有别于mcp server的一种开发方式,用于为 AI **引入可共享的专业技能**。经验封装到**可发现、可复用的能力单元**中,每个技能以文件夹形式存在,包含特定任务的指导性说明(SKILL.md 文件)、脚本代码和资源等 。大模型可以根据需要动态加载这些技能,从而扩展自身的功能。目前不少国内外的一些框架也开始支持此种的开发方式,详细介绍如下。
438 5