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)]](https://img-blog.csdnimg.cn/bd30fc7fc7104c92b8715353b7f54ce7.png)
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-lgwU9XK3-1693212887659)(E:\Java笔记\大数据\Scala\Scala.assets\image-20230828162108960.png)]](https://img-blog.csdnimg.cn/96c9922392964cb998bd26678e672bc3.png)
配置maven仓库
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-IKpAdeaz-1693212887660)(E:\Java笔记\大数据\Scala\Scala.assets\image-20230828162200365.png)]](https://img-blog.csdnimg.cn/dc6c0d4127da47979bc45ba8103ea705.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)]](https://img-blog.csdnimg.cn/5b339b106a1b4f5a84c9272f0b641002.png)
创建Scala文件
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-1AtqgWqh-1693212887661)(E:\Java笔记\大数据\Scala\Scala.assets\image-20230828163533181.png)]](https://img-blog.csdnimg.cn/d68ce4ecbcec48b1b521a1ab6ee2b557.png)
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-bOTwnqVl-1693212887661)(E:\Java笔记\大数据\Scala\Scala.assets\image-20230828163614831.png)]](https://img-blog.csdnimg.cn/ed595db247a94dc79ad8aa0af4a1e749.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()}}
}
相关文章:
Scala入门,idea关联Scala
Scala 介绍 Scala是一种多规范的编程语言,它结合了面向对象编程(OOP)和函数式编程(FP)的特征,Scala的名字源于”Scalable language“,意为”可伸缩语言“。2003年开发的,并在JVM&a…...
3DCAT携手华为,打造XR虚拟仿真实训实时云渲染解决方案
2023年5月8日-9日,以 因聚而生 众志有为 为主题的 华为中国合作伙伴大会2023 在深圳国际会展中心隆重举行。本次大会汇聚了ICT产业界的广大新老伙伴朋友,共同探讨数字化转型的新机遇,共享数字化未来的新成果。 华为中国合作伙伴大会2023现场&…...
Spring Security注销后未正确保存空的SecurityContext漏洞CVE-2023-20862
文章目录 0.前言漏洞Spring Security介绍 1.参考文档2.基础介绍3.解决方案3.1. 升级版本3.2. 临时替代方案 4.Spring Security使用教程简单代码示例 0.前言 背景:公司项目扫描到 Spring-security 组件 注销后未正确保存空的SecurityContext CVE-2023-20862 漏洞 高…...
11、监测数据采集物联网应用开发步骤(8.2)
监测数据采集物联网应用开发步骤(8.1) 新建TCP/IP Client线程类com.zxy.tcp.ClientThread.py #! python3 # -*- coding: utf-8 -Created on 2017年05月10日 author: zxyong 13738196011 import datetime import socket import threading import timefrom com.zxy.adminlog.Us…...
【PWN · ret2text | RISC-V异构】[2023 羊城杯]login
第一道异构PWN的题目,没做出来。。。。但是是因为工具没有 QAQ 目录 前言 一、食用工具 Ghidra 安装使用 二、解题思路 三、exp 总结 前言 我们context.arch经常是i386和amd64,突然遇到RISC-V架构的题目,一是本地运行不了(…...
【HBZ分享】TCP可靠性传输如何保证的?以及传输优化之Nagle算法
ACK机制 ACK机制是发送方与接收方的一个相互确认客户端向服务端发送连接请求,此时服务端要回馈给客户端ACK,以表示服务端接到了客户端请求,这是第一和的第二次握手客户端接收到服务端响应后,同样也要回馈服务端的响应,…...
智能电销机器人,主要体现的价值是什么
21世纪科技的迅速发展,人工智能逐渐走入大家的视线,越来越多的机器人出现在我们生活中。见的最多的有电销公司的智能语音机器人、在仓库拣货打包的机器人、商场店铺供娱乐对话的机器人。机器人活跃在各行各业中,降低了人工成本,代…...
Win7系统电脑开机总出现硬盘自检的简单解决方法
你是不是经常会遇到电脑开机进行硬盘自检,而且每次开机都检查很久不能跳过;怎么才能跳过这一步骤呢?下面教大家如何让Win7系统电脑在开机的时候跳过硬盘自检这一步骤,加快开机时间。 解决步骤: 1、按下“Win R”快捷键…...
计网第四章(网络层)(五)
目录 静态路由配置 默认路由: 特定主机路由: 示例: 广播域和冲突域: 静态路由配置 在第四节(计网第四章(网络层)(四)_永无魇足的博客-CSDN博客)有提到过…...
ios 手机浏览器,点击输入框页面会放大
一个普通的h5静态页面,在ios手机上用浏览器打开,发现每次聚焦输入框的时候整个页面都会放大! 解决办法在html的头部meta标签中设置 user-scalableno viewport meta 标记 - HTML(超文本标记语言) | MDN...
全局异常处理
案例一: 自定义异常 public class StudentException extends RuntimeException {private Integer code;private String msg;public StudentException(Integer code, String msg) {this.code code;this.msg msg;}/*** 这里需要重写 getMessage方法,否…...
更健康舒适更科技的照明体验!SUKER书客护眼台灯 L1上手体验
低价又好用的护眼台灯是多数人的需求,很多人只追求功能性护眼台灯,显色高、无频闪、无蓝光等基础需求。但是在较低价格中很难面面俱到,然而刚发布的SUKER书客L1护眼台灯却是一款不可多得的性价比护眼台灯,拥有高品质光源ÿ…...
Locked勒索病毒:最新变种.locked袭击了您的计算机?
导言: 在今天的数字时代,勒索病毒已经不再是仅仅让数据变得不可访问的小威胁。 .locked 勒索病毒,作为其中的一种,以其高度复杂的加密算法和迅速变化的攻击手法而备受恶意分子喜爱。本文91数据恢复将带您深入了解 .locked 勒索病毒…...
随机森林算法
介绍 随机森林是一种基于集成学习的有监督机器学习算法。随机森林是包含多个决策树的分类器,一般输出的类别是由决策树的众数决定。随机森林也可以用于常见的回归拟合。随机森林主要是运用了两种思想。具体如下所示。 Breimans的Bootstrap aggregatingHo的random …...
如何将国标规范用EndNote插入到英文期刊中,自定义文献插入指南
EndNote自定义文献 1.插入国标JTG 2034-2020这种新建一个StandardReference填入信息参考 插入英文期刊规范ASTM 1.插入国标JTG 2034-2020这种 首先找到大家要投稿的英文期刊,然后去找那些中…...
重写 UGUI
重写Button using UnityEngine; using UnityEngine.UI; public class MyButton : Button {[SerializeField] private int _newNumber; }using UnityEditor;//编辑器类在UnityEditor命名空间下。所以当使用C#脚本时,你需要在脚本前面加上 "using UnityEditor&q…...
合宙Air724UG LuatOS-Air LVGL API控件--容器 (Container)
容器 (Container) 容器是 lvgl 相当重要的一个控件了,可以设置布局,容器的大小也会自动进行调整,利用容器可以创建出自适应成都很高的界面布局。 代码示例 – 创建容器 cont lvgl.cont_create(lvgl.scr_act(), nil) lvgl.obj_set_auto_re…...
代码随想录训练营第41天|343.整数拆分,96.不同的二叉搜索树
代码随想录训练营第41天|343.整数拆分,96.不同的二叉搜索树 343.整数拆分文章思路代码 96.不同的二叉搜索树文章思路代码 总结 343.整数拆分 文章 代码随想录|0343.整数拆分 思路 二刷不难 d p [ i ] M a x j ( m a x ( j 1 , d p [ j ] ) ∗ ( i − j ) ) \…...
高防服务器与云防产品都适用哪些情况
高防服务器与云防护产品(如高防IP,高防CDN)都可以对DDOS、CC等攻击进行防护,在现如今的互联网市场上,不法分子经常会通过DDOS、CC等攻击服务器,干扰业务正常运行,以此来获得利益。 高防服务器是…...
【广州华锐互动】AR远程连接专家进行协同管理,解放双手让协同更便捷
AR远程协同系统是一种基于AR技术,实现远程设备维修和技术支持的系统。该系统通过将虚拟信息叠加在现实世界中,实现对设备的全方位监控和管理,并可以通过AR眼镜等终端设备,实时查看设备的各项数据和信息,为设备维修提供…...
ES6从入门到精通:前言
ES6简介 ES6(ECMAScript 2015)是JavaScript语言的重大更新,引入了许多新特性,包括语法糖、新数据类型、模块化支持等,显著提升了开发效率和代码可维护性。 核心知识点概览 变量声明 let 和 const 取代 var…...
高等数学(下)题型笔记(八)空间解析几何与向量代数
目录 0 前言 1 向量的点乘 1.1 基本公式 1.2 例题 2 向量的叉乘 2.1 基础知识 2.2 例题 3 空间平面方程 3.1 基础知识 3.2 例题 4 空间直线方程 4.1 基础知识 4.2 例题 5 旋转曲面及其方程 5.1 基础知识 5.2 例题 6 空间曲面的法线与切平面 6.1 基础知识 6.2…...
技术栈RabbitMq的介绍和使用
目录 1. 什么是消息队列?2. 消息队列的优点3. RabbitMQ 消息队列概述4. RabbitMQ 安装5. Exchange 四种类型5.1 direct 精准匹配5.2 fanout 广播5.3 topic 正则匹配 6. RabbitMQ 队列模式6.1 简单队列模式6.2 工作队列模式6.3 发布/订阅模式6.4 路由模式6.5 主题模式…...
【7色560页】职场可视化逻辑图高级数据分析PPT模版
7种色调职场工作汇报PPT,橙蓝、黑红、红蓝、蓝橙灰、浅蓝、浅绿、深蓝七种色调模版 【7色560页】职场可视化逻辑图高级数据分析PPT模版:职场可视化逻辑图分析PPT模版https://pan.quark.cn/s/78aeabbd92d1...
基于PHP的连锁酒店管理系统
有需要请加文章底部Q哦 可远程调试 基于PHP的连锁酒店管理系统 一 介绍 连锁酒店管理系统基于原生PHP开发,数据库mysql,前端bootstrap。系统角色分为用户和管理员。 技术栈 phpmysqlbootstrapphpstudyvscode 二 功能 用户 1 注册/登录/注销 2 个人中…...
Vue ③-生命周期 || 脚手架
生命周期 思考:什么时候可以发送初始化渲染请求?(越早越好) 什么时候可以开始操作dom?(至少dom得渲染出来) Vue生命周期: 一个Vue实例从 创建 到 销毁 的整个过程。 生命周期四个…...
HTML前端开发:JavaScript 获取元素方法详解
作为前端开发者,高效获取 DOM 元素是必备技能。以下是 JS 中核心的获取元素方法,分为两大系列: 一、getElementBy... 系列 传统方法,直接通过 DOM 接口访问,返回动态集合(元素变化会实时更新)。…...
前端开发者常用网站
Can I use网站:一个查询网页技术兼容性的网站 一个查询网页技术兼容性的网站Can I use:Can I use... Support tables for HTML5, CSS3, etc (查询浏览器对HTML5的支持情况) 权威网站:MDN JavaScript权威网站:JavaScript | MDN...
加密通信 + 行为分析:运营商行业安全防御体系重构
在数字经济蓬勃发展的时代,运营商作为信息通信网络的核心枢纽,承载着海量用户数据与关键业务传输,其安全防御体系的可靠性直接关乎国家安全、社会稳定与企业发展。随着网络攻击手段的不断升级,传统安全防护体系逐渐暴露出局限性&a…...
TJCTF 2025
还以为是天津的。这个比较容易,虽然绕了点弯,可还是把CP AK了,不过我会的别人也会,还是没啥名次。记录一下吧。 Crypto bacon-bits with open(flag.txt) as f: flag f.read().strip() with open(text.txt) as t: text t.read…...
