Spark-Scala语言实战(3)

news2025/1/23 15:06:38

在之前的文章中,我们学习了如何在来如何在IDEA离线和在线安装Scala,想了解的朋友可以查看这篇文章。同时,希望我的文章能帮助到你,如果觉得我的文章写的不错,请留下你宝贵的点赞,谢谢。

Spark-Scala语言实战(2)(在IDEA中安装Scala,超详细配图)-CSDN博客icon-default.png?t=N7T8https://blog.csdn.net/qq_49513817/article/details/136719556?spm=1001.2014.3001.5501

目录

一、知识回顾

二、函数

1.无参函数

2.带参函数

3.匿名函数 

三、任务实现

拓展-


一、知识回顾

在之前的文章中,我们学习了定义常量变量和数组,以及九九乘法表的实现。

相信定义的方法大家没有忘记吧

无非就是val和var的区别,一个是常量,一个是变量,很好理解记忆,主要是要了解它们的用法。

其次,在上一篇文章结尾我们也了解到了一些常见的函数。

今天,我就来教大家如何定义函数。

二、函数

1.无参函数

我们先从简单的无参函数开始,我只需要我的函数给我输出一个"Hello, World!",该怎么操作呢?接着往下看。

def greet(): Unit = {
  println("Hello, World!")
}

greet() // 调用函数,输出 "Hello, World!"

这样,我们就定义了一个名为greet的函数,它的内容很简单,就是输出我们所需的"Hello, World!",来看看效果吧。

2.带参函数

在带参函数中,其实和无参的区别不大,但是要注意我们的调用方法。

def add(a: Int, b: Int): Int = {  
  a + b  
}  
  
val sum = add(3, 4) // 调用函数,并将结果赋值给变量sum  
println(sum) // 输出 7

 我们首先定义了一个add函数,再把它作完相加的值赋给sum,然后输出sum,来看看效果吧。

3.匿名函数 

在Scala中,匿名函数是一种没有名称的函数,它们常常作为参数传递给其他函数,或者在某些情况下直接用于表达简单的逻辑。Scala的匿名函数是通过=>符号来定义的,它左侧是参数列表,右侧是函数体。

来个简单的匿名函数看看

val add = (a: Int, b: Int) => a + b  
val sum = add(3, 4) // 调用匿名函数,并将结果赋值给变量sum  
println(sum) // 输出 7

可能单单一个大家看不出来区别,再来个难的

匿名函数作为返回值

def createMultiplier(factor: Int): Int => Int = {  
  (num: Int) => num * factor // 返回匿名函数  
}  
  
val triple = createMultiplier(3) // 创建一个函数,该函数将输入的数字乘以3  
val result = triple(5) // 调用返回的函数,并将结果赋值给变量result  
println(result) // 输出 15

这样就很直观吧,多做对比。

三、任务实现

用Scala写一个电话号码归属地以输入的号码前几位的字段来区分,在输入号码后告知是联通移动电信还是错误的号码,号码字段用数组来存贮。

object p2 {
  // 假设电话号码的前三位或四位代表不同的运营商
  // 这里使用数组来存储号码字段和对应的运营商
  val phonePrefixes = Array(
    ("130", "131", "132", "155", "156", "185", "186", "1709") -> "联通",
    ("134", "135", "136", "137", "138", "139", "150", "151", "152", "157", "158", "159", "182", "183", "184", "187", "188", "198", "1705", "1340") -> "移动",
    ("133", "153", "180", "181", "189", "1700") -> "电信"
  )

  // 函数来根据号码前缀判断运营商
  def classifyPhoneNumber(phoneNumber: String): String = {
    // 提取号码的前几位作为前缀
    val prefix = phoneNumber.take(4) // 假设前四位是足够的
    // 查找前缀对应的运营商
    phonePrefixes.find(_._1.contains(prefix)).map(_._2).getOrElse("错误的号码")
  }

  // 程序的入口点
  def main(args: Array[String]): Unit = {
    val phoneNumber = "13800138000" // 示例号码,请替换为实际输入的号码
    val operator = classifyPhoneNumber(phoneNumber)
    println(s"号码 $phoneNumber 的归属运营商是: $operator")
  }

}

我在 find 方法中使用了一个匿名函数 prefixSet => prefixSet._1.contains(prefix) 这样做是为了提高代码的可读性,并且使类型推断更加明确。

现在,编译并运行这个代码,它应该可以正确地根据电话号码前缀判断归属运营商了。

拓展-scala自定函数的种类作用

函数种类描述作用
成员函数定义在类的内部,作为类的成员成员函数能够访问和修改类的内部状态,实现对象的行为和属性。它们是面向对象编程的基石,允许通过对象来执行操作。
本地函数定义在另一个函数内部本地函数用于封装一段特定的逻辑,只在其定义的函数内部可见和使用。它们可以提高代码的可读性和可维护性,通过将复杂的逻辑分解为更小的函数。
匿名函数没有函数名,通过=>来连接参数列表和方法体匿名函数可以作为参数传递给其他函数,也可以作为返回值返回。它们常用于高阶函数中,作为回调函数或谓词使用。匿名函数的灵活性使得代码更加简洁和易读。
高阶函数将函数作为参数传递或返回的函数高阶函数允许将函数作为一等公民来处理,可以像处理其他数据类型一样传递和返回函数。这使得代码更加模块化和可重用,能够编写更加抽象和通用的函数。
函数种类描述作用
柯里化函数(Curried Functions)将一个接受多个参数的函数转换为一系列接受单一参数的函数柯里化函数允许我们将复杂的函数分解为一系列更简单的函数,从而增强函数的复用性和可读性。
偏函数(Partial Functions)只定义在其定义域子集上的函数偏函数在处理某些特定条件或异常情况时非常有用,它们允许我们定义只在某些输入上有效的函数。
递归函数(Recursive Functions)在函数体内部调用自身的函数递归函数常用于处理树形结构或需要重复执行的任务,它们通过将问题分解为更小的子问题来解决复杂的问题。
尾递归函数(Tail Recursive Functions)递归调用出现在函数体的最后位置(即尾部)的函数尾递归函数在Scala中经过优化,可以避免栈溢出的问题,从而允许处理更大的数据集。
隐式函数(Implicit Functions)通过隐式转换和隐式参数自动应用的函数隐式函数提供了在编译时自动插入转换和参数的机制,从而简化代码并增强类型安全性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1538570.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

SpringBoot 集成支付宝支付,看这篇就够了!

SpringBoot 集成支付宝支付,看这篇就够了! 1.进入支付宝开发平台—沙箱环境 2.点击沙箱进入沙箱环境 3.进入沙箱,配置接口加签方式 在沙箱进行调试前需要确保已经配置密钥/证书用于加签,支付宝提供了 系统默认密钥 及 自定义密钥 两种方式进行配置。这里我采取的是默认方…

现行有效外汇管理主要法规目录(截至2023年12月31日)

现行有效外汇管理主要法规目录 (截至 2023 年 12 月 31 日) 一、综合(27 项) (一)基本法规(9 项) 1 中华人民共和国外汇管理条例 国务院令第 532 号 2 个人外汇管理办法 中国…

只看到真人版《武庚纪》的顶级特效?那你亏大了!

“一不留神就看6集”,一看一个不吱声,相信看过《烈焰》(原名:武庚纪)的观众或多或少都有和笔者一样的感受。 与其他国产剧不同的是,《烈焰》改编自动画《武庚纪》,“漫改”让他的人物装造更贴近…

Elasticsearch:让你的 Elasticsearch 索引与 Python 和 Google Cloud Platform 功能保持同步

作者:来自 Elastic Garson Elasticsearch 内的索引 (index) 是你可以将数据存储在文档中的位置。 在使用索引时,如果你使用的是动态数据集,数据可能会很快变旧。 为了避免此问题,你可以创建一个 Python 脚本来更新索引&#xff0…

SpringBoot项目配置文件不生效问题解决

目录 一、问题描述 二、问题解决过程 三、总结 四、拓展 一、问题描述 近期在写一个RabbitMQ基于springboot的使用damon的时候,在启动消费者服务的时候一直发现连接不上RabbitMQ,很是纳闷,配置文件大概如下: server:port:…

Linux相关命令(1)

1、找出文件夹下包含 “aaa” 同时不包含 “bbb”的文件,然后把他们重新生成一下。要求只能用一行命令。 find ./ -type f -name "*aaa*" ! -name "*bbb*" -exec touch {} \;文件系统操作命令 df:列出文件系统的整体磁盘使用情况 …

欧科云链OKLink:坎昆升级后,Layer2项目是否更具竞争力?

在坎昆升级激活之际,OKLink 上线以太坊坎昆升级 Dencun 专题页 👉 从专业链上数据分析角度,带来一场充实且即时的 Layer2 数据盛宴。 在近日由 137Labs 发起,Cointime 主持的 Layer2 生态专场讨论中,OKLink 产品…

【办公类-16-07-08】“2023下学期 大班户外游戏2(做成打印用的的贴墙版样式--A4横版撑满)”(python 排班表系列)

背景需求: 运用代码做出了中班每个班级用的户外游戏(新版)的表格(包含有场地的贴墙版和无场地的贴周计划版) 【办公类-16-07-07】“2023下学期 大班户外游戏2(有场地和无场地版,每天不同场地&…

python爬虫之xpath+多进程爬取百度贴吧实战

文章目录 抓取百度贴吧的某一个帖子的评论内容前言先查看贴吧的robots.txt页面结构分析评论者头像,用户抓取评论内容的抓取评论下回复内容的抓取 源码实现贴吧抓取过程源码实现多进程的实现 抓取百度贴吧的某一个帖子的评论内容 前言 本项目实战是用来学习用&#…

uniapp自定义导航栏左中右内容和图标,以及点击事件

uniapp自定义导航栏左中右内容和图标&#xff0c;以及点击事件 效果&#xff1a; 页面&#xff1a; <view class"navigation-bar"><view class"navigation-bar-left" click"navigateBack"><u-icon name"arrow-left"…

曲面斑马纹分析

曲面斑马纹分析是一种在曲面设计和质量检测中广泛使用的技术&#xff0c;其基本原理是利用明暗相间的光线照射到物体表面经反射产生的纹路来评估曲面的连续性和光顺性。这些斑马纹不仅美观&#xff0c;更重要的是它们能直观地展示曲面上的几何特性&#xff0c;帮助设计师和工程…

C++入门笔记开源【研究生3年+7W字】

博主研究生3年时间积累了一个C的基础知识文档&#xff0c;共计7W字。几乎把常用的各种语法和接口都包含进去了。一个文档&#xff0c;markdown格式的&#xff0c;可以当做工具书来使用。由于本文档内容较多&#xff0c;直接复制到csdn会各种卡&#xff0c;而且图片链接不对&…

【循环神经网络rnn】一篇文章讲透

目录 引言 二、RNN的基本原理 代码事例 三、RNN的优化方法 1 长短期记忆网络&#xff08;LSTM&#xff09; 2 门控循环单元&#xff08;GRU&#xff09; 四、更多优化方法 1 选择合适的RNN结构 2 使用并行化技术 3 优化超参数 4 使用梯度裁剪 5 使用混合精度训练 …

C++剑指offer与高频面试题源码解答与分析

这是博主在当初秋招刷题时候记录的剑指offer第二版以及一些高频题的C源码和解法分析&#xff0c;可以说把这上面的题练好了面试不虚&#xff0c;最后也顺利帮助我拿下baidu ali meituan等多家大厂offer。整篇文章写了大概5W个字&#xff0c;也是积累了很长一段时间的作品&#…

数据分析案例-国际象棋顶级棋手数据可视化分析(文末送书)

&#x1f935;‍♂️ 个人主页&#xff1a;艾派森的个人主页 ✍&#x1f3fb;作者简介&#xff1a;Python学习者 &#x1f40b; 希望大家多多支持&#xff0c;我们一起进步&#xff01;&#x1f604; 如果文章对你有帮助的话&#xff0c; 欢迎评论 &#x1f4ac;点赞&#x1f4…

C++的内存模型

大家好&#xff1a; 衷心希望各位点赞。 您的问题请留在评论区&#xff0c;我会及时回答。 内存分区模型 C程序在执行时&#xff0c;将内存大方向划分为4个区域。 代码区&#xff1a;存放函数体的二进制代码&#xff0c;由操作系统进行管理。 全局区&#xff1a;存放全局变…

是时候来唠一唠synchronized关键字了,Java多线程的必问考点!

写在开头 在之前的博文中&#xff0c;我们介绍了volatile关键字&#xff0c;Java中的锁以及锁的分类&#xff0c;今天我们花5分钟时间&#xff0c;一起学习一下另一个关键字&#xff1a;synchronized。 synchronized是什么&#xff1f; 首先synchronized是Java中的一个关键字…

机器学习-06-无监督算法-01-划分聚类Kmeans算法

总结 本系列是机器学习课程的系列课程&#xff0c;主要介绍机器学习中无监督算法&#xff0c;包括划分聚类等。 参考 数据分析实战 | K-means算法——蛋白质消费特征分析 欧洲48国英文名称的来龙去脉及其国旗动画 Kmeans在线动态演示 本门课程的目标 完成一个特定行业的…

基于modbus TCP实现EPICS与西门子S7 1200系列1215C PLC的通信

PLC介绍 西门子系列PLC在国内的市场占比第一&#xff0c;1200系列中小型PLC&#xff0c;因其众多的产品序列、强大的通讯功能和丰富扩展模块&#xff0c;被使用在工业生产、自动化生产线、智能制造、机器人等各行各业。根据CPU的供电电源的型号和数字量输出的类型&#xff0c;…

科技革新背后:码垛机器人在不同领域的实践应用

随着科技的进步&#xff0c;机器人技术已经渗透到各个行业之中&#xff0c;成为提高生产效率、减少人工成本的重要工具。码垛机器人作为自动化技术的杰出代表&#xff0c;其在各个行业中的应用场景日益广泛&#xff0c;从食品饮料到化工产品&#xff0c;再到物流仓储&#xff0…