RHCE的学习(20)
变量5种赋值方式
shell中变量赋值5种方式,其中采用name=10的方法称A 直接赋值 name=B read命令 read v1C 使用命令行参数 ($1 $2 $3 ..) name=$1D 使用命令的输入 username=$(whoami)E 从文件读取 #cut -d : -f1 /etc/passwd > /user.listfor user in $(cat /user.list);doecho $userdonewhile read user;doecho $userdone < user.list
变量和引号
Shell语言中一共有3种引号,分别为
- 单引号(' ')单引号括起来的字符都作为普通字符出现
- 双引号(" ")双引号括起来的字符,除“$”、“\”、“'”和“"”这几个字符仍是特殊字符并保留其特殊功能外,其余字符仍作为普通字符对待,
- 反引号(``)反引号括起来的字串被Shell解释为命令,在执行时,Shell首先执行该命令,并以它的标准输出结果取代整个反引号(包括两个反引号)部分
| 符号 | 说明 |
|---|---|
| 双引号 | 除美元符号、单引号、反引号和反斜线之外,其他所有的字符都将保持字面意义 |
| 单引号 | 所有的字符都将保持字面意义 |
| 反引号 | 反引号中的字符串将被解释为Shell命令 |
| 反斜线 | 转义字符,屏蔽后的字符的特殊意义 |
演示:引号的区别
[root@localhost ~]# echo "current_user is: $USER"
current_user is: root
[root@localhost ~]# echo 'current_user is: $USER'
current_user is: $USER
[root@localhost ~]# echo "current_user is: `whoami`"
current_user is: root
[root@localhost ~]# echo 'current_user is: `whoami`'
current_user is: `whoami`
变量的运算
运算符与命令

-
例:
r=$((2+5*8)) ---需要通过$引用运算值---- (()) 可以直接运算 运算结果需要通过变量接受
((dec=num-1))
r=$[1+2] $[] 不能直接运算 运算结果需要通过变量接受
declare –i r=2+3 申明整形变量对数值进行运算
let r=3+4 let 可以直接运算 运算结果需要通过变量接受
expr 4 + 2 后三种可以直接运算输出运算结果
expr 也可用字符串expr length “this is a test”expr substr "this is a test" 3 5 从第三个字符开始取5个字符expr index "sarasare" a 抓取指定字符第一次出现的位置,标记第一个a字符是第2个字符
r=`expr 4 + 2`
bc
echo "2+5*8" | bc
awk 'BEGIN {print 2+5*8}'
[root@server ~]# expr 1 + 1 # 注意+左右必须要有空格
2
[root@server ~]# expr 1+1 # 否则原样显示
1+1
[root@server ~]# a=1
[root@server ~]# b=2
[root@server ~]# expr $a + $b # 支持变量
3[root@server ~]# let num=1+2 # let+echo 等价于expr
[root@server ~]# echo $num
3
[root@server ~]# let num=1 + 2 # 注意let中运算符左右不能由空格
-bash: let: +:语法错误: 需要操作数 (错误符号是 "+")[root@server ~]# echo $((1+2))
3
[root@server ~]# echo $((5%3))
2
[root@server ~]# echo $((3%5))
3
[root@server ~]# echo $((1-5))
-4
[root@server ~]# echo $((2 * 5)) # 可以有空格
10
[root@server ~]# echo $((5.2-5)) # 只支持整数运算
-bash: 5.2-5:语法错误: 无效的算术运算符 (错误符号是 ".2-5")[root@server ~]# echo $[2+3] # [] 等价于 (())
5
[root@server ~]# echo $[2.5+3] # # 只支持整数运算
-bash: 2.5+3:语法错误: 无效的算术运算符 (错误符号是 ".5+3")
[root@server ~]# bc
bc 1.07.1
Copyright 1991-1994, 1997, 1998, 2000, 2004, 2006, 2008, 2012-2017 Free Software
Foundation, Inc.
This is free software with ABSOLUTELY NO WARRANTY.
For details type `warranty'.
1.1+2
3.1
2.5-3.9
-1.4
1.5>4
0
5>3
1
quit # 退出交互模式
# 不进入交互模式直接使用,bc需要放在最后
[root@server ~]# echo "scale=3;11/3" | bc
3.666
# scale=3 表示保留运算精度
-
例2:计算用户输入的任意两个整数的和、差、乘积、商、余数
# 方法1
[root@server ~]# cat 1.sh
#!/bin/bash
a=$1
b=$2
echo a+b=$(($a+$b))
echo a-b=$((a-b))
echo a*b=$((a*b))
echo a/b=$((a/b))
echo a%b=$((a%b))
[root@server ~]# ./1.sh 10 3
a+b=13
a-b=7
a*b=30
a/b=3
a%b=1
# 方法2:
[root@server ~]# cat 1.1.sh
#!/bin/bash
read -p "please input two number:" a b
echo $a+$b=$(($a+$b))
echo $a-$b=$((a-b))
echo $a*$b=$((a*b))
echo $a/$b=$((a/b))
echo $a%$b=$((a%b))
[root@server ~]# ./1.1.sh
please input two number:3 4
3+4=7
3-4=-1
3*4=12
3/4=0
3%4=3
-
例3:计算 1~ 100 的和
# 方法1:
[root@server ~]# cat 2.sh
#!/bin/bash
# 1. 使用 echo {1..100} 生成 1 到 100 字符串
# 2. 然后使用 tr 命令来将空格替换为 + 号 echo {1..100} | tr " " "+"
# 3. 使用管道加bc命令来实现
echo {1..100} | tr " " "+" | bc
# 方法2:
root@server ~]# cat 2.1.sh
#!/bin/bash
# 使用 seq 命令来实现 seq -s "+" 100,然后接合双括号来实现
echo $((`seq -s "+" 100`))
# 方法3:
[root@openEuler ~]# cat 2.2.sh
#!/bin/bash
# 使用 expr 命令来实现
seq -s " + " 100 | xargs expr
-
例3:6种方式计算长方形的面积
s1=$(( $l * $w ))
echo "1--面积是$s1"---'$(())'let s2=$l*$w
#let s2=l*w
echo "2--面积是$s2"---'let's3=`expr $l \* $w`
echo "3--面积是$s3"---'expr’'s4=`echo "$l * $w" | bc`
echo "4--面积是$s4"---'bc's5=$[ $l * $w ]
#s5=$[ l * w ] #可以有空格
echo "5--面积是$s5"---'$[]'declare -i s6=$l*$w #不能有空格
#declare -i s6=l*w
echo "6--面积是$s6"---'declare'
字符运算
格式
| 表达式 | 说明 |
|---|---|
| ${parameter} | 返回变量的内容 |
| ${#parameter} | 返回变量内容的长度(按字符) |
| ${paramater:offset} | 在变量${parameter}中,从位置offset之后开始提取子串到结尾 |
| ${paramater:offset:length} | 在变量${parameter}中,从位置offset之后开始提取长度为length的子串 |
| ${parameter#word} | 从变量${parameter}开头开始删除最短匹配的word子串 |
| ${parameter##word} | 从变量${parameter}开头开始删除最长匹配的word子串 |
| ${parameter%word} | 从变量${parameter}结尾开始删除最短匹配的word子串 |
| ${parameter%%word} | 从变量${parameter}结尾开始删除最长匹配的word子串 |
| ${parameter/pattern/string} | 使用string代替第一个匹配的pattern |
| ${parameter//pattern/string} | 使用string代替所有匹配的pattern |
获取字符串
${parameter} 返回变量的内容
${#parameter} 返回变量内容的长度(按字符)
[root@server ~]# str="hello world"
#返回变量长度
[root@server ~]# echo ${#str}
11
截取字符串
${paramater:offset} 在变量${parameter}中,从位置offset之后开始提取子串到结尾
${paramater:offset:length} 在变量${parameter}中,从位置offset之后开始提取长度为length的子串
[root@server ~]# echo ${str1:0:3} # 从左边第1个字符开始截取3个
hel
[root@server ~]# echo ${str1::3} # 可以省略起始0
hel
[root@server ~]# echo ${str1:1} # 从下标1开始截取到尾部
ello world
[root@server ~]# echo ${str1:0-1:1} # 从右边第一个字符开始截取1个,左边第一个为0,右边第一个为0-1
d
[root@server ~]# echo ${str1:0-5} # 从右边第5个开始截取到尾部
world
[root@server ~]# echo ${str1: -5} # 使用空格替代0,同上
world
注意:下面写法会输出全部,以${parameter:-default}方式,默认是提取完整地字符串
[root@server ~]# echo ${str1:-5} # 没有空格表示提取整串
hello world
删除字符串
${parameter#word} 从变量${parameter}开头开始删除最短匹配的word子串
${parameter##word} 从变量${parameter}开头开始删除最长匹配的word子串
${parameter%word} 从变量${parameter}结尾开始删除最短匹配的word子串
${parameter%%word} 从变量${parameter}结尾开始删除最长匹配的word子串
# 使用%截取,删除右边字符,保留左边字符
[root@server ~]# filename=testfile.tar
[root@server ~]# file=${filename%.*} # %.表示从右边开始检索第一次出现. 之后删除.右侧的内容,#保留左边内容,用于对文件名去掉扩展名
[root@server ~]# echo $file
testfile
[root@server ~]# url=http://www.baidu.com/index.html
[root@server ~]# ul1=${url%%:*} # %%: 表示从右边开始检索最后一次出现的: #之后删除:右侧的内容,保留左边内容
[root@server ~]# echo $ul1
http
[root@server ~]# url=http://www.baidu.com/index.html
[root@server ~]# ul1=${url#*.} # #*.表示左向右遍历,删除第一次出现的.左侧内容
[root@server ~]# echo $ul1
baidu.com/index.html
[root@server ~]# url=http://www.baidu.com/index.html
[root@server ~]# ul1=${url%/*}
[root@server ~]# echo $ul1
http://www.baidu.com
[root@server ~]# url=http://www.baidu.com/index.html
[root@server ~]# ul1=${url##*/}
[root@server ~]# echo $ul1
index.html
替换字符串
${parameter/pattern/string} 使用string代替第一个匹配的pattern
${parameter//pattern/string} 使用string代替所有匹配的pattern
[root@server ~]# str="Hi, girl, i am your friend."
[root@server ~]# echo $str
Hi, i am your friend.
[root@server ~]# echo ${str/i/I}
HI, i am your friend.
[root@server ~]# echo ${str//i/I}
HI, I am your frIend.
案例:批量修改文件名
-
需求:去掉所有文件的_finished字符信息。
-
准备测试数据
[root@server ~]# mkdir d2
[root@server ~]# cd d2
[root@server sub_str]# touch open_{1..5}_finish.jpg
[root@server sub_str]# touch open_{1..5}_finish.png
[root@server sub_str]# ll
total 0
-rw-r--r--. 1 root root 0 Mar 23 17:42 open_1_finish.jpg
-rw-r--r--. 1 root root 0 Mar 23 17:42 open_1_finish.png
-rw-r--r--. 1 root root 0 Mar 23 17:42 open_2_finish.jpg
-rw-r--r--. 1 root root 0 Mar 23 17:42 open_2_finish.png
-rw-r--r--. 1 root root 0 Mar 23 17:42 open_3_finish.jpg
-rw-r--r--. 1 root root 0 Mar 23 17:42 open_3_finish.png
-rw-r--r--. 1 root root 0 Mar 23 17:42 open_4_finish.jpg
-rw-r--r--. 1 root root 0 Mar 23 17:42 open_4_finish.png
-rw-r--r--. 1 root root 0 Mar 23 17:42 open_5_finish.jpg
-rw-r--r--. 1 root root 0 Mar 23 17:42 open_5_finish.png
-
实现思路:
1. 可以通过 mv 命令来修改,如:
mv open_1_finish.jpg open_1.jpg
2. 我们要获取这个文件
f=open_1_finish.jpg
3. 通过字符串删除来实现
${f//_finish/}
-
功能实现:
# 查看当前目录下所有的文件
[root@server sub_str]# ls
open_1_finish.jpg open_2_finish.jpg open_3_finish.jpg open_4_finish.jpg open_5_finish.jpg
open_1_finish.png open_2_finish.png open_3_finish.png open_4_finish.png open_5_finish.png
# 循环这些文件并显示
[root@server sub_str]# for f in `ls`
> do
> echo ${f}
> done
open_1_finish.jpg
open_1_finish.png
open_2_finish.jpg
open_2_finish.png
open_3_finish.jpg
open_3_finish.png
open_4_finish.jpg
open_4_finish.png
open_5_finish.jpg
open_5_finish.png
# 通过循环来去掉 _finish 字符,但它并没有真正的修改磁盘中的文件,只是在内存中修改了
[root@server sub_str]# for f in `ls`; do echo ${f//_finish/}; done
open_1.jpg
open_1.png
open_2.jpg
open_2.png
open_3.jpg
open_3.png
open_4.jpg
open_4.png
open_5.jpg
open_5.png
[root@server sub_str]# ll
total 0
-rw-r--r--. 1 root root 0 Mar 23 17:42 open_1_finish.jpg
-rw-r--r--. 1 root root 0 Mar 23 17:42 open_1_finish.png
-rw-r--r--. 1 root root 0 Mar 23 17:42 open_2_finish.jpg
-rw-r--r--. 1 root root 0 Mar 23 17:42 open_2_finish.png
-rw-r--r--. 1 root root 0 Mar 23 17:42 open_3_finish.jpg
-rw-r--r--. 1 root root 0 Mar 23 17:42 open_3_finish.png
-rw-r--r--. 1 root root 0 Mar 23 17:42 open_4_finish.jpg
-rw-r--r--. 1 root root 0 Mar 23 17:42 open_4_finish.png
-rw-r--r--. 1 root root 0 Mar 23 17:42 open_5_finish.jpg
-rw-r--r--. 1 root root 0 Mar 23 17:42 open_5_finish.png
# 结合 mv 命令来一个文件一个文件的修改 mv open_1_finish.jpg open_1.jpg
# open_1_finish.jpg 文件名称就是每次循环所得到的文件名 ${f}
# open_1.jpg 是通过 ${f//_finish/} 替换来到的
[root@server sub_str]# for f in `ls`; do mv ${f} ${f//_finish/}; done
[root@server sub_str]# for f in `ls`; do mv ${f} ${f##_finish}; done
[root@server sub_str]# for f in `ls`; do mv ${f} ${f%%_finish}; done
[root@server sub_str]# ll
total 0
-rw-r--r--. 1 root root 0 Mar 23 17:42 open_1.jpg
-rw-r--r--. 1 root root 0 Mar 23 17:42 open_1.png
-rw-r--r--. 1 root root 0 Mar 23 17:42 open_2.jpg
-rw-r--r--. 1 root root 0 Mar 23 17:42 open_2.png
-rw-r--r--. 1 root root 0 Mar 23 17:42 open_3.jpg
-rw-r--r--. 1 root root 0 Mar 23 17:42 open_3.png
-rw-r--r--. 1 root root 0 Mar 23 17:42 open_4.jpg
-rw-r--r--. 1 root root 0 Mar 23 17:42 open_4.png
-rw-r--r--. 1 root root 0 Mar 23 17:42 open_5.jpg
-rw-r--r--. 1 root root 0 Mar 23 17:42 open_5.png
变量扩展
功能介绍

| 表达式 | 说明 |
|---|---|
| result=${parameter:-word} | 如果 parameter 变量值为空,会将word的值赋给result变量,parameter 变量值不变 |
| result=${parameter:=word} | 如果 parameter 变量为空,会将 word 的值赋给 parameter 和 ressult变量 |
| result=${parameter:?word} | 如果 parameter 变量为空,会将 word 作为标准错误输出。parameter 变量和 result 变量不变 |
| result=${parameter:+word} | 如果 parameter 变量为空,什么都不做,否则 word 返回 |
使用示例
-
这四个扩展变量,都属于对变量的值进行判断和处理
# :- 判断变量如果值为空就返回后面字符信息 无值时临时赋值
[root@server ~]# echo $name
[root@server ~]# result=${name:-haha}
[root@server ~]# echo $name
[root@server ~]# echo $result
haha
# := 如果变量为空,则会将后面的字符赋值给变量并返回 无值时永久赋值
[root@server ~]# unset result
[root@server ~]# echo $name
[root@server ~]# echo $result
[root@server ~]# result=${name:=hehe}
[root@server ~]# echo $name
hehe
[root@server ~]# echo $result
hehe
[root@server ~]#
# :? 如果变量为空则错误信息返回后面的字符 无值时输出错误提示值
[root@server ~]# unset name result
[root@server ~]# echo $name
[root@server ~]# echo $result
[root@server ~]# result=${name:?haha}
-bash: name: haha
[root@server ~]# echo $result
[root@server ~]# echo $name
[root@server ~]#
# :+ 如果变量为空,什么都不做,否则返回后面字符 有值时临时替换
[root@server ~]# result=${name:+haha}
[root@server ~]# echo $name
[root@server ~]# echo $result
[root@server ~]# name=hehe
[root@server ~]# echo $name
hehe
[root@server ~]# result=${name:+haha}
[root@server ~]# echo $name
hehe
[root@server ~]# echo $result
haha
-
面试题:删除7天前的过期备份数据
#!/bin/bash
find ${path:-/tmp} -name "*.tar.gz" -type f mtime +7 | xargs rm -f
# find为查找文件命令
# ${path:-/tmp} :表示如果没有定义path则使用/tmp替代
# find不支持| 使用xargs命令表示管道符进行数据转换[root@localhost ~]# cat del.sh | 字符 -exec |xargs 参数find ${path:-/tmp} -name "*.bak" -type f -mtime +7 | xargs rm -f
如果没有定义path值,事先脚本中也没有设置变量:
[root@localhost ~]# cat del2.sh
find ${path} -name "*.tar.gz" -type f -mtime +7 | xargs rm -f
这样就不会删除指定目录,而是删除脚本运行目录中的文件。
相关文章:
RHCE的学习(20)
变量5种赋值方式 shell中变量赋值5种方式,其中采用name10的方法称A 直接赋值 nameB read命令 read v1C 使用命令行参数 ($1 $2 $3 ..) name$1D 使用命令的输入 username$(whoami)E 从文件读取 #cut -d : -f1 /etc/passwd > /user.listfor…...
控制器ThinkPHP6
五、控制器中对数组值的返回 在做接口服务时,很多时候回使用数组作为返回值,那么数组如何返回成 json呢? 在 tp6 中返回json 很简单,直接使用 json 进行返回即可,例如: public function index(){$resarra…...
1. Django中的URL调度器 (项目创建与简单测试)
1. 创建 Django 项目 运行以下命令创建一个名为 blog_project 的 Django 项目: django-admin startproject blog_project2. 创建博客应用 Django 中,项目可以包含多个应用。创建一个名为 blog 的应用: cd blog_project python manage.py …...
学习python的第十天之数据类型——dict字典
学习python的第十天之数据类型——dict字典 Python 中的字典(Dictionary)是一个非常强大的内置数据类型,它用来存储键值对(key-value pairs)信息。字典是无序的,这意味着它们不会记录你添加键值对的顺序&am…...
华为Mate 70临近上市:代理IP与抢购攻略
随着科技的飞速发展,智能手机已经成为我们日常生活中不可或缺的一部分。而在众多智能手机品牌中,华为一直以其卓越的技术和创新力引领着行业的发展。近日,华为Mate 70系列手机的发布会正式定档在11月26日,这一消息引发了众多科技爱…...
进程信号
目录 信号入门 1. 生活角度的信号 2. 技术应用角度的信号 3. 注意 4. 信号概念 5. 用kill -l命令可以察看系统定义的信号列表 6. 信号处理常见方式概览 产生信号 1. 通过终端按键产生信号 Core Dump 2. 调用系统函数向进程发信号 3. 由软件条件产生信号 4. 硬件异…...
RT-DETR融合GhostModel V3及相关改进思路
RT-DETR使用教程: RT-DETR使用教程 RT-DETR改进汇总贴:RT-DETR更新汇总贴 《GhostNetV3: Exploring the Training Strategies for Compact Models》 一、 模块介绍 论文链接:https://arxiv.org/pdf/2404.11202v1 代码链接:https:…...
JVM有哪些垃圾回收器
Serial垃圾回收器:单线程收集器,适用于客户端模式下的小型应用。 使用复制算法回收新生代,使用标记-整理算法回收老年代。 在进行垃圾回收时,会停止所有用户线程(Stop-The-World, STW)。Serial Old垃圾回收…...
EWM 打印
目录 1 简介 2 后台配置 3 主数据 4 业务操作 1 简介 打印即输出管理(output management)利用“条件表”那一套理论实现。而当打印跟 EWM 集成到一起时,也需要利用 PPF(Post Processing Framework)那一套理论。而…...
前端文件优化
一、图片优化 计算图片大小 对于一张100*100像素的图片来说,图像上有 10000 个像素点,如果每个像素的值是 RGBA 存储的话,那么也就是说每个像素有 4 个通道,每个通道 1 个字节(8 位 1个字 节)࿰…...
电脑怎么自动切换IP地址
在现代网络环境中,电脑自动切换IP地址的需求日益增多。无论是出于网络安全、隐私保护,还是为了绕过地域限制,自动切换IP地址都成为了许多用户关注的焦点。本文将详细介绍几种实现电脑自动切换IP地址的方法,以满足不同用户的需求。…...
hbase集成phoenix
1.环境 环境准备 三台节点zookeeper三节点hadoop三节点hbase三节点 2.pheonix集成 官网下载地址,需挂梯子,使用官网推荐的对应hbase版本即可 https://phoenix.apache.org/download.html下载及解压 wget https://dlcdn.apache.org/phoenix/phoenix-…...
单片机智能家居火灾环境安全检测
目录 前言 一、本设计主要实现哪些很“开门”功能? 二、电路设计原理图 电路图采用Altium Designer进行设计: 三、实物设计图 四、程序源代码设计 五、获取资料内容 前言 在现代社会,火灾安全始终是人们关注的重点问题。随着科技的不…...
Git_2024/11/16
文章目录 前言Git是什么核心概念工作流程常见术语解读Git的优势 Git与SVN对比SVNGit总结 Git配置流程及指令环境配置获取Git仓库本地初始化远程克隆 工作目录、暂存区、版本库文件的两种状态本地仓库操作远程仓库操作Git分支Git标签IntelliJ IDEA使用Git回滚代码 GitHub配置流程…...
Java基础夯实——2.1Java常见的线程创建方式
在 Java 中,线程是实现并发编程的核心。主要有以下三种: 继承 Thread 类实现 Runnable 接口实现 Callable 接口并结合 Future 使用 1. 继承 Thread 类 继承 Thread 类是创建线程的最简单方式之一。通过扩展 Thread 类并重写其 run 方法,可…...
【Docker容器】一、一文了解docker
1、什么是docker? 1.1 docker概念 Docker是一种容器化平台,通过使用容器技术,Docker允许开发人员将应用程序和其依赖项打包到一个独立的、可移植的容器中。每个容器具有自己的文件系统、环境变量和资源隔离,从而使应用程序可以在…...
Spring:IOC实例化对象bean的方式
对象已经能交给Spring的IOC容器来创建了,但是容器是如何来创建对象的呢? 就需要研究下bean的实例化过程,在这块内容中主要解决两部分内容,分别是 bean是如何创建的实例化bean的三种方式,构造方法,静态工厂和实例工厂 在讲解这…...
深入解析生成对抗网络(GAN)
1. 引言 背景介绍 在过去的几十年中,深度学习在计算机视觉、自然语言处理和语音识别等领域取得了巨大的突破。然而,如何让机器生成高质量、逼真的数据一直是人工智能领域的挑战。传统的生成模型,如变分自编码器(VAE)…...
curl命令提交大json
有个客户需要提交一个4M左右的pdf,接口里传的是pdf字节流base64编码后的字符串。 直接curl -XPOST -d json串 api接口会报 参数过长报错Argument list too long 网上搜了下解决方案把json串放到文本里然后通过json.txt引入参数 这一试不要紧,差点儿导致…...
以太坊拥堵扩展解决方案Arbitrum
Arbitrum是一种用于以太坊的Layer 2(L2)扩展解决方案,以下是详细介绍: 1. 背景和基本原理 背景介绍:随着以太坊网络的发展,交易拥堵和高Gas费用的问题逐渐凸显。为了解决这些问题,Layer 2扩展…...
手游刚开服就被攻击怎么办?如何防御DDoS?
开服初期是手游最脆弱的阶段,极易成为DDoS攻击的目标。一旦遭遇攻击,可能导致服务器瘫痪、玩家流失,甚至造成巨大经济损失。本文为开发者提供一套简洁有效的应急与防御方案,帮助快速应对并构建长期防护体系。 一、遭遇攻击的紧急应…...
CTF show Web 红包题第六弹
提示 1.不是SQL注入 2.需要找关键源码 思路 进入页面发现是一个登录框,很难让人不联想到SQL注入,但提示都说了不是SQL注入,所以就不往这方面想了 先查看一下网页源码,发现一段JavaScript代码,有一个关键类ctfs…...
云计算——弹性云计算器(ECS)
弹性云服务器:ECS 概述 云计算重构了ICT系统,云计算平台厂商推出使得厂家能够主要关注应用管理而非平台管理的云平台,包含如下主要概念。 ECS(Elastic Cloud Server):即弹性云服务器,是云计算…...
React Native 导航系统实战(React Navigation)
导航系统实战(React Navigation) React Navigation 是 React Native 应用中最常用的导航库之一,它提供了多种导航模式,如堆栈导航(Stack Navigator)、标签导航(Tab Navigator)和抽屉…...
【WiFi帧结构】
文章目录 帧结构MAC头部管理帧 帧结构 Wi-Fi的帧分为三部分组成:MAC头部frame bodyFCS,其中MAC是固定格式的,frame body是可变长度。 MAC头部有frame control,duration,address1,address2,addre…...
FFmpeg 低延迟同屏方案
引言 在实时互动需求激增的当下,无论是在线教育中的师生同屏演示、远程办公的屏幕共享协作,还是游戏直播的画面实时传输,低延迟同屏已成为保障用户体验的核心指标。FFmpeg 作为一款功能强大的多媒体框架,凭借其灵活的编解码、数据…...
Redis相关知识总结(缓存雪崩,缓存穿透,缓存击穿,Redis实现分布式锁,如何保持数据库和缓存一致)
文章目录 1.什么是Redis?2.为什么要使用redis作为mysql的缓存?3.什么是缓存雪崩、缓存穿透、缓存击穿?3.1缓存雪崩3.1.1 大量缓存同时过期3.1.2 Redis宕机 3.2 缓存击穿3.3 缓存穿透3.4 总结 4. 数据库和缓存如何保持一致性5. Redis实现分布式…...
【HarmonyOS 5.0】DevEco Testing:鸿蒙应用质量保障的终极武器
——全方位测试解决方案与代码实战 一、工具定位与核心能力 DevEco Testing是HarmonyOS官方推出的一体化测试平台,覆盖应用全生命周期测试需求,主要提供五大核心能力: 测试类型检测目标关键指标功能体验基…...
无法与IP建立连接,未能下载VSCode服务器
如题,在远程连接服务器的时候突然遇到了这个提示。 查阅了一圈,发现是VSCode版本自动更新惹的祸!!! 在VSCode的帮助->关于这里发现前几天VSCode自动更新了,我的版本号变成了1.100.3 才导致了远程连接出…...
MVC 数据库
MVC 数据库 引言 在软件开发领域,Model-View-Controller(MVC)是一种流行的软件架构模式,它将应用程序分为三个核心组件:模型(Model)、视图(View)和控制器(Controller)。这种模式有助于提高代码的可维护性和可扩展性。本文将深入探讨MVC架构与数据库之间的关系,以…...
