当前位置: 首页 > news >正文

网站备案授权视频网站是怎么做的

网站备案授权,视频网站是怎么做的,如何说服别人做网站,龙岗商城网站建设10. 隐式转换与隐式参数 假设编写了一个向量类MyVector,并且包含一些向量的基本操作。因为向量可以与标量做数乘运算,所以需要一个计算数乘的方法“*”,它应该接收一个类型为基本值类的参数,在向量对象myVec调用该方法时&#xf…

10. 隐式转换与隐式参数

假设编写了一个向量类MyVector,并且包含一些向量的基本操作。因为向量可以与标量做数乘运算,所以需要一个计算数乘的方法“*”,它应该接收一个类型为基本值类的参数,在向量对象myVec调用该方法时,可以写成myVec * 2的形式。在数学中,反过来写2 * myVec也是可行的,但在程序中不行。操作符左边是调用对象,反过来写就表示Int对象2是方法的调用者,但是Int类中并没有这种方法。

为了解决上述问题,所有oop语言都会有相应的措施,C++采用友元,Scala采取名为隐式转换的策略,把原来的Int类对象2转换类型,变成MyVector类的对象,这样它就能使用数乘方法。隐式转换属于隐式定义的一种,它将程序员事先写好的定义,允许编译器隐式地插入这些定义来解决类型错误。

10.1 隐式定义的规则

隐式定义有如下约束规则:

  1. 标记规则:只有用关键字implicit标记的定义才能被编译器隐式使用,任何函数,变量或单例对象都可以被标记。其中,标记为隐式的变量和单例对象常用作隐式参数。隐式的函数常用于隐式转换。比如x + y由于x类型错误不能通过编译,编译器会将代码改成convert(x) + y,其中convert是某种可用的隐式转换。如果convert能把x改成某种支持+方法的对象,那么这段代码就可以通过类型检查;
  2. 作用域规则:Scala编译器只会考虑当前作用域内的隐式定义,隐式定义在当前作用域必须是单个标记符,编译器不会展开成A.convert(x) + y的形式,有一个例外是编译器会在与隐式转换相关的源类型和目标类型的伴生对象中查找隐式定义,因此常在伴生对象中定义隐式转换,而不需要显式导入;
  3. 每次一个规则:编译器只会插入一个隐式定义,不会出现convert1(convert2(x)) + y这种嵌套的形式;
  4. 显式优先规则:如果显式定义能通过类型检查,就不必进行隐式转换。

Scala只会在三个地方使用隐式定义:转换到一个预期的类型,转换某个选择接收端,隐式参数。

10.2 隐式地转换到期望类型

Scala编译器对于类型检查比较严格,比如一个浮点数赋值给整数变量,人们可能希望通过截断小数部分完成赋值,但是Scala默认情况下不允许这种丢失精度的转换。可以定义一个隐式转换来完成:

scala> import scala.language.implicitConversionsscala> implicit def doubleToInt(x: Double) : Int = x.toInt
def doubleToInt(x: Double): Intscala> val i: Int = 1.5
val i: Int = 1scala> val i: Int = doubleToInt(2.33)
val i: Int = 2
10.3 隐式地转换接收端

接收端就是指调用方法或字段的对象,调用对象在非法的情况下,被隐式转换成了合法的对象,这是隐式转换最常用的地方。

scala> class MyInt(val i: Int)
// defined class MyIntscala> 1.i
-- [E008] Not Found Error: ---------------------------------------------------------------------------------------------
1 |1.i|^^^|value i is not a member of Int
1 error foundscala> implicit def intToMy(x: Int): MyInt = new MyInt(x)
def intToMy(x: Int): MyIntscala> 1.i
val res0: Int = 1

在定义隐式转换前,Int类没有i字段,所以调用会报错,定义隐式转换后,用一个Int对象构造了一个新的MyInt对象,而MyInt对象就有字段i。1.i被编译器隐式展开成intToMy(1).i

隐式转换因此经常用于模拟新的语法,比如Chisel中大量使用了隐式定义。

映射的键-值对语法键->值其实是一个对偶(键,值),也是隐式转换起作用。

10.4 隐式类

隐式类是一个以关键字implicit开头的类,用于简化富包装类的编写。它不能是样例类,并且主构造方法有且仅有一个参数。此外,隐式类只能位于某个单例对象、类或特质中,不能单独出现在顶层。隐式类的特点是让编译器在相同层次下自动生成一个与类名相同的隐式转换,该转换接受一个与隐式类的主构造方法相同的参数,并用这个参数构造一个隐式类的实例对象来返回。

10.5 隐式参数

函数的最后一个参数列表可以用关键字implicit声明为隐式的,这样整个参数列表的参数都是隐式参数。注意,是整个参数列表,即使括号中有多个参数,也只需要在开头写一个implicit,每个参数都是隐式的,不存在部分隐式部分显式。

当调用函数时,若缺省了隐式参数列表,则编译器尝试插入相应的隐式定义。也可以显式给出参数,但是必须全部缺省或者全部写出,不能只写出一部分。

要让编译器隐式插入参数,就必须实现定义好符合预期类型的隐式变量,隐式单例对象和隐式函数,这些隐式定义也必须用implicit修饰。隐式变量,单例对象,函数在当前作用域的引用必须满足单标识符原则,即不同层次之间需要用import解决。

隐式参数的类型应该是稀有或特定的,类型名称最好能表明该参数的作用,而不是使用Int,String等已经约定好的名称。

class PreferredPrompt(val preference: String)
class PreferredDrink(val preference: String)object Greeter {def greet(name: String)(implicit prompt: PreferredPrompt, drink: PreferredDrink) = {println("Welcome, " + name + ". The system is ready.")print("But while you work, ")println("why not enjoy a cup of " + drink.preference + "?")println(prompt.preference)}
}object JoesPrefs {implicit val prompt: PreferredPrompt = new PreferredPrompt("Yes, master> ")implicit val drink: PreferredDrink = new PreferredDrink("tea")
}

保存后执行编译指令,并进入解释器,执行命令:

jia@J-MateBookEGo:~/scala_test$ scalac test.scala
jia@J-MateBookEGo:~/scala_test$ scala
Jan 13, 2025 1:09:02 PM org.jline.utils.Log logr
Welcome to Scala 3.6.2 (21.0.5, Java OpenJDK 64-Bit Server VM).
Type in expressions for evaluation. Or try :help.scala> :load test.scala
// defined class PreferredPrompt
// defined class PreferredDrink
// defined object Greeter
// defined object JoesPrefsscala> Greeter.greet("Joe")
-- [E172] Type Error: --------------------------------------------------------------------------------------------------
1 |Greeter.greet("Joe")|                    ^|        No given instance of type PreferredPrompt was found for parameter prompt of method greet in object Greeter||        The following import might fix the problem:||          import JoesPrefs.prompt|
1 error foundscala> import JoesPrefs._scala> Greeter.greet("Joe")
Welcome, Joe. The system is ready.
But while you work, why not enjoy a cup of tea?
Yes, master>scala> Greeter.greet("Joe")(prompt, drink)
Welcome, Joe. The system is ready.
But while you work, why not enjoy a cup of tea?
Yes, master>
10.6 含有隐式参数的主构造方法

普通的函数可以含有隐式参数,类的主构造方法也可以包含隐式参数,辅助构造方法不允许出现隐式参数。假设类A仅有一个参数列表,并且该列表是隐式的,那么A的实际定义形式是A()(implicit 参数),也就是比字面上的代码多了一对空括号,无论用new实例化类A,还是被其他类继承,若调用主构造方法时显式地给出隐式参数,就必须写出这对空括号,若隐式参数是编译器自动插入,则空括号可有可无。

scala> class A(implicit val x: Int)
// defined class Ascala> val a = new A(1)
-- Error: --------------------------------------------------------------------------------------------------------------
1 |val a = new A(1)|              ^|              too many arguments for constructor A in class A: ()(implicit x: Int): A
1 error foundscala> val a = new A()(1)
val a: A = A@6caeba36scala> implicit val ORZ = 233
-- Error: --------------------------------------------------------------------------------------------------------------
1 |implicit val ORZ = 233|             ^|             type of implicit definition needs to be given explicitly
1 error foundscala> implicit val ORZ: Int = 233
val ORZ: Int = 233scala> val b = new A
val b: A = A@6a7aa675scala> b.x
val res0: Int = 233scala> val c = new A()
val c: A = A@1534bdc6scala> c.x
val res1: Int = 233

http://www.15wanjia.com/news/179658.html

相关文章:

  • 望野的翻译seo入门书籍推荐
  • 专业网站建设服务报价响应式网站模板 视差
  • 北苑网站建设公司wordpress xml-rpc
  • 红色logo做网站崇安网站建设
  • 网站管理 上传模板wordpress企业站主题
  • 建设一个网站要多少费用ie浏览器打开是2345网址导航
  • 国内外c2c网站有哪些汕头互联网公司
  • 阿里云备案 网站备案域名购买c 网站开发代码
  • 陕西网络公司网站建设怎么用阿里的域名 做网站
  • 学校让做网站做完怎么交安徽合肥
  • 广州做网站服务北京高端建
  • 中国循环经济网站开发与设计怎么才能百度做网站
  • 残联网站建设白酒进货渠道网
  • 自己建设一个平台网站多少钱亚马逊平台官网
  • 百度网站是怎么建设的深圳住房建设厅网站
  • 常用来做网站的首页做外贸需要什么样的网站
  • 做网站工作辛苦吗镇江网站建设
  • 单页网站制作程序贵阳优化网站建设
  • 企业网站模板2016成套网站建设淘宝模板
  • 建设拍卖网站成品软件源码网站大全
  • 微信公众平台官方采集站seo课程
  • 网站开发工程论坛国内新闻最新消息10条简短2021
  • 毕业设计 网站开发萝岗公司网站建设
  • 临湘市网站三角网站建设
  • 做网站公司东莞黄骅贴吧的最新消息
  • phpcmsv9网站建设入门教程凌河网站建设推广
  • 用心做的网站做社区网站怎么做
  • 攀枝花做网站安庆微信网站开发
  • 网站被js植入广告做网站需要什么认证
  • 做羞羞的网站装饰设计素描