当前位置: 首页 > news >正文

shell编程基础知识及脚本示例


文章目录

  • 前言
  • 一、shell变量
    • 1.命名规则
    • 2.定义及使用变量
  • 二、shell传递参数
    • 1.位置参数
    • 2. 任意参数
  • 三、shell一维数组
    • 0.定义方式
    • 1.定义并获取数组的单个元素
    • 2.定义并获取数组的所有元素
    • 3.定义并获取数组的元素个数
    • 4.定义并获取数组的元素索引
  • 四、shell条件判断语法
  • 五、shell常用的数值比较命令
  • 六、shell常用的字符串比较命令
  • 七、shell常用的文件比较命令
  • 八、shell处理参数的特殊字符
  • 九、流程控制
    • 1.if else-if else语法格式
    • 2. while语法格式
    • 3. for语法格式
    • 4.until语法格式
    • 5.case
    • 6. 跳出循环
      • break
      • continue
  • 十、shell函数
  • 十一、日常脚本示例


前言

shell脚本作为运维人员的基操,本博客从实战角度出发,以清晰的结构和通俗的示例,系统梳理 Shell 脚本的核心知识点。内容涵盖从基础变量定义到复杂流程控制,从参数解析到函数封装,最终通过日常脚本示例串联所有技能点。无论你是刚接触 Shell 的新手,还是希望查漏补缺的进阶者,都能在此找到可落地的代码片段和深入浅出的原理剖析。


一、shell变量

1.命名规则

	首个字符必须为字母(a-z,A-Z)。中间不能有空格,可以使用下划线(_)。不能使用标点符号。不能使用bash里的关键字(可用help命令查看保留关键字)

2.定义及使用变量

my_name="AAA"
echo $my_name
echo ${my_name}#注意
ehco两句效果一样,均为输出变量的值。变量名外面的花括号是可选的,加花括号是为了帮助解释器识别变量的边界。

二、shell传递参数

注意:$10 不能获取第十个参数,获取第十个参数需要${10}。当n>=10时,需要使用${n}来获取参数

1.位置参数

代码如下(示例):
$0:表示脚本名称
$1: 脚本的第一个参数,以此类推

[root@ops ~]# cat i.sh 
#!/bin/bash
echo "The script name is $0"
echo "The number of arguments is $1"[root@ops ~]# sh i.sh "位置参数"
The script name is i.sh
The number of arguments is 位置参数

2. 任意参数

代码如下(示例):

$*和$@的区别:相同点:都是引用所有参数。不同点:只有在双引号中体现出来。假设在脚本运行时写了三个参数 1、2、3,,则 “ * “ 等价于 “1 2 3”(传递了1个参数)而 “@” 等价于 “1” “2” “3”(传递了3个参数)

$*示例

[root@ops ~]# cat i.sh 
#!/bin/bash
for i in "$*"; doecho $i
done
[root@ops ~]# sh i.sh 1 2 3
1 2 3

$@示例

[root@ops ~]# cat i.sh 
#!/bin/bash
for i in "$@"; doecho $i
done
[root@ops ~]# sh i.sh 1 2 3
1
2
3

三、shell一维数组

此处以一维数组为例,只能使用整数作为数组索引

0.定义方式

方法一: 一次赋一个值数组名[下标]=变量值例如:#array[0]=pear#array[1]=apple查看数组:declare -a  | grep  array   echo ${array[@]}
方法二: 一次赋多值数组名=(值1  值2  值3)  查看:echo  ${array [@]}

1.定义并获取数组的单个元素

[root@ops ~]# cat i.sh 
#!/bin/bash
my_array=(A B "C" D)  #定义数组
echo "第一个元素为: ${my_array[0]}"
echo "第二个元素为: ${my_array[1]}"
echo "第三个元素为: ${my_array[2]}"
echo "第四个元素为: ${my_array[3]}"
[root@ops ~]# sh i.sh
第一个元素为: A
第二个元素为: B
第三个元素为: C
第四个元素为: D

2.定义并获取数组的所有元素

[root@ops ~]# cat i.sh 
#!/bin/bash
my_array=(A B "C" D)  #定义数组
echo "my_array元素是: ${my_array[*]}"
echo "my_array元素是: ${my_array[@]}"
[root@ops ~]# sh i.sh
my_array元素是: A B C D
my_array元素是: A B C D

3.定义并获取数组的元素个数

[root@ops ~]# cat i.sh 
#!/bin/bash
my_array=(A B "C" D)  #定义数组
echo "my_array元素个数: ${#my_array[@]}"
[root@ops ~]# sh i.sh
my_array元素个数: 4

4.定义并获取数组的元素索引

[root@ops ~]# cat i.sh 
#!/bin/bash
my_array=(A B "C" D)  #定义数组
echo "my_array元素个数: ${!my_array[@]}"
[root@ops ~]# sh i.sh
my_array元素索引: 0 1 2 3

四、shell条件判断语法

使用test

[root@ops ~]# cat i.sh 
#!/bin/bash
num1=10
num2=100
if test $[num1] -eq $[num2]
thenecho '两个数相等!'
elseecho '两个数不相等!'
fi

test 命令的作用

test 是 Shell 内置命令,用于条件判断。它直接评估表达式,返回退出状态码:
0 表示条件为真(True)。
1 表示条件为假(False)。在示例中:test $[num1] -eq $[num2] 比较 num1 和 num2 是否相等。$[ ] 是旧式算术展开语法(现代 Shell 中建议用 $(( )) 替代),此处等效于 $((num1)) 和 $((num2))

使用[ ],它是 test 的另一种形式,本质是同一个命令

[root@ops ~]# cat i.sh 
#!/bin/bash
num1=10
num2=100
if [ $[num1] -eq $[num2] ]
thenecho '两个数相等!'
elseecho '两个数不相等!'
fi

使用[[ ]] 双重方括号,该条件下可以使用正则

[root@ops ~]# cat i.sh 
#!/bin/bash
num1=10
num2=100
if [[ $[num1] =~ $[num2] ]]
thenecho '两个数相等!'
elseecho '两个数不相等!'
fi

五、shell常用的数值比较命令

参数说明
-eq等于
-le小于等于
-ge大于等于
-lt小于
-gt大于
-ne不等于

六、shell常用的字符串比较命令

参数说明
=等于则为真
!=不相等则为真
-z 字符串字符串的长度为0则为真
-n 字符串字符串的长度不为0则为真

判断字符串是否相等示例

[root@ops ~]# cat i.sh 
#!/bin/bash
num1="xx"
num2="xxx"
if [[ $num1 = $num2 ]]
thenecho '两个数相等!'
elseecho '两个数不相等!'
fi
[root@ops ~]# sh i.sh 
两个数不相等!

七、shell常用的文件比较命令

在这里插入图片描述
判断文件是否存在示例

[root@ops ~]# cat i.sh 
#!/bin/bash
if test  -e ./bash
thenecho '文件已存在!'
elseecho '文件不存在'
fi
[root@ops ~]# sh i.sh 
文件不存在

八、shell处理参数的特殊字符

参数处理说明
$0脚本名称
$#传递到脚本中的参数个数
$*以单一字符串的形式给脚本传递参数
$@以多个字符串的形式给脚本传递参数
$$当前脚本运行的进程号
$!后台运行的最后一个进程的PID号
$-显示Shell使用的当前选项,与set命令功能相同
$?显示最后命令的退出状态。0表示没有错误,其他任何值表明有错误

九、流程控制

1.if else-if else语法格式

if condition1
thencommand1
elif condition2
thencommand2
elsecommandN
fi

2. while语法格式

while condition
docommand
done

3. for语法格式

for var in item1 item2 ... itemN
docommand1
done

4.until语法格式

until循环执行一系列命令直至条件为真时停止,与while循环刚好相反

until condition
docommand
done

5.case

casein模式1)command1command2commandN;;模式2)command1command2;;
esac

6. 跳出循环

在循环过程中,有时候需要在未达到循环结束条件时强制跳出循环,Shell使用两个命令来实现该功能:break和continue

break

break命令允许跳出所有循环(终止执行后面的所有循环)

#!/bin/bash
while :
doecho -n "输入 1 到 5 之间的数字:"read aNumcase $aNum in1|2|3|4|5) echo "你输入的数字为 $aNum!";;*) echo "你输入的数字不是 1 到 5 之间的! 游戏结束"break;;esac
done

continue

#!/bin/bash
while :
doecho -n "输入 1 到 5 之间的数字:"read aNumcase $aNum in1|2|3|4|5) echo "你输入的数字为 $aNum!";;*) echo "你输入的数字不是 1 到 5 之间的!"continueecho "游戏结束";;esac
done

十、shell函数

函数形式的shell编程示例

#!/bin/bash
services=(
aries:8199
nginx:80
)
stop_all_services () {for service in "${services[@]}"do# 获取服务名和端口号name=$(echo "$service" | cut -d":" -f1)port=$(echo "$service" | cut -d":" -f2)cd /export/servers/"$name"/binsh stop.shsleep 2  # 等待一段时间,确保服务已经完全停止# 检查服务是否成功停止if [ "$(curl -sIL -w '%{http_code}\n' http://xxx:$port/ -o /dev/null)" == "000" ]thenecho "Service $name stopped successfully."elseecho "Failed to stop service $name."fidone
}
stop_all_services

十一、日常脚本示例

生产环境centos服务器安全加固脚本

#!/bin/bash
#linux脆弱性加固脚本
system_auth(){echo "---口令锁定策略---"cp -p /etc/pam.d/system-auth /etc/pam.d/system-auth_bakif grep -q 'auth required pam_tally2.so' /etc/pam.d/system-auth;thensed -i 's/^auth.*required.*pam_tally2.so$/&\nauth required pam_tally2.so deny=5 unlock_time=300 even_deny_root root_unlock_time=10/g' /etc/pam.d/system-authelseecho "auth required pam_tally2.so deny=5 unlock_time=300 even_deny_root root_unlock_time=10" >> /etc/pam.d/system-authfi  if grep -q 'account required pam_tally2.so' /etc/pam.d/system-auth;thensed -i 's/^account.*required.*pam_tally2.so$/&\n/g' /etc/pam.d/system-authelseecho "account required pam_tally2.so" >> /etc/pam.d/system-authfi
}
logindefs(){echo "---口令生存期---"cp -p /etc/login.defs /etc/login.defs_baksed -i 's/^PASS_MAX_DAYS.*/PASS_MAX_DAYS 90/g' /etc/login.defssed -i 's/^PASS_MIN_DAYS.*/PASS_MIN_DAYS 10/g' /etc/login.defssed -i 's/^PASS_WARN_AGE.*/PASS_WARN_AGE 7/g' /etc/login.defs
}
system_auth_crack(){echo "---口令复杂度---"# 判断 system-auth 配置文件中是否包含 password requisite pam_cracklib.so 的配置if grep -q 'password requisite pam_cracklib.so' /etc/pam.d/system-auth; then# 如果有,则使用 sed 命令替换原有的行sed -i 's/^password.*requisite.*pam_cracklib.so$/& try_first_pass retry=3 dcredit=-1 lcredit=-1 ucredit=-1 ocredit=-1 minlen=8/g' /etc/pam.d/system-authelse# 如果没有,则添加新的一行echo "password requisite  pam_cracklib.so try_first_pass retry=3 dcredit=-1 lcredit=-1 ucredit=-1 ocredit=-1 minlen=8" >> /etc/pam.d/system-authfi
}
file_contro(){echo "文件与目录缺省权限控制"cp  -p /etc/profile /etc/profile.bakif grep -q 'umask 027' /etc/profile;thenecho "已存在umask 027"elseecho "umask 027" >>/etc/profilefi
}
user_control(){filename1="/etc/passwd"filename2="/etc/shadow"filename3="/etc/group"filename4="/etc/services"filename5="/etc/xinetd.conf"filename6="/etc/security"filename7="/var/log/messages"if [ -e "${filename1}" ]; thenchmod 644 /etc/passwdelseecho "$filename1 不存在"fiif [ -e "${filename2}" ];thenchmod 400 /etc/shadowelseecho "$filename2 不存在"fiif [ -e "${filename3}" ];thenchmod 644 /etc/groupelseecho "$filename3 不存在"fiif [ -e "${filename4}" ];thenchmod 644 /etc/serviceselseecho "$filename4 不存在"fiif [ -e "${filename5}" ];thenchmod 600 /etc/xinetd.confelseecho "$filename5 不存在"fiif [ -e "${filename6}" ];thenchmod 600 /etc/securityelseecho "$filename6 不存在"fiif [ -e "${filename7}" ];then chattr +a /var/log/messageselseecho "$filename7 不存在"fi  
}
security_log(){filename="/var/adm/messages"if [ -e "${filename}" ]; thenchmod 666 /var/adm/messagessystemctl restart rsyslog
elsetouch ${filename}chmod 666 /var/adm/messagesecho "*.err;kern.debug;daemon.notice /var/adm/messages" >> /etc/rsyslog.confsystemctl restart rsyslog
fi
}
login_timeout(){# 检查 /etc/profile 文件是否存在
if [ ! -f /etc/profile ]; thenecho "/etc/profile 文件不存在"exit 1
fi# 使用 sed 命令检查文件末尾是否已经存在所需的两行内容,不存在则添加
if ! grep -q '^TMOUT=' /etc/profile; thenecho 'TMOUT=300' >> /etc/profile
elsesed -i 's/^TMOUT=.*/TMOUT=300/' /etc/profile
fiif ! grep -q '^export TMOUT' /etc/profile; thenecho 'export TMOUT' >> /etc/profile
fi
}
history_set(){# 检查 /etc/profile 文件是否存在
if [ ! -f /etc/profile ]; thenecho "/etc/profile 文件不存在"exit 1
fi# 使用 sed 命令检查文件中是否已经存在所需的两行内容,不存在则添加上去
if ! grep -q '^HISTFILESIZE=' /etc/profile; thenecho 'HISTFILESIZE=5' >> /etc/profile
elsesed -i 's/^HISTFILESIZE=.*/HISTFILESIZE=5/' /etc/profile
fiif ! grep -q '^HISTSIZE=' /etc/profile; thenecho 'HISTSIZE=5' >> /etc/profile
elsesed -i 's/^HISTSIZE=.*/HISTSIZE=5/' /etc/profile
fi# 让配置生效
source /etc/profile
}
core_dump(){# 检查 /etc/security/limits.conf 文件是否存在
if [ ! -f /etc/security/limits.conf ]; thenecho "/etc/security/limits.conf 文件不存在"exit 1
fi# 使用 sed 命令检查文件末尾是否已经存在所需的两行内容
if ! grep -q '^\*\s\+soft\s\+core\s\+0$' /etc/security/limits.conf; thenecho '* soft core 0' >> /etc/security/limits.conf
elsesed -i 's/^\(\*\s\+soft\s\+core\s\+\).*/\10/' /etc/security/limits.conf
fiif ! grep -q '^\*\s\+hard\s\+core\s\+0$' /etc/security/limits.conf; thenecho '* hard core 0' >> /etc/security/limits.conf
elsesed -i 's/^\(\*\s\+hard\s\+core\s\+\).*/\10/' /etc/security/limits.conf
fi# 检查 /etc/profile 文件是否存在
if [ ! -f /etc/profile ]; thenecho "/etc/profile 文件不存在"exit 1
fi# 使用 grep 命令检查文件中是否存在指定内容,同时注释掉对应的行
if grep -q 'ulimit\s\+-S\s\+-c\s\+0\s\+>\s\+\/dev\/null\s\+2>&1' /etc/profile; thensed -i 's/^ulimit\s\+-S\s\+-c\s\+0\s\+>\s\+\/dev\/null\s\+2>&1/#&/' /etc/profile
fi
}
system_auth
logindefs
system_auth_crack
file_contro
user_control
security_log
login_timeout
history_set
core_dump

相关文章:

shell编程基础知识及脚本示例

文章目录 前言一、shell变量1.命名规则2.定义及使用变量 二、shell传递参数1.位置参数2. 任意参数 三、shell一维数组0.定义方式1.定义并获取数组的单个元素2.定义并获取数组的所有元素3.定义并获取数组的元素个数4.定义并获取数组的元素索引 四、shell条件判断语法五、shell常…...

再学GPIO(一)

GPIO输出模式 STM32的GPIO(General Purpose Input Output 通用输入输出)引脚支持多种输出模式,不同模式决定了引脚的驱动能力和信号特性。STM32的GPIO输出模式主要分为以下4种: 推挽输出(Push-Pull Output)…...

OpenCV彩色图像分割

OpenCV计算机视觉开发实践:基于Qt C - 商品搜索 - 京东 灰度图像大多通过算子寻找边缘和区域生长融合来分割图像。彩色图像增加了色彩信息,可以通过不同的色彩值来分割图像,常用彩色空间HSV/HIS、RGB、LAB等都可以用于分割。本节使用inRange…...

django filter 排除字段

在Django中,当你使用filter查询集(QuerySet)时,通常你会根据模型的字段来过滤数据。但是,有时你可能想要排除某些特定的字段,而不是过滤这些字段。这里有几种方法可以实现这一点: 使用exclude方…...

多模态大语言模型arxiv论文略读(四十五)

CAT: Enhancing Multimodal Large Language Model to Answer Questions in Dynamic Audio-Visual Scenarios ➡️ 论文标题:CAT: Enhancing Multimodal Large Language Model to Answer Questions in Dynamic Audio-Visual Scenarios ➡️ 论文作者:Qil…...

Vue3 通过Vue3-Print-Nb在线工单打印 模板打印 自定义打印 打印下载

介绍 通过在应用中集成打印功能,用户可以直接从页面打印工单,不用导出文件或使用其他外部工具。节省时间,提高效率,特别是当需要大量打印时。同时也可以将文件模板上传到数据库,提供给部门工作自行下载。 开源文档&am…...

视觉“解锁”触觉操控:Franka机器人如何玩转刚柔物体?

集智联机器人(Plug & Play Robotics),简称PNP机器人,是Franka Robotics和思灵机器人金牌合作伙伴,集智联机器人团队成员均来自于国内外机器人行业知名企业,具有较强的学术背景。PNP机器人致力于为客户提…...

FlinkUpsertKafka深度解析

1. 设计目标与工作机制 Upsert-Kafka Connector 核心功能:支持以 Upsert(插入/更新/删除) 模式读写 Kafka 数据,适用于需要动态更新结果的场景(如聚合统计、CDC 数据同步)。数据流类型: 作为 …...

百度Create大会深度解读:AI Agent与多模态模型如何重塑未来?

目录 百度Create大会亮点全解析:从数字人到Agent生态布局 数字人商业化:从"拟人"到"高说服力"的进化 Agent生态:从"心响"App看百度的Agent战略布局 "心响"App的技术架构与创新点 多模态大模型&a…...

新能源汽车运动控制器核心芯片选型与优化:MCU、DCDC与CANFD协同设计

摘要:随着新能源汽车产业的迅猛发展,汽车运动控制器的性能和可靠性面临着更高的要求。本文深入探讨了新能源汽车运动控制器中MCU(微控制单元)、DCDC电源管理芯片和CANFD总线通信芯片的选型要点、优化策略及其协同设计方案。通过综…...

【软件工程】 白盒测试简介

1. 前言 在软件测试过程中,白盒测试(White-box Testing)是一种重要方法,它通过检查程序内部结构来验证软件功能。本文以一道典型的伪代码程序为例,结合白盒测试的基本操作,设计语句覆盖测试用例&#xff0…...

uniapp自定义一个选择年月日时分的组件。

<template><view><u-popup :show"timePopShow" mode"bottom" close"close" open"open" :closeOnClickOverlay"true"><view class"popup-container"><!-- 自定义时间内容 --><vi…...

Git命令(Gitee)

三板斧&#xff1a; git init //初始化本地仓库 git add . //添加所有文件到缓存区 &#xff08;或指定文件&#xff09; git commit -m "备注" //提交&#xff0c;填写备注 git remote add origin <远程仓库链接> git push -u origin ma…...

Node.js 应用部署:镜像体积优化与安全的多阶段构建探索

Node.js 应用部署:镜像体积优化与安全的多阶段构建探索 在开发 Node.js 应用时,部署过程中的镜像体积优化和安全性保障是至关重要的环节。本文将通过两种不同的 Docker 部署方式,深入探讨如何实现高效的镜像体积优化和安全的部署环境。 传统的单阶段构建方式 许多开发者在…...

深度解析:Web Crawling与Web Scraping的区别与联系

在现代互联网数据驱动的时代&#xff0c;Web Crawling(网页爬取)和Web Scraping(网页抓取)成为数据采集领域的两大核心技术。尽管两者常被混用&#xff0c;但它们在技术实现、应用目的和操作流程上存在显著差异。本文将基于权威资料&#xff0c;特别是维基百科的定义&#xff0…...

C# 利用log4net 工作台打印和保存到文件

目录 ‌log4net‌简介引言1、添加引用库2、添加引用和构建实例3、添加属性配置4、添加配置文件最后 ‌log4net‌简介 log4net‌是一个开源的日志记录组件&#xff0c;专为.NET平台设计。它是Apache log4j框架在Microsoft .NET平台的实现&#xff0c;属于Apache Logging Servic…...

2025 VSCode中如何进行dotnet开发环境配置完整教程

我一直都是用Visual Studio 2019来开发C#项目的&#xff0c;用的比较顺手&#xff0c;也习惯了。看其他技术文章有介绍VS Code更轻量&#xff0c;更方便。 所以就想来研究如何使用VS Code&#xff0c;看看它是如何构建代码、调试代码、如何运行C#应用程序。 本文将详细介绍如何…...

vscode本地化显示远程图形化界面

远程登陆到服务器端 sudo vim /etc/ssh/sshd_config修改文件中的参数&#xff0c;保存。主要参数如下 配置好上述后需要reload一下ssh,安装xclock。 service ssh reload # 安装x11-apps&#xff0c;这样就可以使用xclock apt install x11-apps查看环境变量,在其中并没有DISPL…...

STM32 CAN通信 HAL库实战教程:从零到测试成功

STM32 CAN通信 HAL库实战教程&#xff1a;从零到测试成功 <我打印的是陀螺仪的数据> 目录 简介&#xff1a;为什么学习CAN通信CAN通信基础概念STM32 CAN硬件配置CAN初始化详解CAN数据发送实现CAN数据接收实现测试与验证方法常见问题与解决总结与拓展 1. 简介&#xff1…...

数据结构强化篇

应用题 排序 插入排序 void InsertSort (ElemType A[], n int) {int i, j;for (i2; i<n; i) //依次将 A[2]&#xff5e;A[n]插入前面已排序序列if (A[i]<A[i-1]) { //若 A[i]关键码小于其前驱&#xff0c;将 A[i]插入有序表A[0]A[i]; //复制为哨兵&#xff0c;A[0]不存放…...

泰迪杯实战案例超深度解析:旅游景点游客流量预测与资源优化

(2025年泰迪杯数据挖掘挑战赛D题特等奖案例) 一、案例背景与目标 1.1 应用场景与痛点 某5A级景区面临以下核心问题: 拥堵严重:节假日热门景点游客密度超过10人/㎡,排队时间长达2小时。 资源浪费:接驳车空载率30%,餐饮点位在非高峰时段闲置率60%。 应急滞后:突发降雨或…...

qt 3d航迹图

一般就是三种方法 1.opengl&#xff0c;vtk这种从零自己画&#xff0c;网上也可能有半成品&#xff0c;大多是付费的。 2.重写qwt3d&#xff0c;07年就停止更新了&#xff0c;画出来类似opengl&#xff0c;需要自己修改参数&#xff0c;参数修改不对很难搞&#xff0c;对于经…...

探索排序算法的奥秘(上):冒泡排序、选择排序、插入排序

在计算机科学中&#xff0c;排序算法是数据处理的基础工具之一。通过对数据进行有序排列&#xff0c;可以极大地提高数据检索和处理的效率。本文将详细介绍三种经典的排序算法&#xff1a;冒泡排序、选择排序和插入排序。我们将从算法思想、原理、代码实现&#xff08;C语言、P…...

Stable Diffusion 技术全景解析与行业竞争力分析

目录 一、Stable Diffusion 技术概览 1. 核心背景 2. 技术架构 二、行业地位与竞品对比 1. 市场定位 2. 核心竞争优势 三、部署成本与硬件要求 1. 硬件配置方案 2. 优化技巧 四、优势与劣势分析 1. 核心优势 2. 主要劣势 五、开源策略与商业模型 1. 开源协议 2. …...

基于Python的DeepSeek API图形界面开发

基于Python的DeepSeek API图形界面开发 在人工智能技术广泛应用的今天&#xff0c;如何将强大的API能力与用户友好的界面结合&#xff0c;成为开发者关注的重点。本文将以DeepSeek API为例&#xff0c;详解如何通过Python构建兼具功能性与美观度的GUI应用程序。 一、技术架构…...

w~嵌入式C语言~合集4

我自己的原文哦~ https://blog.51cto.com/whaosoft/13870376 一、STM32怎么选型 什么是 STM32 STM32&#xff0c;从字面上来理解&#xff0c;ST是意法半导体&#xff0c;M是Microelectronics的缩写&#xff0c;32表示32位&#xff0c;合起来理解&#xff0c;STM32就是指S…...

自动驾驶(ADAS)领域常用数据集介绍

1. KITTI 数据集 简介&#xff1a;由德国卡尔斯鲁厄理工学院与丰田研究院联合创建&#xff0c;是自动驾驶领域最经典的评测基准&#xff0c;涵盖立体视觉、光流、3D检测等任务。包含市区、乡村和高速公路场景的真实数据&#xff0c;标注对象包括车辆、行人等&#xff0c;支持多…...

【嵌入式八股23】Linux关键指令

系统关机命令 在 Linux 系统中,有多种命令可用于实现系统关机或重启操作,以下为你详细介绍各命令及其特点: 指令 说明 shutdown该命令能够安全地将系统关机。它允许用户指定关机的时间,还可以在关机前向所有登录用户发送警告消息。例如,shutdown -h now 可立即关机,shu…...

机器学习的一百个概念(13)布里尔分数

前言 本文隶属于专栏《机器学习的一百个概念》,该专栏为笔者原创,引用请注明来源,不足和错误之处请在评论区帮忙指出,谢谢! 本专栏目录结构和参考文献请见[《机器学习的一百个概念》 ima 知识库 知识库广场搜索: 知识库创建人机器学习@Shockang机器学习数学基础@Shocka…...

AI提示词(Prompt)终极指南:从入门到精通(附实战案例)

在AI重塑工作方式的今天&#xff0c;掌握Prompt工程已成为智能时代的必备技能。本指南系统解析提示词设计精髓&#xff0c;从认知底层逻辑到实战应用技巧&#xff0c;带您解锁AI工具的完整潜能。涵盖主流模型选型策略、三大黄金法则、结构化模板及典型避坑指南&#xff0c;更有…...

鸿蒙版电影app设计开发

鸿蒙电影购票APP项目介绍 一、项目概述及使用方式 &#xff08;一&#xff09;项目概述 在智能手机与移动互联网蓬勃发展的当下&#xff0c;移动设备已成为人们生活不可或缺的一部分&#xff0c;而电影购票这一日常娱乐消费行为也日益向移动端迁徙。鸿蒙系统作为新兴力量&…...

如何启动jar包隐藏cmd窗口

要启动一个JAR文件并隐藏命令行窗口&#xff08;cmd&#xff09;&#xff0c;你可以使用不同的方法&#xff0c;具体取决于你的操作系统。以下是几种常见的方法&#xff1a; 在Windows中使用批处理文件 你可以创建一个批处理文件&#xff08;.bat文件&#xff09;&#xff0c;…...

【Redis】基础3:一些应用场景

文章目录 1. session管理1.1 手机号登录流程1.2 session的数据结构设计1.2.1 一些概念1.2.2 session数据结构例子 1.3 引入redis来实现共享session1.3.1 流程发送验证码短信的流程验证码登录流程登录检查流程 1.3.2 要考虑的问题 2. 限时抢购代金券2.1 业务流程2.2 代金券表设计…...

【创新实训个人博客】multi-agent调研(2)

下面的部分我们将简单介绍现有的三个multi-agent框架&#xff0c;并对它们进行简单的比较 multi-agent框架分析 MetaGPT 相关资料 代码repo&#xff1a;https://github.com/geekan/MetaGPT论文&#xff1a;https://arxiv.org/pdf/2308.0035 AgentVerse 相关资料 代码repo&…...

对鸿蒙 Next 系统“成熟论”的深度剖析-优雅草卓伊凡

对鸿蒙 Next 系统“成熟论”的深度剖析-优雅草卓伊凡 在科技飞速发展的当下&#xff0c;鸿蒙 Next 系统无疑成为了众多科技爱好者与行业人士关注的焦点。今日&#xff0c;卓伊凡便收到这样一个饶有趣味的问题&#xff1a;鸿蒙 Next 系统究竟需要多长时间才能完全成熟&#xff…...

模方ModelFun瓦片数据操作教程

摘要&#xff1a;本文主要介绍模方ModelFun瓦片数据操作&#xff0c;包含&#xff1a;打开/关闭瓦片数据&#xff0c;备份和恢复&#xff0c;导出 OBJ/ OSGB&#xff0c;导出DOM/DSM。 1.打开/关闭瓦片数据 在“总体模型视图/OSGB”里对 tiles 进行操作&#xff1a;选择&…...

RabbitMQ应用(基于腾讯云)

1.防火墙配置 关于RabbitMQ的远程&#xff0c;主要有4个端口需要开通【入站规则】&#xff0c;分别是&#xff1a; 端口 5672&#xff1a;这是 RabbitMQ 的默认 AMQP&#xff08;Advanced Message Queuing Protocol&#xff09;端口&#xff0c;用于客户端与 RabbitMQ 服务器之…...

堆和二叉树的概念和操作

目录 1.树的概念 1.1数的表示 1.2二叉树 1.3特殊的二叉树 1.3.1满二叉树 1.3.2完全二叉树 1.3.3 二叉树存储结构 2.堆 2.1堆的实现 初始化和销毁 堆的插入 堆的向上调整算法​编辑 ​编辑 堆的删除 出堆顶 1.树的概念 树是非线性的数据结构&#xff0c;有限节点具有的层…...

互联网大厂Java面试实录:从Spring Boot到微服务架构的技术问答

互联网大厂Java面试实录&#xff1a;从Spring Boot到微服务架构的技术问答 在某互联网大厂的面试现场&#xff0c;严肃的面试官开始了对求职者谢飞机的技术考核。此次面试围绕Java技术栈的应用与场景展开。 第一轮&#xff1a;基础架构与语言 面试官&#xff1a; 请你用简单…...

Rollup、Webpack、Esbuild 和 Vite 前端打包工具

Rollup、Webpack、Esbuild 和 Vite 都是前端开发中常用的打包工具&#xff0c;它们各有特点&#xff0c;以下是对它们的详细对比&#xff1a; 核心功能 Rollup&#xff1a;专注于 JavaScript 模块打包&#xff0c;擅长将小的 JavaScript 模块打包成一个或多个文件&#xff0c…...

刀客独家 | 潘胜接管百度移动生态市场部

一、 据刀客doc向独家信源确认&#xff0c;百度移动生态事业群&#xff08;MEG&#xff09;市场部日前完成重要人事调整&#xff1a;潘胜已经接任市场负责人。 此前&#xff0c;根据雷锋网3月底的报道&#xff0c;百度云渠道生态总经理陈之若离职&#xff0c;原移动生态事业群…...

如何在Chrome浏览器中启用硬件加速【提升浏览器性能】

在使用谷歌浏览器时&#xff0c;硬件加速是提升性能的一个重要功能。它可以将一些计算任务从CPU转移到GPU&#xff0c;从而加速图像处理、视频播放等任务。如果您希望提升浏览器的运行速度&#xff0c;可以通过以下简单步骤启用硬件加速。 1. 打开Chrome浏览器设置 首先&#…...

部署mongodb三幅本集群

背景&#xff1a;原先使用的mongodb采用的是SSPL协议&#xff0c;此协议客户检测到有bug&#xff0c;故需要替换mongodb的版本&#xff0c;原先采用helm部署的mongodb但是无法找到4.1.4版本的chart包&#xff0c;故手写yaml部署 1、部署mongodb-arbiter服务 这个服务是用来选…...

JavaScript 解构赋值(下):对象解构与高级应用

对象解构赋值 基本语法 const person { name: Alice, age: 30 }; const { name, age } person;console.log(name); // Alice console.log(age); // 30别名 const { name: fullName, age: years } person; console.log(fullName); // Alice console.log(years); // 30…...

批量级负载均衡(Batch-Wise Load Balance)和顺序级负载均衡(Sequence-Wise Load Balance)

本文主要比较了批量级负载均衡(Batch-Wise Load Balance)和顺序级负载均衡(Sequence-Wise Load Balance)在 Mixture-of-Experts(MoE)模型训练中的核心区别 。批量级负载均衡通过对整个训练批次的专家负载进行平衡约束,实现了更灵活的均衡策略,有助于专家在不同领域的专…...

什么是EI期刊?EI目录列表如何看?一文查看最新目录+避坑指南

近期有很多人在后台问小编关于EI期刊的各种问题&#xff0c;且前段时间EI期刊目录刚刚更新&#xff0c;小编正好借此&#xff0c;这期仔细给大家介绍一下。 什么是EI期刊&#xff1f; EI期刊也称为工程索引期刊&#xff0c;是供查阅工程技术领域文献的综合性情报检索刊物。每年…...

[创业之路-341]:华为人力资源管理 - 华为技术专家体系详解

华为技术专家体系详解 一、技术专家等级划分 华为技术专家体系以 “专业能力管理贡献” 为双维度&#xff0c;覆盖 19级&#xff08;技术专家B&#xff09;至22级&#xff08;集团核心领导者&#xff09;&#xff0c;其中 19B-20A级 为核心技术专家层级&#xff1a; 19B级&a…...

【HarmonyOS 5】鸿蒙检测系统完整性

【HarmonyOS 5】鸿蒙检测系统完整性 一、前言 从现实安全威胁来看&#xff0c;设备系统完整性风险已影响至移动应用的各个场景。不少用户因使用越狱设备&#xff08;Jailbreak&#xff09;或非真实设备&#xff08;Emulator&#xff09;&#xff0c;导致应用安全防护机制失效…...

量子网络:构建未来通信的超高速“高速公路”

在当今数字化时代&#xff0c;通信技术的飞速发展极大地推动了全球信息的流动和共享。然而&#xff0c;随着数据量的爆炸式增长和对信息安全需求的不断提高&#xff0c;传统通信网络正面临着前所未有的挑战。量子网络作为一种新兴的通信技术&#xff0c;以其超高速传输和绝对安…...

安卓触摸事件分发机制分析

1. 前言 &#x1f3af; 一句话总结&#xff1a; 触摸事件&#xff08;TouchEvent&#xff09;会从 Activity 层开始&#xff0c;按从外到内的方式传递给每一个 ViewGroup/View&#xff0c;直到某个 View 消费&#xff08;consume&#xff09; 它&#xff0c;事件传递就会停止…...