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

2023_Spark_实验六:Scala面向对象部分演示(二)(IDEA开发)

7、Scala中的apply方法()

遇到如下形式的表达式时,apply方法就会被调用:

Object(参数1,参数2,......,参数N)

通常,这样一个apply方法返回的是伴生类的对象;其作用是为了省略new关键字

Object的apply方法举例:

//object的apply方法class Student5(val stuName:String) {}object Student5 {//定义自己的apply方法def apply(stuName: String) = {println("*********Apply in Object **********")new Student5(stuName)}//如果没有这个apply方法,下面创建Mary的时候就会报错def main(args: Array[String]): Unit = {var s51 = new Student5("Tom")println(s51.stuName)var s52 = new Student5("Mary")//由于省略了new关键字,创建这个对象的时候,就会在Object找对应的apply方法println(s52.stuName)}}

8、Scala中的继承

Scala和Java一样,使用extends关键字扩展类。

案例一:Employee类继承Person类


//演示Scala的维承父类class Person(val name:String,val age:Int) {//定义结果def sayHello():String = "Hello" + name + " and the age is " + age}//子类class Employee (override val name:String,override val age:Int,val salary:Int) extends Person(name,age){//重新父类的sayHello方法//注意override 是关键字override def sayHello(): String = "子类中的sayHello方法"}object Demo {//测试程序def main(args: Array[String]): Unit = {//创建一个Employee的对象var p2:Person = new Employee("Mike",25,1000)println(p2.sayHello())//使用匿名子类来创建Person对象//这里我们创建了Person的一个匿名子类,并且在该子类中重写了sayHello方法。var p3:Person = new Person("Jerry",26) {override def sayHello(): String = "匿名子类中的sayHello方法"}println(p3.sayHello())}}

案例二:在子类中重写父类的方法

//子类class Employee (override val name:String,override val age:Int,val salary:Int) extends Person(name,age){//重新父类的sayHello方法override def sayHello(): String = "子类中的sayHello方法"}

案例三:使用匿名子类

//使用匿名子类来创建Person对象//这里我们创建了Person的一个匿名子类,并且在该子类中重写了sayHello方法。var p3:Person = new Person("Jerry",26) {override def sayHello(): String = "匿名子类中的sayHello方法"}println(p3.sayHello())

案例四:使用抽象类。抽象类中包含抽象方法,抽象类只能用来继承。


//Scala中的抽象类//父类:抽象类abstract class Vehicle{//定义抽象方法def checkType():String}//子类class Car extends Vehicle {//实现checkType 方法override def checkType(): String = {"I am a Car"}}class Bycical extends Vehicle {//实现checkType方法override def checkType(): String = {"I am a bike"}}object Demo2 {//定义两个交通工具def main(args: Array[String]): Unit = {var v1:Vehicle = new Carprintln(v1.checkType())var v2:Vehicle = new Bycicalprintln(v2.checkType())}}

案例五:使用抽象字段。抽象字段就是一个没有初始值的字段


package class4//Scala中的抽象字段:就是没有初始值的字段//抽象的父类abstract class Person{//第一个抽象字段,并且只有get方法val id:Int//另一个抽象字段,并且有get和set方法var name:String}//子类:应该提供抽象字段的初始值,否则该子类也,应该是抽象的abstract class Employee1 extends Person {//val id:Int = 1var name:String = "No Name"}class Employee2(val id:Int) extends Person {var name:String = "No Name"}object Demo3 {def main(args: Array[String]): Unit = {var a:Person = new Employee2(1)println(a.id,a.name)}}

9、Scala中的trait(特质)

trait就是抽象类。trait跟Java抽象类最大的区别:trait支持多重继承


package class4/** Scala中的trait* 1.trait 就是抽象类* 2.区别:trait 支持多重继承*///第一个traittrait Human {val id:Intval name:String//方法def sayHello():String = "Hello" + name}//第二个traittrait Actions {//抽象方法def getActionNames():String}//子类class Student(val id:Int,val name:String) extends Human with Actions {override def getActionNames(): String = "Action is running"}object Demo4 {def main(args: Array[String]): Unit = {//创建一个student的对象var s1 = new Student(1,"Tom")println(s1.sayHello())println(s1.getActionNames())}}

10、包的使用

Scala的包和Java中的包或者C++中的命名空间的目的是相同的:管理大型程序中的名称。

Scala中包的定义和使用:

包的定义

包的引入:Scala中依然使用import作为引用包的关键字,例如

而且Scala中的import可以写在任意地方

11、包对象

包可以包含类、对象和特质,但不能包含函数或者变量的定义。很不幸,这是

Java虚拟机的局限。把工具函数或者常量添加到包而不是某个Utils对象,这是

更加合理的做法。Scala中,包对象的出现正是为了解决这个局限。Scala中的包

对象:常量,变量,方法,类,对象,trait(特质)


package class4//Scala中的包对象:常量,变量,方法,类,对象,trait(特质)//定义一个包对象package object MyPackageObject {//常量val x:Int = 0//变量var y:String = "Hello World "//方法def sayHelloWorld():String = "Hello World"//类class MyTestClass {}//对象objectobject MyTestObject {}//特质 traittrait MyTestTrait {}}class Demo3 {//测试def method1 = {//导入需要的包对象import class4.MyPackageObject._//定义MyTestClass的一个对象var a= new MyTestClass}}

12、Scala中的文件访问

读取行


val source = scala.io.Source.fromFile("e:\\temp\\a.txt")println(source.mkString)val lines = source.getLines()for(l<-lines) println(l.toString)

读取字符


val source = scala.io.Source.fromFile("e:\\temp\\a.txt")for(c <-source) println(c)

其实这里的source就指向了这个文件中的每个字符。

相关文章:

2023_Spark_实验六:Scala面向对象部分演示(二)(IDEA开发)

7、Scala中的apply方法&#xff08;&#xff09; 遇到如下形式的表达式时&#xff0c;apply方法就会被调用&#xff1a; Object(参数1,参数2,......,参数N) 通常&#xff0c;这样一个apply方法返回的是伴生类的对象&#xff1b;其作用是为了省略new关键字 Object的apply方法…...

ArcGIS美化科研论文地图(利用在线底图)

1.加载在线底图服务 在ArcGIS Desktop中打开Catalog窗口&#xff0c;在GIS Servers中点击Add ArcGIS Server&#xff0c;之后选项全部默认&#xff0c;仅在URL中输入以下网址https://services.arcgisonline.com/arcgis 之后就可以看到底图了 我们在WorldElevation3D中选择Nat…...

vue项目静态文件资源下载

业务场景&#xff1a;页面有一个导入功能&#xff0c;需要一个模板文件供下载&#xff0c;文件放在本地。 对于 Vue 3 Vite 项目&#xff0c;使用 require 方法来导入模块是不被支持的。require 是 CommonJS 规范中用于模块导入的方法&#xff0c;在 Webpack 等构建工具中常用…...

Apache Hudi初探(三)(与flink的结合)--flink写hudi的操作(真正的写数据)

背景 在之前的文章中Apache Hudi初探(二)(与flink的结合)–flink写hudi的操作(JobManager端的提交操作) 有说到写hudi数据会涉及到写hudi真实数据以及写hudi元数据,这篇文章来说一下具体的实现 写hudi真实数据 这里的操作就是在HoodieFlinkWriteClient.upsert方法: public …...

解释 Git 的基本概念和使用方式(InsCode AI 创作助手)

Git 是一种分布式版本控制系统&#xff0c;它允许多个用户协同工作并对项目进行版本控制。下面是 Git 的基本概念和使用方式&#xff1a; 基本概念&#xff1a; 仓库&#xff08;Repository&#xff09;&#xff1a;存储代码和版本历史记录的地方。 提交&#xff08;Commit&a…...

【QT】信号和槽(15)

前面的内容说了很多不同的控件如何使用&#xff0c;今天来看下QT的核心&#xff0c;信号与槽&#xff08;Signals and slots&#xff09;&#xff01; 简单理解一下&#xff0c;就是我们的信号与槽连接上了之后&#xff0c;发射一个信号给到槽&#xff0c;槽函数接收到了这个信…...

EFLK日志平台(filebeat-->kafka-->logstash-->es-->kiabana)

ELK平台是一套完整的日志集中处理解决方案&#xff0c;将 ElasticSearch、Logstash 和 Kiabana 三个开源工具配合使用&#xff0c; 完成更强大的用户对日志的查询、排序、统计需求。 安装顺序 1.安装es 7.17.12 2.安装kibana 7.17.12 3.安装x-pack 保证以上调试成功后开始下面…...

C盘扩容遇到的问题(BitLocker解密、)

120G的C盘不知不觉的就满了&#xff0c;忍了好久终于要动手了。 尽管电脑-管理--磁盘管理里可以进行磁盘大小调整&#xff0c;但由于各盘都在用&#xff0c;不能够连续调整&#xff0c;所以选用DiskGenius。 # DiskGenius调整分区大小遇到“您选择的分区不支持无损调整容量” …...

ShardingSphere——柔性事务SEATA原理

摘要 Apache ShardingSphere集成了 SEATA 作为柔性事务的使用方案&#xff0c;本文主要介绍其实现ShardingSphere中柔性事务SEATA原理原理。帮助你更好的理解ShardingSphere原理。同时帮助大家更好的使用柔性事务SEATA原理。 一、Seata柔性事务 Apache ShardingSphere 集成了…...

Introducing GlobalPlatform(一篇了解GP)

安全之安全(security)博客目录导读 TEE之GP(Global Platform)认证汇总 目录 一、GP简介 二、GP新的重点领域是什么? 三、认证程序和培训<...

Ubuntu 18.04上无法播放MP4格式视频解决办法

ubuntu18.04系统无法播放MP4格式视频&#xff0c;提示如下图所示&#xff1a; 解决办法&#xff1a; 1、首先&#xff0c;确保ubuntu系统已完全更新。可使用以下命令更新软件包列表&#xff1a;sudo apt update&#xff0c;然后使用以下命令升级所有已安装的软件包&#xff1a…...

科技驱动产业升级:浅谈制造型企业对MES系统的应用

在科技不断进步的背景下&#xff0c;制造型行业也在持续发展&#xff0c;但随之而来的挑战也不断增加。传统的管理方式已经无法满足企业的需求&#xff0c;因此许多制造型企业开始寻找新的管理模式。制造执行系统&#xff08;MES&#xff09;作为先进的制造信息技术之一&#x…...

智能化新十年,“全栈智能”定义行业“Copilot智能助手”

“智能化转型是未来十年中国企业穿越经济周期的利器”&#xff0c;这是联想集团执行副总裁兼中国区总裁刘军在去年联想创新科技大会上做出的判断&#xff0c;而2023年正值第四次工业革命第二个十年的开端&#xff0c;智能化是第四次工业革命的主题。2023年初&#xff0c;基于谷…...

Docker资源控制cgroups

文章目录 一、docker资源控制1、资源控制工具2、Cgroups四大功能 二、CPU 资源控制1、设置CPU使用率上限2、CPU压力测试3、Cgroups限制cpu使用率4、设置CPU资源占用比&#xff08;设置多个容器时才有效&#xff09;5、设置容器绑定指定的CPU 三、对内存使用的限制四、对磁盘IO配…...

通过python 获取当前局域网内存在的IP和MAC

通过python 获取当前局域网内存在的ip 通过ipconfig /all 命令获取局域网所在的网段 通过arp -d *命令清空当前所有的arp映射表 循环遍历当前网段所有可能的ip与其ping一遍建立arp映射表 for /L %i IN (1,1,254) DO ping -w 1 -n 1 192.168.3.%i 通过arp -a命令读取缓存的映射表…...

解决D盘的类型不是基本,而是动态的问题

一、正确的图片 1.1图片 1.2本人遇到的问题 二、将动态磁盘 转为基本盘 2.1 基本概念&#xff0c;动态无法转化为基本&#xff0c;不是双向的&#xff0c;借助软件 网址&#xff1a;转换动态磁盘到普通磁盘_检测到计算机本地磁盘为动态分区_卫水金波的博客-CSDN博客 2.2分区…...

如何判断自己的qt版本呢?

如何判断自己的qt版本呢? 前情提要很简单,按照如下图所示,即可查看当前打开的qtCreator的版本如何打开5.15.2版本的qtCreator呢?安装教程 前情提要 我的电脑已经安装了qt5.14.1,然后我又安装了qt5.15.2,我想尝试一下同一台电脑能否适应两个版本的qt? 当我安装完成qt5.15.2后…...

【文心一言大模型插件制作初体验】制作面试错题本大模型插件

文心一言插件开发初体验 效果图 注意&#xff1a;目前插件仅支持在本地运行&#xff0c;虽然只能自用&#xff0c;但仍然是一个不错的选择。&#xff08;什么&#xff1f;你说没有用&#xff1f;这不可能&#xff01;文心一言app可以支持语音&#xff0c;网页端结合手机端就可…...

ROS 2官方文档(基于humble版本)学习笔记(二)

ROS 2官方文档&#xff08;基于humble版本&#xff09;学习笔记&#xff08;二&#xff09; 理解节点&#xff08;node&#xff09;ros2 runros2 node list重映射&#xff08;remap&#xff09;ros2 node info 理解话题&#xff08;topic&#xff09;rqt_graphros2 topic listr…...

excel中公式结合实际的数据提取出公式计算的分支

要在Excel中使用公式结合实际数据提取分支信息&#xff0c;您可以使用一些文本函数和条件函数来实现这个目标。以下是一个示例&#xff0c;假设您有一个包含银行交易描述的列A&#xff0c;想要从中提取分支信息&#xff1a; 假设交易描述的格式是"分行名称-交易类型"…...

FModel终极指南:3步快速掌握游戏资源提取与创作应用

FModel终极指南&#xff1a;3步快速掌握游戏资源提取与创作应用 【免费下载链接】FModel Unreal Engine Archives Explorer 项目地址: https://gitcode.com/gh_mirrors/fm/FModel 你是否曾想过提取游戏中的精美模型、纹理和音频&#xff0c;用于自己的创作项目&#xff…...

B站成分检测器:5分钟快速上手智能识别工具

B站成分检测器&#xff1a;5分钟快速上手智能识别工具 【免费下载链接】bilibili-comment-checker B站评论区自动标注成分&#xff0c;支持动态和关注识别以及手动输入 UID 识别 项目地址: https://gitcode.com/gh_mirrors/bil/bilibili-comment-checker 你是否曾在B站评…...

从AB类到C类:拆解Doherty功放里载波与峰值支路的相位“打架”问题及宽带补偿方案

从AB类到C类&#xff1a;拆解Doherty功放里载波与峰值支路的相位“打架”问题及宽带补偿方案 在射频功率放大器设计中&#xff0c;Doherty架构因其高效率特性而备受青睐。然而&#xff0c;当工程师们试图将这种架构扩展到更宽频带时&#xff0c;往往会遇到一个令人头疼的问题—…...

Hive 3.1.3部署后,你可能会遇到的3个连接与权限报错及解决实录

Hive 3.1.3部署后三大经典连接与权限问题深度解析 当你终于按照教程完成Hive 3.1.3的安装&#xff0c;却在最后连接阶段遭遇各种"拦路虎"时&#xff0c;那种挫败感我深有体会。本文将带你直击三个最具代表性的连接与权限问题&#xff0c;从报错现象到根因分析&#x…...

大模型写论文,“文献”全是瞎编的?为什么大模型爱编参考文献?如何确保文献的真实性

一、引言&#xff1a;当AI开始“编文献” 随着大语言模型&#xff08;如 GPT-4、DeepSeek、Claude 等&#xff09;在学术写作、文献综述、技术调研中的普及&#xff0c;一个隐蔽但危险的问题逐渐暴露出来——文献幻觉&#xff08;Citation Hallucination&#xff09;。 你可能…...

智能电表:解锁智能照明精细化能耗管控新密码

摘要随着双碳政策深度落地与智慧楼宇数字化升级&#xff0c;智能照明已成为商业园区、市政道路、综合体的标配设施。传统机械式电表仅具备基础电量统计功能&#xff0c;存在数据滞后、精度不足、无分区计量、无异常监测等短板&#xff0c;无法适配现代照明多回路、多场景、长时…...

Android多媒体开发避坑:深入理解DMABUF机制与RK3588上的常见泄漏点

Android多媒体开发中的DMABUF机制解析与RK3588内存泄漏实战指南 在RK3588这类高性能芯片上开发视频编解码、相机等多媒体应用时&#xff0c;追求零拷贝性能优化往往会引入DMABUF的使用。然而&#xff0c;这种看似完美的解决方案背后隐藏着复杂的内存管理陷阱。本文将带您深入理…...

别再为查重和 AIGC 检测头秃!okbiye 降重 + 降 AIGC 双功能,论文安全过审的最后一道防线

okbiye-免费查重复率aigc检测/开题报告/毕业论文/智能排版/文献综述/AI PPT降重复率 - Okbiye智能写作https://www.okbiye.com/reduceAIGC 一、前言&#xff1a;论文提交前&#xff0c;你最怕的两个 “隐形杀手” 论文写到定稿&#xff0c;才发现重复率超标、AIGC 检测不过&am…...

Spine骨骼动画集成:Unity 2D游戏性能优化实战指南

1. 为什么Spine不是“另一个动画插件”&#xff0c;而是2D游戏性能分水岭在Unity里做2D游戏&#xff0c;很多人卡在同一个地方&#xff1a;角色动起来很卡&#xff0c;美术给的PSD切图动效一多就掉帧&#xff0c;UI动画和角色动画抢资源&#xff0c;打包后APK体积暴涨——你试过…...

AI工程实践简报:如何用高质量信号提升技术决策效率

1. 项目概述&#xff1a;一份真正“够用”的AI资讯简报&#xff0c;到底长什么样&#xff1f;“This AI newsletter is all you need #38”——光看标题&#xff0c;你可能以为这又是一份泛泛而谈的行业 roundup&#xff0c;或是堆砌热点、浮于表面的“信息快餐”。但作为连续三…...