Scala入门,idea关联Scala

Scala

介绍

Scala是一种多规范的编程语言,它结合了面向对象编程(OOP)和函数式编程(FP)的特征,Scala的名字源于”Scalable language“,意为”可伸缩语言“。2003年开发的,并在JVM(Java虚拟机)上运行的,Scala被设计用于编程简介高效的代码的同时提供强大的表达能力和灵活性。

特点

  • 面向对象和函数式编程支持:
    • Scala支持面向对象的编程范式,同时也强调函数式编程,允许开发者以更函数式的方式思考和编写代码,从而更好地处理并发和异步编程等问题。
  • 静态类型:
    • Scala是一门静态类型语言,可以在编译时捕获一些错误,提高代码的稳定性和可维护性。
  • 表达力强:
    • Scala提供了丰富的语法特性,可以用更少的代码表达更多的概念,从而增强代码的可读性和可理解性。
  • 互操作性:
    • Scala可以与Java无缝集成,可以直接调用Java类库和组件,这对于现有的Java开发者来说是一个优势,也使得在已有的Java项目中引入Scala逐步过渡变得容易。
  • 并发支持:
    • Scala通过其函数式编程特性,提供了更好的并发编程支持,例如使用不可变数据结构和并行集合来简化多线程编程。

为什么学习

  • 丰富的编程范式:
    • 学习Scala可以让你同时了解面向对象和函数式编程的特性,从而能够更灵活地选择适合不同情境的编程方式。
  • 并发和多线程编程:
    • Scala在并发编程方面提供了强大的支持,这在处理现代应用中的并发性和异步编程方面非常有用。
  • 表达能力:
    • Scala的语法特性允许你以更简洁的代码表达复杂的概念,提高代码的可读性和可维护性。
  • JVM平台:
    • Scala运行在Java虚拟机上,因此可以与Java代码互操作,适合在现有的Java项目中引入。Scala可以直接调用Java中的方法,访问Java中的字段,继承java类,实现Java接口。
  • 函数式思维:
    • 学习Scala可以培养函数式编程思维,这对于提高编程的抽象能力、模块化能力和问题解决能力都很有帮助。

总之,学习Scala可以让你拥有多规范编程的能力,从而更好的应对复杂的软件开发任务,尤其是在并发编程和大规模的应用开发方面。

数据类型

类型数据类型
整数类型byte,short,int,long
浮点数类型float,double
字符类型char
布尔类型boolean
字符串类型String
数组类型Array
列表类型list
元组类型tuple
集合类型set
映射类型map

运算符

类型运算符
算术运算符+,-,*,/,%
比较运算符==,!= , > , < , >= , <=
逻辑运算符&& , || , !
赋值运算符= , += , -= , *= , /=
位运算符& , | , ^ , ~ , << , >>
条件运算符if-else , match-case
循环运算符for , while , do-while

案例

scala> "hello scala"
res0: String = hello scalascala> 1+1
res1: Int = 2

变量,常量

关键字定义
var变量
val常量

创建变量方式

var 变量名称: 数据类型 = 变量值;

例如

# 创建变量count,数据类型为Int类型,初始值为10
scala> var count:Int=10;
count: Int = 10
# 输入count变量,返回变量值
scala> count
res0: Int = 10
# 对count变量重新赋值
scala> count=1;
count: Int = 1scala> count
res1: Int = 1

创建常量的方式

val 常量名称:数据类型 = 常量值

例如

# 创建常量name,数据类型为String,常量值为zhangsan
scala> val name:String = "zhangsan";
name: String = zhangsan
# 输入name常量,返回常量值
scala> name
res3: String = zhangsan
# 对常量name重新赋值时,编译错误,常量无法重新赋值
scala> name = "lisi";
<console>:12: error: reassignment to valname = "lisi";

函数

使用关键字def来定义函数,函数定义语法为:

def 函数名称(参数列表):返回类型={//函数体//可以包含多条一句//最后一行的表达式作为返回值
}

无参函数

# 定义函数sayHello,Unit:表示无值,等同于Java中的void 
scala> def sayHello():Unit={| println("Hello,Scala!");//打印:Hello,Scala!| }
sayHello: ()Unit
# 调用函数
scala> sayHello()
Hello,Scala!

有参函数

# 定义函数add,参数为x(Int整数类型),y(Int整数类型),返回类型为Int
scala> def add(x:Int,y:Int):Int={| x+y;| }
add: (x: Int, y: Int)Int
# 调用函数,传入实参
scala> val result = add(10,10)
result: Int = 20scala> result
res8: Int = 20

默认参数函数

# 定义函数greet,参数为name(String字符串类型),greeting(String字符串类型,默认值为Hello)
scala> def greet(name:String,greeting:String="Hello"):Unit={| println(s"$greeting,$name");//插值语法| }
greet: (name: String, greeting: String)Unitscala> greet("zhangsan");
Hello,zhangsanscala> greet("lisi","Hi");
Hi,lisi

可变参数函数

# 定义函数sum,参数为number(Int整数类型,*多个值)
scala> def sum(number:Int*):Int = {| number.sum; //参数的和| }
sum: (number: Int*)Intscala> println(sum(1,2,3,4,5,6));
21

匿名函数(lambda表达式)

# 定义函数add,参数为x(Int整数类型),y(Int整数类型),返回类型为Int
scala> val add:(Int,Int)=> Int=(x,y)=>x+y
add: (Int, Int) => Int = <function2>scala> println(add(3,4))
7

if判断

语法

if(布尔表达式){//执行条件为true时的代码块
}else{//执行条件为false时的代码块
}

例如

scala> val x = 10;
x: Int = 10scala> if (x>5){| println("x大于5");| }else{| println("x小于5");| }
x大于5

for循环

语法

for(变量 <- 初始值 to 结束值){//循环体
}

例如

# 循环从1输出到5
scala> for(i <- 1 to 5){| println(i);| }
1
2
3
4
5

数组

创建数据的方式

var 数据名称 : Array[数据类型] = new Array[数据类型](数组长度)
var 数组名称 : Array[数据类型] = Array(元素1,元素2......) 
var 数组名称 : Array.ofDim[数据类型](数组长度)

操作数组常用的方式

方法描述
length返回数组的长度
head返回数组的第一个元素
tail返回数组中除了第一个元素意外的所有元素
isEmpty判断数组是否为空
contains()判断数组中是否包含某个元素
forEach()遍历数组
max返回数组的最大元素
min返回数组的最小元素
sum返回数组的和
distinct去重
sorted升序排序
mkString数组以字符串形式显示

例如

# 第一种创建方式
scala> var arr: Array[String] = new Array[String](3)
arr: Array[String] = Array(null, null, null)
# 数组的长度
scala> arr.length
res0: Int = 3
# 对索引1的元素赋值
scala> arr(1)="zhangsan"
# 查看索引1的元素
scala> arr(1)
res2: String = zhangsan
# 查看索引0的元素
scala> arr(0)
res3: String = null
# 查看数组
scala> arr
res4: Array[String] = Array(null, zhangsan, null)# 第二种创建方式
scala> var arr1 : Array[Int] = Array(1,2,3,4)
arr1: Array[Int] = Array(1, 2, 3, 4)
# 数组长度
scala> arr1.length
res6: Int = 4
# 索引处的元素值
scala> arr1(2)
res7: Int = 3

List列表

在Scala中,List是一个常用的数据结构,用于存储有序的元素序列。List是不可变的,意味着一旦创建就不能修改,但可以通过创建新的List来进行操作和转换

语法

val 列表名称:List[列表类型] = List(列表元素);

例如

scala> val list:List[String] = List("zhangsan","lisi","wangwu");
list: List[String] = List(zhangsan, lisi, wangwu)scala> val ageList:List[Int] = List(18,29,38,10);
ageList: List[Int] = List(18,29,38,10)

列表常用方法

方法描述
head返回列表的第一个元素
tail返回除第一个元素之外的所有元素
last返回列表的最后一个元素
init返回除最后一个元素之外的所有元素
::或+:将元素添加到列表的开头,返回新列表
:+或 :::将元素添加到列表的末尾,返回新列表
++将两个列表连接在一起,返回新列表
filter根据给定的条件过滤列表中的元素,返回符合条件的新列表
drop删除前n个元素,返回新列表
dropWhile删除满足指定条件的前缀元素,返回新列表
dropRight删除后n个元素,返回新列表
dropRightWhile删除满足指定条件的后缀元素,返回新列表
updated通过下标更新列表中的元素,返回新列表
patch替换列表中的一部分元素,返回新列表
isEmpty判断列表是否为空
contains判断列表是否包含指定的元素
exists判断列表中是否存在满足指定条件的元素
forall判断列表中的所有元素是否都满足指定条件
foreach对列表的每个元素应用指定的函数
map将列表中的每个元素通过指定的函数进行转换,返回新列表
filter根据指定条件过滤列表中的元素,返回新列表
foldLeft或reduceLeft从左到右对列表的元素进行累积计算
foldRight或reduceRight从右到左对列表的元素进行累积计算

案例

定义数组

scala> val ageList:List[Int] = List(18,28,39,40,12,32,21);
ageList: List[Int] = List(18, 28, 39, 40, 12, 32, 21)
  • 访问元素
# 获取第一个元素
scala> ageList.head
res7: Int = 18# 获取除第一个元素外的所有元素
scala> ageList.tail
res8: List[Int] = List(28, 39, 40, 12, 32, 21)# 获取最后一个元素
scala> ageList.last
res9: Int = 21# 获取除最后一个元素外的所有元素
scala> ageList.init
res10: List[Int] = List(18, 28, 39, 40, 12, 32)
  • 添加元素
# 在列表开头添加元素
scala> 80::ageList
res11: List[Int] = List(80, 18, 28, 39, 40, 12, 32, 21)# 在列表末尾添加元素
scala> ageList :+ 90
res12: List[Int] = List(18, 28, 39, 40, 12, 32, 21, 90)# 连接两个列表
scala> ageList ++ List(70,60)
res13: List[Int] = List(18, 28, 39, 40, 12, 32, 21, 70, 60)
  • 修改元素
# 更新0索引位置的元素为43
scala> ageList.updated(0,43)
res15: List[Int] = List(43, 28, 39, 40, 12, 32, 21)# 替换一部分元素,将索引1,2位置的值替换
scala> ageList.patch(1,List(31,42),2)
res16: List[Int] = List(18, 31, 42, 40, 12, 32, 21)
  • 遍历列表
# 对列表的每个元素应用函数进行遍历打印
scala> ageList.foreach(println);
18
28
39
40
12
32
21# 将列表中的每个元素平方
scala> ageList.map(x => x * x)
res19: List[Int] = List(324, 784, 1521, 1600, 144, 1024, 441)# 过滤出偶数元素
scala> ageList.filter(_%2 == 0)
res20: List[Int] = List(18, 28, 40, 12, 32)# 计算列表元素的累加和
scala> ageList.foldLeft(0)(_+_)
res21: Int = 190
  • 判断列表
# 判断列表是否为空
scala> ageList.isEmpty
res22: Boolean = false# 判断列表是否包含40
scala> ageList.contains(40)
res25: Boolean = true# 判断列表是否存在偶数元素
scala> ageList.filter(_%2==0)
res26: List[Int] = List(18, 28, 40, 12, 32)# 判断列表中的所有元素是否都为正数
scala> ageList.forall(_>0)
res2: Boolean = true
  • 删除元素
# 根据条件过滤元素
scala> ageList.filter(_%2 == 0)
res3: List[Int] = List(18, 28, 40, 12, 32, 70, 60)# 删除前两个元素
scala> ageList.drop(2)
res4: List[Int] = List(39, 40, 12, 32, 21, 70, 60)# 删除小于30的前缀元素
scala> ageList.dropWhile(_<30)
res6: List[Int] = List(39, 40, 12, 32, 21, 70, 60)# 删除后两个元素
scala> ageList.dropRight(2)
res7: List[Int] = List(18, 28, 39, 40, 12, 32, 21)

Set集合

在Scala中,集合(Set)是一个用于存储不重复元素的无序集合

语法

# Scala默认创建的时不可变集合
val 集合名称: Set[数据类型] = Set(集合元素)# 创建一个可变集合
import scala.collection.mutable.Set
val 集合名称: Set[数据类型] = Set(集合元素)# 创建一个不可变集合
import scala.collection.immutable.Set
val 集合名称: Set[数据类型] = Set(集合元素)

集合常用的方法

方法描述
add向集合中添加元素,并返回一个布尔值表示是否成功添加
remove从集合中移除指定元素,并返回一个布尔值表示是否成功移除
contains判断集合中是否包含指定元素
foreach对集合中的每个元素应用指定的函数
map将集合中的每个元素通过指定的函数进行转换,返回新的集合
filter根据指定条件过滤集合中的元素,返回符合条件的新集合

例如

定义集合

# 定义为可变
scala> import scala.collection.mutable.Set;
import scala.collection.mutable.Setscala> val nameSet:Set[String] = Set("张三","李四","王五")
nameSet: scala.collection.mutable.Set[String] = Set(李四, 张三, 王五)
  • 添加元素
scala> nameSet.add("赵六")
res10: Boolean = truescala> nameSet
res11: scala.collection.mutable.Set[String] = Set(李四, 张三, 王五, 赵六)scala> nameSet+"老王"
res12: scala.collection.mutable.Set[String] = Set(老王, 李四, 张三, 王五, 赵六)
  • 删除元素
scala> nameSet.remove("张三")
res14: Boolean = truescala> nameSet
res15: scala.collection.mutable.Set[String] = Set(李四, 王五, 赵六)scala> nameSet - "李四"
res16: scala.collection.mutable.Set[String] = Set(王五, 赵六)
  • 判断集合是否包含某个元素
scala> nameSet.contains("赵六")
res17: Boolean = true
  • 遍历集合
scala> nameSet.foreach(println)
李四
王五
赵六

Map映射

在Scala中,映射(Map)是一种键值对的集合,其中每个键都唯一且与一个值相关联

语法

# Scala默认创建的时不可变映射
val 映射名称:Map[键的数据类型,值的数据类型] = Map(键->)# 创建可变映射
import scala.collection.mutable
val 映射名称:Map[键的数据类型,值的数据类型] = Map(键->)

常用的方法

方法描述
keys返回所有键的集合
values返回所有值的集合
contains检查是否包含键的键值对
exists检查是否包含值的键值对
foreach迭代Map
toList转换为列表
++合并Map
updated更新Map中的值
-删除键值对

例如

定义映射

scala> import scala.collection.mutable
import scala.collection.mutablescala> val nameMap:Map[String,Int] = Map("张三"->28,"李四"->29,"王五"->30)
nameMap: Map[String,Int] = Map(张三 -> 28, 李四 -> 29, 王五 -> 30)
  • 获取所有键或所有值
scala> nameMap.keys
res20: Iterable[String] = Set(张三, 李四, 王五)scala> nameMap.values
res22: Iterable[Int] = MapLike(28, 29, 30)
  • 检查是否包含某个建或值
scala> nameMap.contains("张三")
res23: Boolean = truescala> nameMap.values.exists(_==28)
res24: Boolean = true
  • 迭代Map
scala> nameMap.foreach{| case (key,value) => println(s"Key:$key,Value:$value")| }
Key:张三,Value:28
Key:李四,Value:29
Key:王五,Value:30
  • 转换为列表
scala> nameMap.toList
res27: List[(String, Int)] = List((张三,28), (李四,29), (王五,30))
  • 更新Map中的值
scala> nameMap.updated("王五",20)
res28: scala.collection.immutable.Map[String,Int] = Map(张三 -> 28, 李四 -> 29, 王五 -> 20)
  • 删除键值对
scala> nameMap-"王五"
res29: scala.collection.immutable.Map[String,Int] = Map(张三 -> 28, 李四 -> 29)

元组

在Scala中,元组(Tuple)时一种类似于列表的结构,是一种不同类型的值的集合

语法

val 元组名称 = (元组元素);
// Tuple3中的3元组即元组中包含了3个元素,若定义的时N元组,写成Tuplen
val 元组名称 = new Tuple3(元素元素);

例如

scala> val tuple = (1,"hello",true);
tuple: (Int, String, Boolean) = (1,hello,true)scala> val tuple1 = new Tuple3(2,"Hi",3.14)
tuple1: (Int, String, Double) = (2,Hi,3.14)
  • 获取元素

_N:通过索引获取元素的第N个元素,索引从1开始

scala> tuple._1
res30: Int = 1scala> tuple._2
res31: String = helloscala> tuple._3
res32: Boolean = true
  • 转换为列表
scala> tuple.productIterator.toList
res33: List[Any] = List(1, hello, true)
  • 合并元组
scala> tuple ++ tuple1
scala> Tuple.concat(tuple,tuple1)

关键字

  • Unit :表示无值,等同于Java中的void

  • abstract:抽象类、抽象方法

  • case:模式匹配中的一个分支

  • class:类定义

  • def:方法/函数定义

  • do:do-while循环的开始

  • else:if条件的分支

  • extends:类的继承

  • false:布尔值false

  • final:不可继承、重写或修改的修饰符

  • for:for循环

  • if:条件语句

  • implicit:隐式转换

  • import:导入其他包或类

  • match:模式匹配

  • new:创建对象

  • null:空值

  • object:单例对象或伴生对象

  • override:重写父类或特质中的方法

  • package:包定义

  • private:私有访问权限

  • protected:受保护的访问权限

  • return:返回值

  • sealed:密封类

  • super:父类引用

  • this:当前类或对象的引用

  • throw:抛出异常

  • trait:特质定义

  • true:布尔值true

  • try:异常处理

  • type:类型别名

  • val:不可变变量声明

  • var:可变变量声明

  • while:while循环

  • with:混入特质

  • yield:生成器

idea关联Scala

创建maven项目

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-4uNor5ep-1693212887659)(E:\Java笔记\大数据\Scala\Scala.assets\image-20230828162019013.png)]

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-lgwU9XK3-1693212887659)(E:\Java笔记\大数据\Scala\Scala.assets\image-20230828162108960.png)]

配置maven仓库

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-IKpAdeaz-1693212887660)(E:\Java笔记\大数据\Scala\Scala.assets\image-20230828162200365.png)]

添加Scala插件

在这里插入图片描述

添加相关依赖

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>com.sin</groupId><artifactId>Demo-scala</artifactId><version>1.0-SNAPSHOT</version><dependencies><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.13.2</version><scope>test</scope></dependency><dependency><groupId>org.apache.spark</groupId><artifactId>spark-sql_2.12</artifactId><version>3.3.1</version></dependency><dependency><groupId>org.apache.spark</groupId><artifactId>spark-hive_2.11</artifactId><version>2.1.1</version></dependency><dependency><groupId>org.apache.spark</groupId><artifactId>spark-graphx_2.11</artifactId><version>2.1.1</version></dependency><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>5.1.47</version></dependency></dependencies></project>

添加scala的SDK
需要将其提前安装好:安装Scala
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Q2lxpStD-1693212887660)(E:\Java笔记\大数据\Scala\Scala.assets\image-20230828163232124.png)]

创建Scala文件

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-1AtqgWqh-1693212887661)(E:\Java笔记\大数据\Scala\Scala.assets\image-20230828163533181.png)]

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-bOTwnqVl-1693212887661)(E:\Java笔记\大数据\Scala\Scala.assets\image-20230828163614831.png)]

案例

package com.sin/*** @CreateName SIN* @CreateDate 2023/08/28 16:36* @description*/
object HelloWorld {def main(args: Array[String]): Unit = {println("Hello, World!")}}

阶乘

package com.sin/*** @CreateName SIN* @CreateDate 2023/08/28 16:36* @description*/
object Factorial {def factorial(n: Int): Int = {if (n == 0) 1else n * factorial(n - 1)}def main(args: Array[String]): Unit = {val result = factorial(5)println(result) // 输出120}}

素数

package com.sin/*** @CreateName SIN* @CreateDate 2023/08/28 16:36* @description*/
object IsPrime {def isPrime(num: Int): Boolean = {if (num <= 1) falseelse if (num == 2) trueelse !(2 to (Math.sqrt(num).toInt + 1)).exists(x => num % x == 0)}def main(args: Array[String]): Unit = {println(isPrime(7)) // 输出trueprintln(isPrime(15)) // 输出false}}

列表中最大的数

package com.sin/*** @CreateName SIN* @CreateDate 2023/08/28 16:36* @description*/
object ListMax {def main(args: Array[String]): Unit = {val numbers = List(2, 8, 1, 6, 10, 4)val maxNumber = numbers.maxprintln(maxNumber) // 输出10}
}

计算列表中所有的和

package com.sin/*** @CreateName SIN* @CreateDate 2023/08/28 16:36* @description*/
object HelloWorld {def main(args: Array[String]): Unit = {val numbers = List(1, 2, 3, 4, 5)val sum = numbers.sumprintln(sum) // 输出15}}

遍历列表

package com.sin/*** @CreateName SIN* @CreateDate 2023/08/28 16:36* @description*/
object ForEachList {def main(args: Array[String]): Unit = {val fruits = List("apple", "banana", "orange")fruits.foreach(println)// 输出:// apple// banana// orange}
}

判断天气

package com.sin/*** @CreateName SIN* @CreateDate 2023/08/28 16:36* @description*/
object IfWeather {def main(args: Array[String]): Unit = {println(weatherType("sunny")) // 输出It's a sunny day!println(weatherType("snowy")) // 输出Unknown weather type.}def weatherType(weather: String): String = weather match {case "sunny" => "It's a sunny day!"case "cloudy" => "It's a cloudy day."case "rainy" => "Don't forget your umbrella!"case _ => "Unknown weather type."}
}

九九乘法表

package com.sin/*** @CreateName SIN* @CreateDate 2023/08/28 16:36* @description*/
object Multiplication {def main(args: Array[String]): Unit = {for (i <- 1 to 9; j <- 1 to i) {print(s"$j * $i = ${i * j}\t")if (i == j) println()}}
}

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

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

相关文章

如何设计一个好的游戏剧情(Part 1:主题的设定)

提醒&#xff1a;此教程仅仅为作者的一些经验和感悟&#xff0c;非专业教程&#xff0c;若介意请前往网上搜集或者书本查阅相关资料&#xff01; 前言&#xff1a;游戏为什么要有剧情——游戏剧情的重要性 游戏剧情的重要性难以低估。一个精彩的剧情可以让玩家感受到强烈的情感…

华为OD:敏感字段加密

题目描述&#xff1a; 给定一个由多个命令字组成的命令字符串&#xff1a; 1、字符串长度小于等于127字节,只包含大小写字母,数字,下划线和偶数个双引号&#xff1b; 2、命令字之间以一个或多个下划线_进行分割&#xff1b; 3、可以通过两个双引号”"来标识包含下划线…

抽象轻松c语言

目 c语言 c程序 c语言的核心在于语言&#xff0c;语言的作用是进行沟通&#xff0c;人与人之间的信息交换 人与人之间的信息交换是会有信息空白&#xff08;A表达信息&#xff0c;B接受信息&#xff0c;B对信息的处理会与A所以表达的信息具有差距&#xff0c;这段差距称为信…

keras深度学习框架通过简单神经网络实现手写数字识别

背景 keras深度学习框架&#xff0c;并不是一个独立的深度学习框架&#xff0c;它后台依赖tensorflow或者theano。大部分开发者应该使用的是tensorflow。keras可以很方便的像搭积木一样根据模型搭出我们需要的神经网络&#xff0c;然后进行编译&#xff0c;训练&#xff0c;测试…

用迅为i.MX6ULL开发板同一个网段概念

使用 nfs 之前&#xff0c;开发板、虚拟机 ubuntu、windows 电脑三者要互相 ping 通&#xff0c;这就涉及到了同一个网段 的概念。 概念&#xff1a;同一个网段是指 IP 地址和子网掩码相与得到的相同的网络地址。 快速判断同一个网段&#xff1a; &#xff08;1&#xff09…

JVM 是怎么设计来保证new对象的线程安全

1、采用 CAS 分配重试的方式来保证更新操作的原子性 2、每个线程在 Java 堆中预先分配一小块内存&#xff0c;也就是本地线程分配缓冲&#xff08;Thread Local AllocationBuffer&#xff0c;TLAB&#xff09;&#xff0c;要分配内存的线程&#xff0c;先在本地缓冲区中分配&a…

windows server 2019 安装sqlserver2012

在安装前&#xff0c;应先关闭系统防火墙 双击exe 选择【全新SQL Server独立安装或向现有安装添加功能】选项 运行完成后&#xff0c;如无失败或警告&#xff0c;点击确定&#xff0c;如果出现警告&#xff0c;需要处理掉再继续执行 点击下一步 勾选接受许可&#xff0c;点击下…

云原生Kubernetes:K8S概述

目录 一、理论 1.云原生 2.K8S 3.k8s集群架构与组件 二、总结 一、理论 1.云原生 &#xff08;1&#xff09;概念 云原生是一种基于容器、微服务和自动化运维的软件开发和部署方法。它可以使应用程序更加高效、可靠和可扩展&#xff0c;适用于各种不同的云平台。 如果…

【微服务部署】一、使用docker-compose部署Jenkins、SonarQube、PostgreSQL

一、安装 1、编写docker-compose部署Postgres、SonarQube、Jenkins的yml文件jenkins-compose.yml Postgres&#xff1a;作为SonarQube的数据库存储SonarQube&#xff1a;代码质量检查Jenkins&#xff1a;jenkins/jenkins:lts镜像&#xff0c;jenkinsci/blueocean镜像缺少node…

解决 filezilla 连接服务器失败问题

问题描述&#xff1a; 开始一直用的 XFTP 后来&#xff0c;它变成收费软件了&#xff0c;所以使用filezilla 代替 XFTP 之前用的还好好的&#xff0c;今天突然就报错了&#xff1a;按要求输入相关字段&#xff0c;连接 连接失败&#xff01;&#xff01;&#xff01;o(╥﹏╥…

使用 BERT 进行文本分类 (03/3)

一、说明 在使用BERT&#xff08;2&#xff09;进行文本分类时&#xff0c;我们讨论了什么是PyTorch以及如何预处理我们的数据&#xff0c;以便可以使用BERT模型对其进行分析。在这篇文章中&#xff0c;我将向您展示如何训练分类器并对其进行评估。 二、准备数据的又一个步骤 …

友元(个人学习笔记黑马学习)

1、全局函数做友元 #include <iostream> using namespace std; #include <string>//建筑物类 class Building {//goodGay全局函数是 Building好朋友 可以访问Building中私有成员friend void goodGay(Building* building);public:Building() {m_SittingRoom "…

信息熵 条件熵 交叉熵 联合熵 相对熵(KL散度) 互信息(信息增益)

粗略版快速总结 条件熵 H ( Q ∣ P ) 联合熵 H ( P , Q ) − H ( P ) 条件熵H(Q∣P)联合熵H(P,Q)−H(P) 条件熵H(Q∣P)联合熵H(P,Q)−H(P) 信息增益 I ( P , Q ) H ( P ) − H ( P ∣ Q ) H ( P ) H ( Q ) − H ( P , Q ) 信息增益 I(P,Q)H(P)−H(P∣Q)H(P)H(Q)-H(P,Q) 信息…

企业架构LNMP学习笔记10

1、Nginx版本&#xff0c;在实际的业务场景中&#xff0c;需要使用软件新版本的功能、特性。就需要对原有软件进行升级或重装系统。 Nginx的版本需要升级迭代。那么如何进行升级呢&#xff1f;线上服务器如何升级&#xff0c;我们选择稳定版本。 从nginx的1.14版本升级到ngin…

Linux系统中驱动入门设备树DTS(经典)

设备树&#xff08;DTS:device tree source&#xff09;&#xff0c;字面意思就是一块电路板上设备如上图中CPU、DDR、I2C、GPIO、SPI等&#xff0c;按照树形结构描绘成的一棵树。按照策略和功能分离的思路&#xff0c;就是驱动代码&#xff08;功能&#xff09;和设备树DTS配置…

IIR滤波器

IIR滤波器原理 IIR的特点是&#xff1a;非线性相位、消耗资源少。 IIR滤波器的系统函数与差分方程如下所示&#xff1a; 由差分方程可知IIR滤波器存在反馈&#xff0c;因此在FPGA设计时要考虑到有限字长效应带来的影响。差分方程中包括两个部分&#xff1a;输入信号x(n)的M节…

Git中smart Checkout与force checkout

Git中smart Checkout与force checkout 使用git进行代码版本管理,当我们切换分支有时会遇到这样的问题&#xff1a; 这是因为在当前分支修改了代码&#xff0c;但是没有commit,所以在切换到其他分支的时候会弹出这个窗口&#xff0c; 提示你选force checkout或者smart checko…

Redis缓存和持久化

目录 Redis缓存 什么是缓存 缓存更新策略​编辑 业务场景 缓存穿透 常见的解决方案 缓存雪崩 解决方案 缓存击穿 解决方案 Redis持久化 RDB持久化 执行时机 RDB方式bgsave的基本流程 AOF持久化 RDB和AOF的对比​编辑 Redis主从 数据同步原理 总结 Redis缓存 …

2、Nginx 安装

文章目录 2、Nginx 安装2.1 官网下载2.2 安装 nginx2.2.1 第一步2.2.2 第二步2.2.3 第三步&#xff0c;安装 nginx2.2.4 第四步&#xff0c;修改防火漆规则 【尚硅谷】尚硅谷Nginx教程由浅入深 志不强者智不达&#xff1b;言不信者行不果。 2、Nginx 安装 2.1 官网下载 nginx…

iOS - 资源按需加载 - ODR

一、瘦身技术大图 二、On-Demand Resources 简介 将其保存管理在苹果的服务器&#xff0c;按需使用资源、优化包体积&#xff0c;实现更小的应用程序。ODR 的好处&#xff1a; 应用体积更小&#xff0c;下载更快&#xff0c;提升初次启动速度资源会在后台下载操作系统将会在磁…