[读书日志]从零开始学习Chisel 第四篇:Scala面向对象编程——操作符即方法(敏捷硬件开发语言Chisel与数字系统设计)
3.2操作符即方法
3.2.1操作符在Scala中的解释
在其它语言中,定义了一些基本的类型,但这些类型并不是我们在面向对象中所说的类。比如说1,这是一个int类型常量,但不能说它是int类型的对象。针对这些数据类型,存在一些基本操作符,比如算数操作符“+”。Scala所追求的是极致的面向对象,因此Scala其实定义了 class Byte
、class Shor
t等等9个值类,但他们是不可继承的,抽象的,不能通过new创建一个Int对象,也不能编写他们的子类。
严格来说,Scala不存在操作符的概念,这些算术运算的加减乘除,逻辑运算的与或非,比较运算的大于小于等,其实都是定义在class Int
、class Double
中的成员方法。在Scala中,操作符即方法。在Scala中,表达式1+2的真正形式是1.+(2)
也就是说,调用了Int类的“+”方法,对象2是一个传入的参数,最后返回一个对象3。
操作符即方法的概念不仅仅限于9种值类的操作符,Scala种任何类定义的成员方法都是操作符,且方法调用都能写成操作符的形式:去掉句点符号,并且在方法参数只有一个时可以省略括号。
在书中给出的代码是这样的:
scala> class Students3(val name: String,var score: Int) {| def exam(s:Int) = score = s| def friends(n:String,s:Int) = println("My friend " + n + " gets " + s + ".")| override def toString = name + "'s score is " + score + "."| }
// defined class Students3
scala> val stu3 = new Students3("Alice",80)
val stu3: Students3 = Alice's score is 80.
scala> stu3 exam 100
1 warning found
-- Warning: ------------------------------------------------------------------------------------------------------------
1 |stu3 exam 100| ^^^^| Alphanumeric method exam is not declared infix; it should not be used as infix operator.| Instead, use method syntax .exam(...) or backticked identifier `exam`.
但在最新版Scala中直接调用会报错,这是因为新版Scala对于这个使用方法进行了约束,有3种解决方案:解决方法
方法 1:使用标准方法调用语法
将代码修改为标准的点号方法调用:
stu3.exam(100)
方法 2:使用反引号
如果希望继续使用中缀调用,则可以用反引号标记方法:
stu3 `exam` 100
方法 3:定义方法为 @infix
(推荐)
如果希望以中缀形式调用 exam
,可以在方法定义上添加 @infix
注解。例如:
import scala.annotation.infix
class Student {@infixdef exam(score: Int): Unit = {println(s"Score: $score")}
}
然后即可使用:
stu3 exam 100
3.2.2三种操作符
前缀操作符
只有“+,-,!,~”这四个,他们的操作数只有1个。可以创建一个类,在其中自定义这些方法,要求命名的格式类似于“unary_+”,如果末尾操作符在这四个以外,则不能使用这样的方法调用:
scala> class MyInt(val x:Int) {| def unary_! = -x| def unary_* = x * 2| }
// defined class MyInt
scala> val mi = new MyInt(10)
val mi: MyInt = MyInt@4df13dd0
scala> !mi
val res1: Int = -10
scala> *mi
*mi在这里是无法调用的,无法输出结果,必须以下面的形式调用:
scala> mi.unary_*
val res2: Int = 20
中缀操作符
中缀操作符左右两边都接收操作数,它对应普通的有参方法。两个操作数中的一个是调用该方法的对象,一个是传入该方法的参数,参数没有数量限制,只不过多个参数需要放在圆括号中。规定以冒号:结尾的操作符,其右操作数是调用该方法的对象,其余的操作数的左操作数是调用该方法的对象。
scala> class MyInt2(val x:Int) {| def +*(y:Int) = (x + y) * y| def +:(y:Int) = x + y| }
// defined class MyInt2
scala> val mi2 = new MyInt2(10)
val mi2: MyInt2 = MyInt2@6bf54260
scala> mi2 +* 10
val res3: Int = 200
scala> mi2 +: 10
-- [E008] Not Found Error: ---------------------------------------------------------------------------------------------
1 |mi2 +: 10| ^^^^^| value +: is not a member of Int
1 error found
scala> 10 +: mi2
val res4: Int = 20
后缀操作符
写在操作数后面的操作符称为后缀操作符,并且操作数只有一个,即调用该方法的对象。如果方法名构成前缀操作符的条件,那么既可以写成前缀操作符,又可以把完整的方法名写成后缀操作符。
scala> class MyInt3(val x:Int) {| def display() = println("the value is " + x + ".")| }
// defined class MyInt3
scala> val mi3 = new MyInt3(10)
val mi3: MyInt3 = MyInt3@1aee6d14
scala> import scala.language.postfixOps
scala> mi3.display()
the value is 10.
3.2.3操作符的优先级和结合性
优先级
可以通过方法名的首个字符比较优先级,前缀操作符的方法名要去掉关键字。圆括号优先级是最高的。下表从高到低列出了字符的优先级:
首个字符 |
---|
所有其他字符(最高) |
*/% |
+- |
: |
=! |
<> |
& |
^ |
| |
所有字母 |
所有赋值操作符(最低) |
这个规则有一个例外,就是如果操作符以等号结尾,并且不是<=,>=,==,!=,那么就认为是赋值运算符,优先级最低。比如sum*=1+2
,优先级是+更高。
结合性
一般情况下同级的操作符都是从左往右结合的,但是以冒号结尾的中缀操作符的调用对象在右侧,所以这些操作符是从右往左结合的。
3.2.4预设操作符
Scala预设了常用的算术运算、逻辑运算的操作符,如下图所示:
3.2.5对象的相等性
相等性可以分为两种,一种是自然相等性,一种是引用相等性。
自然相等性就是我们常见的相等性,只要字面上的值相等,就认为两个对象相等。引用相等性用于比较两个变量是否引用了同一个对象,即是否指向JVM堆中的同一个内存空间。Scala种==和!=只用来比较自然相等性,引用相等性可以使用eq
和ne
方法,它们是被所有类隐式继承的,且不可被子类重写。
相关文章:

[读书日志]从零开始学习Chisel 第四篇:Scala面向对象编程——操作符即方法(敏捷硬件开发语言Chisel与数字系统设计)
3.2操作符即方法 3.2.1操作符在Scala中的解释 在其它语言中,定义了一些基本的类型,但这些类型并不是我们在面向对象中所说的类。比如说1,这是一个int类型常量,但不能说它是int类型的对象。针对这些数据类型,存在一些…...
三子棋游戏
目录 1.创建项目 2.主函数编写 3.菜单函数编写 4.宏定义棋盘行和列 5.棋盘初始化 6.打印棋盘 7.玩家下棋 8.电脑下棋 9.平局判断 10.输赢判断 11.game函数 三子棋游戏(通过改变宏定义可以变成五子棋),玩家与电脑下棋 1.创建项目…...

MyBatis执行一条sql语句的流程(源码解析)
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 MyBatis执行一条sql语句的流程(源码解析) MyBatis执行sql语句的流程加载配置文件加载配置文件的流程 创建sqlsessionFactory对象解析Mapper创建sqlses…...

【电机控制】低通滤波器及系数配置
【电机控制】低通滤波器及系数配置 文章目录 [TOC](文章目录) 前言一、低通滤波器原理二、理论计算三、代码四、参考资料总结 前言 提示:以下是本篇文章正文内容,下面案例可供参考 一、低通滤波器原理 二、理论计算 三、代码 //低通滤波 pv->Ealpha…...
ArcgisServer过了元旦忽然用不了了?许可过期
昨天过完元旦之后上班发现好多ArcgisServer的站点运行出错了,点击日志发现,说是许可过去,也就是当时安装ArcgisServer时读取的ecp文件过期了,需要重新读取。 解决方法 1.临时方法,修改系统时间,早于2024年…...

如何在不丢失数据的情况下从 IOS 14 回滚到 IOS 13
您是否后悔在 iPhone、iPad 或 iPod touch 上安装 iOS 14?如果你这样做,你并不孤单。许多升级到 iOS 14 beta 的 iPhone、iPad 和 iPod touch 用户不再适应它。 如果您在正式发布日期之前升级到 iOS 14 以享受其功能,但您不再适应 iOS 14&am…...
【算法刷题】链表
文章目录 环形链表判断是否有环找出环的入口位置 双指针反转链表(Reverse a Linked List)移除链表中的指定元素(Remove Linked List Elements) 环形链表 判断是否有环 环形链表是指链表中的某些节点的 next 指针指向了链表中的某…...

计算机网络 —— 网络编程实操(1)(UDP)
计算机网络 —— 网络编程实操(UDP) 套接字端口套接字的定义为什么需要套接字? 套接字的分类1. 按照通信协议分类2. 按照地址族(Address Family)分类3. 按照通信模式分类 socket APIsockaddr结构 使用接口套接字初始化…...
selenium 确保页面完全加载
在使用Python和Selenium进行Web自动化时,确保页面完全加载是非常重要的。为了实现这一点,Selenium提供了两种主要类型的等待:显式等待(Explicit Waits)和隐式等待(Implicit Waits)。此外&#x…...

[极客大挑战 2019]HardSQL 1
看了大佬的wp,没用字典爆破,手动试出来的,屏蔽了常用的关键字,例如:order select union and 最搞的是,空格也有,这个空格后面让我看了好久,该在哪里加括号。 先传入1’ 1试试&#…...

vip与haproxy构建nginx高可用集群传递客户端真实ip
问题 系统使用了vip与haproxy实现高可用以及对nginx进行负载均衡,但是发现在上游的应用服务无法拿到客户端的请求ip地址,拿到的是主haproxy机器的ip,以下是nginx与haproxy的缩减配置: location ~* ^/(xx|xx) {proxy_pass http:/…...
Easticsearch介绍|实战?
Elasticsearch 是一个分布式的、RESTful 风格的搜索和数据分析引擎,适用于各种用例,如日志分析、全文搜索、实时应用监控等。它设计用来处理大量数据,并且可以快速地提供相关的搜索结果。以下是一些 Elasticsearch 的实战应用场景以及如何在这…...
Python图形界面(GUI)Tkinter笔记(二十一):Messagebox信息提示功能控件
messagebox 就像是 tkinter 库里的一个好帮手,它能帮你弹出各种各样的消息框给用户看。这些消息框可以告诉用户很多东西,比如提示、警告或者错误信息之类的。在 tkinter 库里,messagebox 这个模块有很多不同的函数,每个函数都能弹出一种特定的消息框。用这些函数,开发者可…...

vue3+ts+element-plus 表单el-form取消回车默认提交
问题描述:在表单el-form中的el-input中按回车后,页面会刷新,url也会改变, 回车前: 回车后: 相关代码: 解决方法1:在 el-form 上阻止默认的 submit 事件,增加 submit.pre…...
Web Services 简介
Web Services 简介 1. 引言 Web Services 是一种基于网络的软件服务,它允许不同的应用程序在互联网上相互通信和交互。这种技术是基于开放的互联网标准,如HTTP、XML、SOAP和WSDL,使得不同平台和编程语言的应用程序能够轻松地实现互操作性。Web Services 的出现,极大地推动…...
Vue3苦逼的学习之路
从一名测试转战到全栈是否可以自学做到,很多朋友肯定会说不可能,或就算转了也是个一般水平,我很认同,毕竟没有经过各种项目的摧残,但是还是得踏足一下这个领域。所以今天和大家分享vue3中的相关内容,大佬勿…...

AcWing练习题:两点间的距离
给定两个点 P1 和 P2,其中 P1P1 的坐标为 (x1,y1),P2 的坐标为 (x2,y2),请你计算两点间的距离是多少。 distance√(x2−x1)^2(y2−y1)^2 输入格式 输入共两行,每行包含两个双精度浮点数 xi,yi,表示其中一个点的坐标…...

文献分享:RoarGraph——跨模态的最邻近查询
文章目录 1. \textbf{1. } 1. 导论 1.1. \textbf{1.1. } 1.1. 研究背景 1.2. \textbf{1.2. } 1.2. 本文的研究 1.3. \textbf{1.3. } 1.3. 有关工作 2. \textbf{2. } 2. 对 OOD \textbf{OOD} OOD负载的分析与验证 2.1. \textbf{2.1. } 2.1. 初步的背景及其验证 2.1.1. \textbf{2…...
故事可视化AI
i68,爱六八,链接你我他 StoryWeaver故事可视化 通过知识增强的角色定制技术,实现高质量的故事可视化论文链接:https://arxiv.org/pdf/2412.07375项目仓库:https://github.com/Aria-Zhangjl/StoryWeaver由厦门大学多媒体可信感知与高效计算教育部重点实验室和网易伏…...

【机器学习篇】从新手探寻到算法初窥:数据智慧的开启之门
文章目录 【机器学习篇】从新手探寻到算法初窥:数据智慧的开启之门前言一、什么是机器学习?二、机器学习的基本类型1. 监督学习(Supervised Learning)2. 无监督学习(Unsupervised Learning)3. 半监督学习&a…...

【Axure高保真原型】引导弹窗
今天和大家中分享引导弹窗的原型模板,载入页面后,会显示引导弹窗,适用于引导用户使用页面,点击完成后,会显示下一个引导弹窗,直至最后一个引导弹窗完成后进入首页。具体效果可以点击下方视频观看或打开下方…...

手游刚开服就被攻击怎么办?如何防御DDoS?
开服初期是手游最脆弱的阶段,极易成为DDoS攻击的目标。一旦遭遇攻击,可能导致服务器瘫痪、玩家流失,甚至造成巨大经济损失。本文为开发者提供一套简洁有效的应急与防御方案,帮助快速应对并构建长期防护体系。 一、遭遇攻击的紧急应…...

C++_核心编程_多态案例二-制作饮品
#include <iostream> #include <string> using namespace std;/*制作饮品的大致流程为:煮水 - 冲泡 - 倒入杯中 - 加入辅料 利用多态技术实现本案例,提供抽象制作饮品基类,提供子类制作咖啡和茶叶*//*基类*/ class AbstractDr…...

Vue3 + Element Plus + TypeScript中el-transfer穿梭框组件使用详解及示例
使用详解 Element Plus 的 el-transfer 组件是一个强大的穿梭框组件,常用于在两个集合之间进行数据转移,如权限分配、数据选择等场景。下面我将详细介绍其用法并提供一个完整示例。 核心特性与用法 基本属性 v-model:绑定右侧列表的值&…...
mongodb源码分析session执行handleRequest命令find过程
mongo/transport/service_state_machine.cpp已经分析startSession创建ASIOSession过程,并且验证connection是否超过限制ASIOSession和connection是循环接受客户端命令,把数据流转换成Message,状态转变流程是:State::Created 》 St…...
macOS多出来了:Google云端硬盘、YouTube、表格、幻灯片、Gmail、Google文档等应用
文章目录 问题现象问题原因解决办法 问题现象 macOS启动台(Launchpad)多出来了:Google云端硬盘、YouTube、表格、幻灯片、Gmail、Google文档等应用。 问题原因 很明显,都是Google家的办公全家桶。这些应用并不是通过独立安装的…...
Qt Http Server模块功能及架构
Qt Http Server 是 Qt 6.0 中引入的一个新模块,它提供了一个轻量级的 HTTP 服务器实现,主要用于构建基于 HTTP 的应用程序和服务。 功能介绍: 主要功能 HTTP服务器功能: 支持 HTTP/1.1 协议 简单的请求/响应处理模型 支持 GET…...
React---day11
14.4 react-redux第三方库 提供connect、thunk之类的函数 以获取一个banner数据为例子 store: 我们在使用异步的时候理应是要使用中间件的,但是configureStore 已经自动集成了 redux-thunk,注意action里面要返回函数 import { configureS…...

AI+无人机如何守护濒危物种?YOLOv8实现95%精准识别
【导读】 野生动物监测在理解和保护生态系统中发挥着至关重要的作用。然而,传统的野生动物观察方法往往耗时耗力、成本高昂且范围有限。无人机的出现为野生动物监测提供了有前景的替代方案,能够实现大范围覆盖并远程采集数据。尽管具备这些优势…...
scikit-learn机器学习
# 同时添加如下代码, 这样每次环境(kernel)启动的时候只要运行下方代码即可: # Also add the following code, # so that every time the environment (kernel) starts, # just run the following code: import sys sys.path.append(/home/aistudio/external-libraries)机…...