SparkCore学习笔记

一. RDD概述

1.1 什么是RDD

	RDD 叫做弹性分布式数据集,是Spark中最基本的数据抽象。它代表的是一个弹性的、不可变、可分区、里面的元素可并行计算的集合。
1.1.1WordCount工作流程

在这里插入图片描述

	首先在yarn模式下将生成的WordCount的Jar包导入,然后启动bin/spark-submit --class WordCount --master yarn --deploy-mode cluster WordCount.jar /input /output   然后向yarn提交submit,在Container容器里开启Driver,然后再开启Executor,textFile从HDFS上读取数据,在Executor上调用FlatMap方法,接收lineRDD传过来的数据,FlatMap处理以后调用map方法,然后调用reduceByKey方法,reduceBykey方法调用的时候会进行shuffler,对数据进行打散、混洗、聚合,同时,在这个阶段数据会落盘。然后调用collect,收集的数据最后传回Driver.
注意
1.所有的RDD算子相关操作都在Executor端执行,RDD算子之外的操作都在Driver端执行
2.Spark中,只有遇到action等行动算子,才会执行RDD的计算(即延迟计算)
RDD几大特点
1) 弹性存储的弹性:内存和磁盘自动切换容错的弹性:数据丢失可以自动恢复计算的弹性:计算出错重试机制分片的弹性:可根据需要重新分片
2) 分布式数据存储在大数据集群的不同节点上
3) 数据集,不存储数据RDD封装了计算逻辑,并不保存数据
4) 数据抽象RDD是一个抽象类,需要子类具体实现
5)不可变RDD封装了计算逻辑,是不可以改变的,想要改变只能产生新的RDD,在新的RDD里面封装计算逻辑
6)可分区,并行计算

1.2 RDD的五大特性

在这里插入图片描述

二. RDD编程

2.1 RDD的创建

在Spark中创建RDD的创建方式可以分为三种:从集合中创建RDD、从外部存储创建RDD、从其他RDD创建。
2.1.1 从集合中创建

1)从集合中创建RDD,Spark主要提供了两种函数:parallelize和makeRDD

import org.apache.spark.rdd.RDD
import org.apache.spark.{SparkConf, SparkContext}object createrdd01_array {def main(args: Array[String]): Unit = {//1.创建SparkConf并设置App名称val conf: SparkConf = new SparkConf().setAppName("SparkCoreTest").setMaster("local[*]")//2.创建SparkContext,该对象是提交Spark App的入口val sc: SparkContext = new SparkContext(conf)//3.使用parallelize()创建rddval rdd: RDD[Int] = sc.parallelize(Array(1, 2, 3, 4, 5, 6, 7, 8))rdd.collect().foreach(println)//4.使用makeRDD()创建rddval rdd1: RDD[Int] = sc.makeRDD(Array(1, 2, 3, 4, 5, 6, 7, 8))rdd1.collect().foreach(println)sc.stop()}
}

注意:makeRDD有两种重构方法,重构方法一如下,makeRDD和parallelize功能一样。

def makeRDD[T: ClassTag](seq: Seq[T],numSlices: Int = defaultParallelism): RDD[T] = withScope {parallelize(seq, numSlices)
}

2)makeRDD的重构方法二,增加了位置信息

注意:只需要知道makeRDD不完全等于parallelize即可。

def makeRDD[T: ClassTag](seq: Seq[(T, Seq[String])]): RDD[T] = withScope {assertNotStopped()val indexToPrefs = seq.zipWithIndex.map(t => (t._2, t._1._2)).toMapnew ParallelCollectionRDD[T](this, seq.map(_._1), math.max(seq.size, 1), indexToPrefs)
}

在大部分情况下,我们采用makeRDD方法!

2.1.2 从外部存储系统的数据集创建

由外部存储系统的数据集创建RDD包括:本地的文件系统,还有所有Hadoop支持的数据集,比如HDFS、HBase等。

1)数据准备

在新建的SparkCoreTest项目名称上右键=>新建input文件夹=>在input文件夹上右键=>分别新建1.txt和2.txt。每个文件里面准备一些word单词。

2)创建RDD

import org.apache.spark.rdd.RDD
import org.apache.spark.{SparkConf, SparkContext}object createrdd02_file {def main(args: Array[String]): Unit = {//1.创建SparkConf并设置App名称val conf: SparkConf = new SparkConf().setAppName("SparkCoreTest").setMaster("local[*]")//2.创建SparkContext,该对象是提交Spark App的入口val sc: SparkContext = new SparkContext(conf)//3.读取文件。如果是集群路径:hdfs://hadoop102:9000/inputval lineWordRdd: RDD[String] = sc.textFile("input")//4.打印lineWordRdd.foreach(println)//5.关闭sc.stop()}
}
2.1.3 从其他RDD创建

主要是通过一个RDD运算完后,再产生新的RDD。

2.2 分区规则

2.2.1 默认分区源码(RDD数据从集合中创建)

1)默认分区数源码解读
在这里插入图片描述

2)代码

import org.apache.spark.rdd.RDD
import org.apache.spark.{SparkConf, SparkContext}object partition01_default {def main(args: Array[String]): Unit = {//1.创建SparkConf并设置App名称val conf: SparkConf = new SparkConf().setAppName("SparkCoreTest").setMaster("local[*]")//2.创建SparkContext,该对象是提交Spark App的入口val sc: SparkContext = new SparkContext(conf)val rdd: RDD[Int] = sc.makeRDD(Array(1,2,3,4))//3. 输出数据,产生了8个分区rdd.saveAsTextFile("output")//4.关闭连接sc.stop()}
}
2.2.2 分区源码(RDD数据从集合中创建)

1)分区测试(RDD数据从集合中创建)

object partition02_Array {def main(args: Array[String]): Unit = {val conf: SparkConf = new SparkConf().setMaster("local[*]").setAppName("SparkCoreTest")val sc: SparkContext = new SparkContext(conf)//1)4个数据,设置4个分区,输出:0分区->1,1分区->2,2分区->3,3分区->4//val rdd: RDD[Int] = sc.makeRDD(Array(1, 2, 3, 4), 4)//2)4个数据,设置3个分区,输出:0分区->1,1分区->2,2分区->3,4//val rdd: RDD[Int] = sc.makeRDD(Array(1, 2, 3, 4), 3)//3)5个数据,设置3个分区,输出:0分区->1,1分区->2、3,2分区->4、5val rdd: RDD[Int] = sc.makeRDD(Array(1, 2, 3, 4, 5), 3)rdd.saveAsTextFile("output")sc.stop()}
}

2)分区源码

在这里插入图片描述

分区的开始位置 = 分区号 * 数据总长度/分区总数

分区的结束位置 =(分区号 + 1) 数据总长度/分区总数*

2.2.3 默认分区源码(RDD数据从文件中读取后创建)

1)分区测试

object partition03_file_default {def main(args: Array[String]): Unit = {val conf: SparkConf = new SparkConf().setMaster("local[*]").setAppName("SparkCoreTest")val sc: SparkContext = new SparkContext(conf)//1)默认分区的数量:默认取值为当前核数和2的最小值//val rdd: RDD[String] = sc.textFile("input")rdd.saveAsTextFile("output")sc.stop()}
}

2)分区源码
在这里插入图片描述

2.2.4 分区源码(RDD数据从文件中读取后创建)

1)分区测试

object partition04_file {def main(args: Array[String]): Unit = {val conf: SparkConf = new SparkConf().setMaster("local[*]").setAppName("SparkCoreTest")val sc: SparkContext = new SparkContext(conf)//1)输入数据1-4,每行一个数字;输出:0=>{1、2} 1=>{3} 2=>{4} 3=>{空}//val rdd: RDD[String] = sc.textFile("input/3.txt", 3)rdd.saveAsTextFile("output")sc.stop()}
}

2)源码解析

在这里插入图片描述

注意:getSplits文件返回的是切片规划,真正读取是在compute方法中创建LineRecordReader读取的,有两个关键变量: start = split.getStart() end = start + split.getLength

2.3 Transformation转换算子

RDD整体上分为Value类型、双Value类型和Key-Value类型

2.3.1 Value类型
2.3.1.1 map()映射

map算子

在这里插入图片描述

代码实现

object value01_map {def main(args: Array[String]): Unit = {//1.创建SparkConf并设置App名称val conf = new SparkConf().setAppName("SparkCoreTest").setMaster("local[*]")//2.创建SparkContext,该对象是提交Spark App的入口val sc = new SparkContext(conf)//3具体业务逻辑// 3.1 创建一个RDDval rdd: RDD[Int] = sc.makeRDD(1 to 4, 2)// 3.2 调用map方法,每个元素乘以2val mapRdd: RDD[Int] = rdd.map(_ * 2)// 3.3 打印修改后的RDD中数据mapRdd.collect().foreach(println)//4.关闭连接sc.stop()}
}
2.3.1.2 mapPartitions()以分区为单位执行Map

mapPartitions算子

在这里插入图片描述

代码实现

object value02_mapPartitions {def main(args: Array[String]): Unit = {//1.创建SparkConf并设置App名称val conf = new SparkConf().setAppName("SparkCoreTest").setMaster("local[*]")//2.创建SparkContext,该对象是提交Spark App的入口val sc = new SparkContext(conf)//3具体业务逻辑// 3.1 创建一个RDDval rdd: RDD[Int] = sc.makeRDD(1 to 4, 2)// 3.2 调用mapPartitions方法,每个元素乘以2val rdd1 = rdd.mapPartitions(x=>x.map(_*2))// 3.3 打印修改后的RDD中数据rdd1.collect().foreach(println)//4.关闭连接sc.stop()}
}
2.3.1.3 map()和mapPartitions()区别

在这里插入图片描述

2.3.1.4 mapPartitionsWithIndex()带分区号

1)函数签名:

​ def mapPartitionsWithIndex[U: ClassTag](

​ f: (Int, Iterator[T]) => Iterator[U], // Int表示分区编号

​ preservesPartitioning: Boolean = false): RDD[U]

2)功能说明:类似于mapPartitions,比mapPartitions多一个整数参数表示分区号

3)需求说明:创建一个RDD,使每个元素跟所在分区号形成一个元组,组成一个新的RDD

在这里插入图片描述

代码实现

object value03_mapPartitionsWithIndex {def main(args: Array[String]): Unit = {//1.创建SparkConf并设置App名称val conf = new SparkConf().setAppName("SparkCoreTest").setMaster("local[*]")//2.创建SparkContext,该对象是提交Spark App的入口val sc = new SparkContext(conf)//3具体业务逻辑// 3.1 创建一个RDDval rdd: RDD[Int] = sc.makeRDD(1 to 4, 2)// 3.2 创建一个RDD,使每个元素跟所在分区号形成一个元组,组成一个新的RDDval indexRdd = rdd.mapPartitionsWithIndex( (index,items)=>{items.map( (index,_) )} )// 3.3 打印修改后的RDD中数据indexRdd.collect().foreach(println)//4.关闭连接sc.stop()}
}
2.3.1.5 flatMap()扁平化

1)函数签名:def flatMap[U: ClassTag](f: T => TraversableOnce[U]): RDD[U]

2)功能说明

与map操作类似,将RDD中的每一个元素通过应用f函数依次转换为新的元素,并封装到RDD中。

区别:在flatMap操作中,f函数的返回值是一个集合,并且会将每一个该集合中的元素拆分出来放到新的RDD中。

3)需求说明:创建一个集合,集合里面存储的还是子集合,把所有子集合中数据取出放入到一个大的集合中。

在这里插入图片描述

代码实现

object value04_flatMap {def main(args: Array[String]): Unit = {//1.创建SparkConf并设置App名称val conf = new SparkConf().setAppName("SparkCoreTest").setMaster("local[*]")//2.创建SparkContext,该对象是提交Spark App的入口val sc = new SparkContext(conf)//3具体业务逻辑// 3.1 创建一个RDDval listRDD=sc.makeRDD(List(List(1,2),List(3,4),List(5,6),List(7)), 2)// 3.2 把所有子集合中数据取出放入到一个大的集合中listRDD.flatMap(list=>list).collect.foreach(println)//4.关闭连接sc.stop()}
}
2.3.1.6 glom()分区转换数组

1)函数签名:def glom(): RDD[Array[T]]

2)功能说明

​ 该操作将RDD中每一个分区变成一个数组,并放置在新的RDD中,数组中元素的类型与原分区中元素类型一致

3)需求说明:创建一个2个分区的RDD,并将每个分区的数据放到一个数组,求出每个分区的最大值

在这里插入图片描述

代码实现

object value05_glom {def main(args: Array[String]): Unit = {//1.创建SparkConf并设置App名称val conf = new SparkConf().setAppName("SparkCoreTest").setMaster("local[*]")//2.创建SparkContext,该对象是提交Spark App的入口val sc = new SparkContext(conf)//3具体业务逻辑// 3.1 创建一个RDDval rdd = sc.makeRDD(1 to 4, 2)// 3.2 求出每个分区的最大值  0->1,2   1->3,4val maxRdd: RDD[Int] = rdd.glom().map(_.max)// 3.3 求出所有分区的最大值的和 2 + 4println(maxRdd.collect().sum)//4.关闭连接sc.stop()}
}
2.3.1.7 groupBy()分组

groupBy算子

在这里插入图片描述

代码实现

object value06_groupby {def main(args: Array[String]): Unit = {//1.创建SparkConf并设置App名称val conf = new SparkConf().setAppName("SparkCoreTest").setMaster("local[*]")//2.创建SparkContext,该对象是提交Spark App的入口val sc = new SparkContext(conf)//3具体业务逻辑// 3.1 创建一个RDDval rdd = sc.makeRDD(1 to 4, 2)// 3.2 将每个分区的数据放到一个数组并收集到Driver端打印rdd.groupBy(_ % 2).collect().foreach(println)// 3.3 创建一个RDDval rdd1: RDD[String] = sc.makeRDD(List("hello","hive","hadoop","spark","scala"))// 3.4 按照首字母第一个单词相同分组rdd1.groupBy(str=>str.substring(0,1)).collect().foreach(println)sc.stop()}
}

groupBy会存在shuffle过程
shuffle:将不同的分区数据进行打乱重组的过程
shuffle一定会落盘。可以在local模式下执行程序,通过4040看效果。

2.3.1.8 GroupBy之WordCount

在这里插入图片描述

代码实现

object value07_groupby_wordcount {def main(args: Array[String]): Unit = {//1.创建SparkConf并设置App名称val conf = new SparkConf().setAppName("SparkCoreTest").setMaster("local[*]")//2.创建SparkContext,该对象是提交Spark App的入口val sc = new SparkContext(conf)//3具体业务逻辑// 3.1 创建一个RDDval strList: List[String] = List("Hello Scala", "Hello Spark", "Hello World")val rdd = sc.makeRDD(strList)// 3.2 将字符串拆分成一个一个的单词val wordRdd: RDD[String] = rdd.flatMap(str=>str.split(" "))// 3.3 将单词结果进行转换:word=>(word,1)val wordToOneRdd: RDD[(String, Int)] = wordRdd.map(word=>(word, 1))// 3.4 将转换结构后的数据分组val groupRdd: RDD[(String, Iterable[(String, Int)])] = wordToOneRdd.groupBy(t=>t._1)// 3.5 将分组后的数据进行结构的转换val wordToSum: RDD[(String, Int)] = groupRdd.map {case (word, list) => {(word, list.size)}}wordToSum.collect().foreach(println)sc.stop()}
}
2.3.1.9 filter()过滤

1)函数签名: def filter(f: T => Boolean): RDD[T]

2)功能说明

接收一个返回值为布尔类型的函数作为参数。当某个RDD调用filter方法时,会对该RDD中每一个元素应用f函数,如果返回值类型为true,则该元素会被添加到新的RDD中。

3)需求说明:创建一个RDD,过滤出对2取余等于0的数据

在这里插入图片描述

代码实现

object value08_filter {def main(args: Array[String]): Unit = {//1.创建SparkConf并设置App名称val conf: SparkConf = new SparkConf().setAppName("SparkCoreTest").setMaster("local[*]")//2.创建SparkContext,该对象是提交Spark App的入口val sc: SparkContext = new SparkContext(conf)//3.创建一个RDDval rdd: RDD[Int] = sc.makeRDD(Array(1, 2, 3, 4),2)//3.1 过滤出符合条件的数据val filterRdd: RDD[Int] = rdd.filter(_ % 2 == 0)//3.2 收集并打印数据filterRdd.collect().foreach(println)//4 关闭连接sc.stop()}
}
2.3.1.10 sample()采样

1)函数签名:

​ def sample(

​ withReplacement: Boolean,

​ fraction: Double,

​ seed: Long = Utils.random.nextLong): RDD[T]

// withReplacement: true为有放回的抽样,false为无放回的抽样;

// fraction表示:以指定的随机种子随机抽样出数量为fraction的数据;

// seed表示:指定随机数生成器种子。

2)功能说明

从大量的数据中采样

3)需求说明:创建一个RDD(1-10),从中选择放回和不放回抽样

在这里插入图片描述

代码实现

object value09_sample {def main(args: Array[String]): Unit = {//1.创建SparkConf并设置App名称val conf: SparkConf = new SparkConf().setAppName("SparkCoreTest").setMaster("local[*]")//2.创建SparkContext,该对象是提交Spark App的入口val sc: SparkContext = new SparkContext(conf)//3.1 创建一个RDDval dataRDD: RDD[Int] = sc.makeRDD(List(1,2,3,4,5,6))// 抽取数据不放回(伯努利算法)// 伯努利算法:又叫0、1分布。例如扔硬币,要么正面,要么反面。// 具体实现:根据种子和随机算法算出一个数和第二个参数设置几率比较,小于第二个参数要,大于不要// 第一个参数:抽取的数据是否放回,false:不放回// 第二个参数:抽取的几率,范围在[0,1]之间,0:全不取;1:全取;// 第三个参数:随机数种子val sampleRDD: RDD[Int] = dataRDD.sample(false, 0.5)sampleRDD.collect().foreach(println)println("----------------------")// 抽取数据放回(泊松算法)// 第一个参数:抽取的数据是否放回,true:放回;false:不放回// 第二个参数:重复数据的几率,范围大于等于0.表示每一个元素被期望抽取到的次数// 第三个参数:随机数种子val sampleRDD1: RDD[Int] = dataRDD.sample(true, 2)sampleRDD1.collect().foreach(println)//4.关闭连接sc.stop()}
}

java随机数测试

public class TestRandom {public static void main(String[] args) {// 随机算法相同,种子相同,那么随机数就相同//Random r1 = new Random(100);// 不输入参数,种子取的当前时间的纳秒值,所以随机结果就不相同了Random r1 = new Random();for (int i = 0; i < 5; i++) {System.out.println(r1.nextInt(10));}System.out.println("--------------");//Random r2 = new Random(100);Random r2 = new Random();for (int i = 0; i < 5; i++) {System.out.println(r2.nextInt(10));}}
}/**种子相同时的输出结果:
5
0
4
8
1
--------------
5
0
4
8
18*/
2.3.1.11 distinct()去重

distinct算子
在这里插入图片描述

代码实现

object value10_distinct {def main(args: Array[String]): Unit = {//1.创建SparkConf并设置App名称val conf: SparkConf = new SparkConf().setAppName("SparkCoreTest").setMaster("local[*]")//2.创建SparkContext,该对象是提交Spark App的入口val sc: SparkContext = new SparkContext(conf)//3具体业务逻辑// 3.1 创建一个RDDval distinctRdd: RDD[Int] = sc.makeRDD(List(1,2,1,5,2,9,6,1))// 3.2 打印去重后生成的新RDDdistinctRdd.distinct().collect().foreach(println)// 3.3 对RDD采用多个Task去重,提高并发度distinctRdd.distinct(2).collect().foreach(println)//4.关闭连接sc.stop()}
}
查看全文
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

相关文章

  1. 如此调用

    起因是看到这样一段代码 queued UNSAFE.compareAndSwapObject(this, waitersOffset,q.next waiters, q); 这里第三个参数类型也是Object类型 但是输入是q.next waiters; 这个怎么解释呢&#xff1f;这个其实分为两步来看、第一步将waiters 赋值给q.next; 第二步是把q.nex…...

    2024/4/7 13:30:16
  2. BeautifulSoup

    1、安装和使用 pip install beautifulsoup4from bs4 import BeautifulSoup soup BeautifulSoup(指定的字符串名,lxml)2、re、 lxml 、bs4 工具速度使用难度正则最快最难lxml较快一般BeautifulSoup慢最简单 3、解析字符串 str1 <div>这是测试div</div> soup B…...

    2024/4/7 13:30:15
  3. 【数据结构·标准C语言实现】链表:线性表,循环链表,双向链表的增删改查

    在之前的很多教材中&#xff0c;数据结构的实现都是基于C实现的&#xff0c;对于很多没有学习C的同学来说&#xff0c;在学习数据结构的过程中造成了一定的阻碍&#xff0c;基于这个原因&#xff0c;希望从标准C语言的角度&#xff0c;来全面描述数据结构的各个算法。 链表 链…...

    2024/4/7 13:30:14
  4. Android音视频学习 之C语言入门之三大经典排序(六)

    C排序算法 冒泡排序 冒泡排序&#xff08;Bubble Sort&#xff09; 最为简单的一种排序&#xff0c;通过重复走完数组的所有元素&#xff0c;通过打擂台的方式两个两个比较&#xff0c;直到没有数可以交换的时候结束这个数&#xff0c;再到下个数&#xff0c;直到整个数组排好…...

    2024/4/12 22:23:53
  5. docker容器自动化

    1、 设置网络yum源并安装docker服务 设置网络yum [rootcentos01 ~]# cd /etc/yum.repos.d/ [rootcentos01 yum.repos.d]# rm -rf * [rootcentos01 yum.repos.d]# ls [rootcentos01 yum.repos.d]# wget http://mirrors.163.com/.help/CentOS7-Base-163.repo [rootcentos01 yum.r…...

    2024/4/7 9:52:49
  6. SP1026 FAVDICE - Favorite Dice(扔筛子期望)

    题目链接 很老套的期望了 定义dp[i]dp[i]dp[i]为已经有iii面筛子扔过,还需要仍到nnn面的期望 那么dp[n]0dp[n]0dp[n]0 pinp\frac{i}{n}pni​表示此时扔到已有的面的概率 dp[i](dp[i]1)∗p(dp[i1]1)∗(1−p)dp[i](dp[i]1)*p(dp[i1]1)*(1-p)dp[i](dp[i]1)∗p(dp[i1]1)∗(1−p)…...

    2024/4/7 9:52:48
  7. JS流程控制、规范

    2020年9月22日真是痛苦的一天 流程控制 流程控制即用于控制代码按照什么结构顺序来执行 流程控制分为顺序结构、分支结构、循环结构 顺序流程控制 代码按照先后顺序&#xff0c;依次执行 分支流程控制 由上到下执行代码的过程中&#xff0c;根据不同的条件&#xff0c;执行…...

    2024/4/7 9:52:47
  8. 报错Error response from daemon: Get https://20.0.0.51/v2/: dial tcp 20.0.0.51:443: connect: connection

    解决Error response from daemon: Get https://20.0.0.51/v2/: dial tcp 20.0.0.51:443: connect: connection refused报错问题报错现象解决方法报错现象 解决方法 [rootlocalhost ~]# vim /usr/lib/systemd/system/docker.service ExecStart/usr/bin/dockerd -H fd:// --inse…...

    2024/4/7 13:30:14
  9. ts ES5 / ES3中的异步函数或方法需要‘Promise‘构造函数(ts An async function or method in ES5/ES3 requires the ';Pro

    ts ES5 / ES3中的异步函数或方法需要’Promise’构造函数(ts An async function or method in ES5/ES3 requires the ‘Promise’ constructor) 解决方法&#xff1a; 在tsconfig.json中配置lib // tsconfig.json {"compilerOptions": {"lib": [ "es…...

    2024/4/7 13:30:12
  10. linux服务器配置,jdk/tomcat/fastDFS安装

    文章目录配置DNS上外网安装JDK安装tomcat安装fastDFS配置DNS上外网 vi /etc/resolv.conf 编辑以下内容 nameserver 8.8.8.8 nameserver 8.8.4.4ifconfig不好使 执行sudo yum install net-tools安装JDK 上传至指定文件夹压缩包解压tar -zxvf jdk-8u141-linux-x64.tar.gz编辑…...

    2024/4/7 13:30:11
  11. 联机相关,让你的好友联机如局域网般丝滑!

    这几天刚开始和女盆友联机玩无主3&#xff0c;但是联机的时候作为客机的我总是会有各种载入黑屏/伤害技能延迟/跑步回弹等等问题&#xff0c;双方都开了加速器也没有很好的改善&#xff0c;联机体验十分不爽。 这时候我想起来以前有用过Teamviewer这个软件用来进行P2P联机游戏(…...

    2024/4/7 13:30:10
  12. VMware虚拟化迁移到KVM

    VMware虚拟化迁移到KVM 记录原有的配置信息 迁移之前&#xff0c;最好记录一下VMware中虚拟机的基本信息。 例如&#xff1a;内存多大、几块网卡、cpu个数等。 导出虚拟机 通过VMware中的导出功能&#xff0c;导出OVF。导出的是一个文件夹&#xff0c;里面 *.mf和*.OVF是虚…...

    2024/4/7 13:30:09
  13. JavaScript中的BOM和DOM操作

    一、课前实例 # 闭包函数的运用var arr []; undefined for (var i0;i<4;i){function outter(i){function f(){console.log(i)}return f}f outter(i)arr.push(f) };arr (5) [ƒ, ƒ, ƒ, ƒ, ƒ] arr[0]() 0arr[1]() 1arr[2]() 2arr[3]() 3arr[4]() 4arr[5]() VM455:1 Un…...

    2024/4/14 12:05:11
  14. Linux 在VMWARE中安装JAVA以及配置jdk环境

    目录 一、使用SSH传输jdk到Linux的demo文件夹下 二、打开SSH窗口或者&#xff08;Linux的终端窗口&#xff09;操作 &#xff1a; 2.1打开Linux终端 2.2输入命令su root 开启root权限 ​ 2.3成功root &#xff1a;~变成# 三、Linux的JDK安装 3.1查看当前Linux系统是否已…...

    2024/4/7 13:30:07
  15. 回归平均值效应

    现在的生活和工作中&#xff0c;越来越多的人认同这样一个事实&#xff1a;正面反馈&#xff08;在表现好的时候&#xff0c;表扬和奖励&#xff09;比负面反馈&#xff08;在其表现差的时候&#xff0c;批评和惩罚&#xff09;更加能够激励一个人取得进步。打击式教育和辱骂式…...

    2024/4/7 13:30:06
  16. day13--sql--统计,分组,分页***

    sql的查询-排序*** &#xff08;1&#xff09;什么是排序 order by &#xff08;2&#xff09;如何排序 》》数据库的查询(排序:order by) SELECT * FROM 表名 ORDER BY 排序字段 ASC(升序)|DESC(降序); &#xff08;3&#xff09;特点 指定列 指定升序或者降序 order by 排序…...

    2024/4/7 13:30:05
  17. Linux 在VMWARE中安装Mysql以及配置mysql环境

    目录 一、使用SSH传输mysql到Linux的demo文件夹下 二、打开SSH窗口或者&#xff08;Linux的终端窗口&#xff09;操作 &#xff1a; 2.1打开Linux终端 2.2输入命令su root 开启root权限&#xff0c;输入密码 ​2.3成功root &#xff1a;~变成# 三、Linux的Mysql安装配置 …...

    2024/4/9 23:45:23
  18. Amazon SageMaker助力行者AI实现游戏内容过滤准确率96%

    [2020年9月22日] 记者从行者AI&#xff08;成都潜在人工智能科技有限公司旗下品牌&#xff0c;xingzhe.ai&#xff09;获悉&#xff0c;该公司利用亚马逊云服务&#xff08;AWS&#xff09;旗下的全托管机器学习服务Amazon SageMaker开发的游戏内容过滤服务&#xff0c;对不恰当…...

    2024/4/7 13:30:04
  19. Linux 在VMWARE中安装Tomcat以及配置Tomcat环境目录 一、使用SSH传输Tomcat到Linux的demo文件夹下 二、打开SSH窗口或者(Linux的终端窗口)操作 : 2

    目录 一、使用SSH传输Tomcat到Linux的demo文件夹下 二、打开SSH窗口或者&#xff08;Linux的终端窗口&#xff09;操作 &#xff1a; 2.1打开Linux终端 2.2输入命令su root 开启root权限&#xff0c;输入密码 2.3成功root &#xff1a;~变成# 三、Linux的Tomcat安装配置 …...

    2024/4/7 13:30:02
  20. 破解 excel 表格加密 高版本不行

    https://blog.51cto.com/b217dgy/1324929 https://blog.csdn.net/diyiday/article/details/85340776...

    2024/4/14 4:35:51

最新文章

  1. 8.Godot 函数|变量|运算符|条件循环语句

    函数 函数的概念 函数也叫方法或模块&#xff0c;是一套操作的集合。函数也包括自定义函数与内置函数。当它被调用时执行的可重复使用的代码块 大部分内置函数可以对游戏内容产生实质性的影响或在代码中起到传递数据的作用。少部分函数比较特殊。 一个函数除名称外&#xff…...

    2024/4/19 17:51:32
  2. 梯度消失和梯度爆炸的一些处理方法

    在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言&#xff0c;在此感激不尽。 权重和梯度的更新公式如下&#xff1a; w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...

    2024/3/20 10:50:27
  3. 【vue】watch监听取不到this指向的数?

    今天同事问我&#xff0c;watch里this指向的数值&#xff0c;别的地方却可以打印出来。工具也能看到数值&#xff0c;但打印出来却是undifined&#xff0c;先看看代码&#xff1a; 懒得打字了直接上截图吧 ps&#xff1a; 在Vue组件中&#xff0c;如果你在watch选项中访问this…...

    2024/4/12 22:01:52
  4. 解析大语言模型训练三阶段

    大语言模型的训练过程一般包括3个阶段&#xff1a;预训练&#xff08;Pre-training&#xff09;、SFT&#xff08;有监督的微调&#xff0c;Supervised-Finetuning&#xff09;以及RLHF&#xff08;基于人类反馈的强化学习&#xff0c;Reinforcement Learning from Human Feedb…...

    2024/4/17 22:18:45
  5. DM数据库状态

    DM 数据库包含以下几种状态&#xff1a; 配置状态&#xff08;MOUNT&#xff09;&#xff1a; 不允许访问数据库对象&#xff0c;只能进行控制文件维护、归档配置、数据库模式修改等操作&#xff1b;打开状态&#xff08;OPEN&#xff09;&#xff1a; 不能进行控制文件维护、…...

    2024/4/18 15:26:52
  6. 416. 分割等和子集问题(动态规划)

    题目 题解 class Solution:def canPartition(self, nums: List[int]) -> bool:# badcaseif not nums:return True# 不能被2整除if sum(nums) % 2 ! 0:return False# 状态定义&#xff1a;dp[i][j]表示当背包容量为j&#xff0c;用前i个物品是否正好可以将背包填满&#xff…...

    2024/4/18 18:47:03
  7. 【Java】ExcelWriter自适应宽度工具类(支持中文)

    工具类 import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.CellType; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet;/*** Excel工具类** author xiaoming* date 2023/11/17 10:40*/ public class ExcelUti…...

    2024/4/19 11:51:49
  8. Spring cloud负载均衡@LoadBalanced LoadBalancerClient

    LoadBalance vs Ribbon 由于Spring cloud2020之后移除了Ribbon&#xff0c;直接使用Spring Cloud LoadBalancer作为客户端负载均衡组件&#xff0c;我们讨论Spring负载均衡以Spring Cloud2020之后版本为主&#xff0c;学习Spring Cloud LoadBalance&#xff0c;暂不讨论Ribbon…...

    2024/4/19 11:33:34
  9. TSINGSEE青犀AI智能分析+视频监控工业园区周界安全防范方案

    一、背景需求分析 在工业产业园、化工园或生产制造园区中&#xff0c;周界防范意义重大&#xff0c;对园区的安全起到重要的作用。常规的安防方式是采用人员巡查&#xff0c;人力投入成本大而且效率低。周界一旦被破坏或入侵&#xff0c;会影响园区人员和资产安全&#xff0c;…...

    2024/4/19 11:52:08
  10. VB.net WebBrowser网页元素抓取分析方法

    在用WebBrowser编程实现网页操作自动化时&#xff0c;常要分析网页Html&#xff0c;例如网页在加载数据时&#xff0c;常会显示“系统处理中&#xff0c;请稍候..”&#xff0c;我们需要在数据加载完成后才能继续下一步操作&#xff0c;如何抓取这个信息的网页html元素变化&…...

    2024/4/19 2:38:12
  11. 【Objective-C】Objective-C汇总

    方法定义 参考&#xff1a;https://www.yiibai.com/objective_c/objective_c_functions.html Objective-C编程语言中方法定义的一般形式如下 - (return_type) method_name:( argumentType1 )argumentName1 joiningArgument2:( argumentType2 )argumentName2 ... joiningArgu…...

    2024/4/19 1:39:20
  12. 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】

    &#x1f468;‍&#x1f4bb;博客主页&#xff1a;花无缺 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! 本文由 花无缺 原创 收录于专栏 【洛谷算法题】 文章目录 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】&#x1f30f;题目描述&#x1f30f;输入格…...

    2024/4/19 11:52:49
  13. 【ES6.0】- 扩展运算符(...)

    【ES6.0】- 扩展运算符... 文章目录 【ES6.0】- 扩展运算符...一、概述二、拷贝数组对象三、合并操作四、参数传递五、数组去重六、字符串转字符数组七、NodeList转数组八、解构变量九、打印日志十、总结 一、概述 **扩展运算符(...)**允许一个表达式在期望多个参数&#xff0…...

    2024/4/18 17:23:55
  14. 摩根看好的前智能硬件头部品牌双11交易数据极度异常!——是模式创新还是饮鸩止渴?

    文 | 螳螂观察 作者 | 李燃 双11狂欢已落下帷幕&#xff0c;各大品牌纷纷晒出优异的成绩单&#xff0c;摩根士丹利投资的智能硬件头部品牌凯迪仕也不例外。然而有爆料称&#xff0c;在自媒体平台发布霸榜各大榜单喜讯的凯迪仕智能锁&#xff0c;多个平台数据都表现出极度异常…...

    2024/4/18 23:06:50
  15. Go语言常用命令详解(二)

    文章目录 前言常用命令go bug示例参数说明 go doc示例参数说明 go env示例 go fix示例 go fmt示例 go generate示例 总结写在最后 前言 接着上一篇继续介绍Go语言的常用命令 常用命令 以下是一些常用的Go命令&#xff0c;这些命令可以帮助您在Go开发中进行编译、测试、运行和…...

    2024/4/18 21:25:02
  16. 用欧拉路径判断图同构推出reverse合法性:1116T4

    http://cplusoj.com/d/senior/p/SS231116D 假设我们要把 a a a 变成 b b b&#xff0c;我们在 a i a_i ai​ 和 a i 1 a_{i1} ai1​ 之间连边&#xff0c; b b b 同理&#xff0c;则 a a a 能变成 b b b 的充要条件是两图 A , B A,B A,B 同构。 必要性显然&#xff0…...

    2024/4/18 18:47:03
  17. 【NGINX--1】基础知识

    1、在 Debian/Ubuntu 上安装 NGINX 在 Debian 或 Ubuntu 机器上安装 NGINX 开源版。 更新已配置源的软件包信息&#xff0c;并安装一些有助于配置官方 NGINX 软件包仓库的软件包&#xff1a; apt-get update apt install -y curl gnupg2 ca-certificates lsb-release debian-…...

    2024/4/18 15:01:51
  18. Hive默认分割符、存储格式与数据压缩

    目录 1、Hive默认分割符2、Hive存储格式3、Hive数据压缩 1、Hive默认分割符 Hive创建表时指定的行受限&#xff08;ROW FORMAT&#xff09;配置标准HQL为&#xff1a; ... ROW FORMAT DELIMITED FIELDS TERMINATED BY \u0001 COLLECTION ITEMS TERMINATED BY , MAP KEYS TERMI…...

    2024/4/19 3:53:57
  19. 【论文阅读】MAG:一种用于航天器遥测数据中有效异常检测的新方法

    文章目录 摘要1 引言2 问题描述3 拟议框架4 所提出方法的细节A.数据预处理B.变量相关分析C.MAG模型D.异常分数 5 实验A.数据集和性能指标B.实验设置与平台C.结果和比较 6 结论 摘要 异常检测是保证航天器稳定性的关键。在航天器运行过程中&#xff0c;传感器和控制器产生大量周…...

    2024/4/18 12:50:28
  20. --max-old-space-size=8192报错

    vue项目运行时&#xff0c;如果经常运行慢&#xff0c;崩溃停止服务&#xff0c;报如下错误 FATAL ERROR: CALL_AND_RETRY_LAST Allocation failed - JavaScript heap out of memory 因为在 Node 中&#xff0c;通过JavaScript使用内存时只能使用部分内存&#xff08;64位系统&…...

    2024/4/18 21:24:56
  21. 基于深度学习的恶意软件检测

    恶意软件是指恶意软件犯罪者用来感染个人计算机或整个组织的网络的软件。 它利用目标系统漏洞&#xff0c;例如可以被劫持的合法软件&#xff08;例如浏览器或 Web 应用程序插件&#xff09;中的错误。 恶意软件渗透可能会造成灾难性的后果&#xff0c;包括数据被盗、勒索或网…...

    2024/4/19 11:54:11
  22. JS原型对象prototype

    让我简单的为大家介绍一下原型对象prototype吧&#xff01; 使用原型实现方法共享 1.构造函数通过原型分配的函数是所有对象所 共享的。 2.JavaScript 规定&#xff0c;每一个构造函数都有一个 prototype 属性&#xff0c;指向另一个对象&#xff0c;所以我们也称为原型对象…...

    2024/4/18 21:24:54
  23. C++中只能有一个实例的单例类

    C中只能有一个实例的单例类 前面讨论的 President 类很不错&#xff0c;但存在一个缺陷&#xff1a;无法禁止通过实例化多个对象来创建多名总统&#xff1a; President One, Two, Three; 由于复制构造函数是私有的&#xff0c;其中每个对象都是不可复制的&#xff0c;但您的目…...

    2024/4/19 10:00:05
  24. python django 小程序图书借阅源码

    开发工具&#xff1a; PyCharm&#xff0c;mysql5.7&#xff0c;微信开发者工具 技术说明&#xff1a; python django html 小程序 功能介绍&#xff1a; 用户端&#xff1a; 登录注册&#xff08;含授权登录&#xff09; 首页显示搜索图书&#xff0c;轮播图&#xff0…...

    2024/4/18 18:47:01
  25. 电子学会C/C++编程等级考试2022年03月(一级)真题解析

    C/C++等级考试(1~8级)全部真题・点这里 第1题:双精度浮点数的输入输出 输入一个双精度浮点数,保留8位小数,输出这个浮点数。 时间限制:1000 内存限制:65536输入 只有一行,一个双精度浮点数。输出 一行,保留8位小数的浮点数。样例输入 3.1415926535798932样例输出 3.1…...

    2024/4/19 2:37:58
  26. 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...

    解析如下&#xff1a;1、长按电脑电源键直至关机&#xff0c;然后再按一次电源健重启电脑&#xff0c;按F8健进入安全模式2、安全模式下进入Windows系统桌面后&#xff0c;按住“winR”打开运行窗口&#xff0c;输入“services.msc”打开服务设置3、在服务界面&#xff0c;选中…...

    2022/11/19 21:17:18
  27. 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。

    %读入6幅图像&#xff08;每一幅图像的大小是564*564&#xff09; f1 imread(WashingtonDC_Band1_564.tif); subplot(3,2,1),imshow(f1); f2 imread(WashingtonDC_Band2_564.tif); subplot(3,2,2),imshow(f2); f3 imread(WashingtonDC_Band3_564.tif); subplot(3,2,3),imsho…...

    2022/11/19 21:17:16
  28. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...

    win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面&#xff0c;在等待界面中我们需要等待操作结束才能关机&#xff0c;虽然这比较麻烦&#xff0c;但是对系统进行配置和升级…...

    2022/11/19 21:17:15
  29. 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...

    有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows&#xff0c;请勿关闭计算机”的提示&#xff0c;要过很久才能进入系统&#xff0c;有的用户甚至几个小时也无法进入&#xff0c;下面就教大家这个问题的解决方法。第一种方法&#xff1a;我们首先在左下角的“开始…...

    2022/11/19 21:17:14
  30. win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...

    置信有很多用户都跟小编一样遇到过这样的问题&#xff0c;电脑时发现开机屏幕显现“正在配置Windows Update&#xff0c;请勿关机”(如下图所示)&#xff0c;而且还需求等大约5分钟才干进入系统。这是怎样回事呢&#xff1f;一切都是正常操作的&#xff0c;为什么开时机呈现“正…...

    2022/11/19 21:17:13
  31. 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...

    Win7系统开机启动时总是出现“配置Windows请勿关机”的提示&#xff0c;没过几秒后电脑自动重启&#xff0c;每次开机都这样无法进入系统&#xff0c;此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一&#xff1a;开机按下F8&#xff0c;在出现的Windows高级启动选…...

    2022/11/19 21:17:12
  32. 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...

    有不少windows10系统用户反映说碰到这样一个情况&#xff0c;就是电脑提示正在准备windows请勿关闭计算机&#xff0c;碰到这样的问题该怎么解决呢&#xff0c;现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法&#xff1a;1、2、依次…...

    2022/11/19 21:17:11
  33. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...

    今天和大家分享一下win7系统重装了Win7旗舰版系统后&#xff0c;每次关机的时候桌面上都会显示一个“配置Windows Update的界面&#xff0c;提示请勿关闭计算机”&#xff0c;每次停留好几分钟才能正常关机&#xff0c;导致什么情况引起的呢&#xff1f;出现配置Windows Update…...

    2022/11/19 21:17:10
  34. 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...

    只能是等着&#xff0c;别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚&#xff0c;只能是考虑备份数据后重装系统了。解决来方案一&#xff1a;管理员运行cmd&#xff1a;net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...

    2022/11/19 21:17:09
  35. 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?

    原标题&#xff1a;电脑提示“配置Windows Update请勿关闭计算机”怎么办&#xff1f;win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢&#xff1f;一般的方…...

    2022/11/19 21:17:08
  36. 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...

    关机提示 windows7 正在配置windows 请勿关闭计算机 &#xff0c;然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;关机提示 windows7 正在配…...

    2022/11/19 21:17:05
  37. 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...

    钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...

    2022/11/19 21:17:05
  38. 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...

    前几天班里有位学生电脑(windows 7系统)出问题了&#xff0c;具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面&#xff0c;长时间没反应&#xff0c;无法进入系统。这个问题原来帮其他同学也解决过&#xff0c;网上搜了不少资料&#x…...

    2022/11/19 21:17:04
  39. 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...

    本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法&#xff0c;并在最后教给你1种保护系统安全的好方法&#xff0c;一起来看看&#xff01;电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中&#xff0c;添加了1个新功能在“磁…...

    2022/11/19 21:17:03
  40. 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...

    许多用户在长期不使用电脑的时候&#xff0c;开启电脑发现电脑显示&#xff1a;配置windows更新失败&#xff0c;正在还原更改&#xff0c;请勿关闭计算机。。.这要怎么办呢&#xff1f;下面小编就带着大家一起看看吧&#xff01;如果能够正常进入系统&#xff0c;建议您暂时移…...

    2022/11/19 21:17:02
  41. 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...

    配置windows update失败 还原更改 请勿关闭计算机&#xff0c;电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;配置windows update失败 还原更改 请勿关闭计算机&#x…...

    2022/11/19 21:17:01
  42. 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...

    不知道大家有没有遇到过这样的一个问题&#xff0c;就是我们的win7系统在关机的时候&#xff0c;总是喜欢显示“准备配置windows&#xff0c;请勿关机”这样的一个页面&#xff0c;没有什么大碍&#xff0c;但是如果一直等着的话就要两个小时甚至更久都关不了机&#xff0c;非常…...

    2022/11/19 21:17:00
  43. 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...

    当电脑出现正在准备配置windows请勿关闭计算机时&#xff0c;一般是您正对windows进行升级&#xff0c;但是这个要是长时间没有反应&#xff0c;我们不能再傻等下去了。可能是电脑出了别的问题了&#xff0c;来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...

    2022/11/19 21:16:59
  44. 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...

    我们使用电脑的过程中有时会遇到这种情况&#xff0c;当我们打开电脑之后&#xff0c;发现一直停留在一个界面&#xff1a;“配置Windows Update失败&#xff0c;还原更改请勿关闭计算机”&#xff0c;等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢&#xff0…...

    2022/11/19 21:16:58
  45. 如何在iPhone上关闭“请勿打扰”

    Apple’s “Do Not Disturb While Driving” is a potentially lifesaving iPhone feature, but it doesn’t always turn on automatically at the appropriate time. For example, you might be a passenger in a moving car, but your iPhone may think you’re the one dri…...

    2022/11/19 21:16:57