scala中trait基本使用

(一)trait定义和作用

[讲] Scala没有Java中接口的概念,所以Scala的trait就类比Java中的接口。Scala的特质定义如下:

scala 复制代码
trait identified {  
    属性; 方法

}

trait是关键字,identified 表示一个合法的标记。

(二)实现单个特质

码\] 用一个类去实现单个特质 ```scala package level02 /* * 特质 * trait: 实现多继承 **/ object class16 { trait BeautifulEye { val eye: String = "眼睛漂亮" } trait Tall { val height: String = "大高个" } // 继承 with class Child extends BeautifulEye with Tall { } def main(args: Array[String]): Unit = { val child = new Child() println(child.eye) println(child.height) } } ``` #### (三)实现多个特质 格式:**类名 extends 特质1 with 特质2 with 特质3** 其中多个特质的顺序可以交换。 【代码示范】 定义两个特质,使用一个类来实现他们。 ```scala package level02 /* * 特质 * trait: 实现多继承 **/ object class16 { trait BeautifulEye { val eye: String = "眼睛漂亮" // 具体属性 val name:String // 抽象属性 } trait Tall { val height: String = "大高个" def run():Unit={ println("run......") } def jump():Unit } // 继承 with class Child extends BeautifulEye with Tall { val name :String="小花" def jump():Unit={ println(s"${name},jump.......") } } def main(args: Array[String]): Unit = { val child = new Child() println(child.eye) println(child.height) child.run() child.jump() } } ``` 结果如下: ![屏幕截图 2025-11-17 152703.png](https://oss.xyyzone.com/jishuzhan/article/1990332525433126914/86bdba20fb05c58c81b391de6f8f31c8.webp) #### (四)特质成员的处理方式 一个类继承了一个特质之后,如何处理它的属性和方法呢? 分成四种情况: 1.特质中的抽象属性:可以通过val或var修饰来重写 2.特质中的抽象方法:一定要实现方法体。 3.特质中的具体属性:重写var不需override和var,只需要属性名即可;重写val需要加上override关键字。 4.特质中的具体方法:使用override重写,且保持名称,参数,返回值一致。

相关推荐
渣渣盟3 天前
Flink实现TopN URL访问量统计
大数据·flink·scala
普通网友3 天前
探索Perl在ASIC中的应用:深入标量、数组和哈希的应用
scala·哈希算法·perl
zxfBdd17 天前
Error:scala: No ‘scala-library*.jar‘ in Scala compiler classpath in Scala SDK
大数据·scala·jar
SHeqSpMeS1 个月前
雷达信号处理:运动目标相参积累——Radon-Fourier算法,用于检测运动目标,实现距离和...
scala
小邓睡不饱耶1 个月前
使用Scala实现手机号码归属地查询系统
开发语言·windows·scala
强化实验室2 个月前
如何设计基于吖啶生物素,Acridinium-Biotin的高效生物检测体系?
flask·scala·pyqt·fastapi·web3.py
m0_748254662 个月前
Perl 变量类型
spark·scala·perl
是阿威啊2 个月前
【用户行为归因分析项目】- 【企业级项目开发第五站】数据采集并加载到hive表
大数据·数据仓库·hive·hadoop·spark·scala
是阿威啊2 个月前
【用户行为归因分析项目】- 【企业级项目开发第四站】模拟三类用户行为数据上传到Hadoop
大数据·hadoop·分布式·sql·scala