一、Shell 脚本基础
一、Shell 简介
1.Shell 的定义与作用
Shell,通常被称为命令行解释器 (Command Line Interpreter),是用户 👤 与 Linux/Unix 操作系统内核进行交互 ↔️ 的“桥梁” 🌉。它扮演着翻译官 🗣️ 的角色:
- 接收用户输入的命令 (如
ls
,cd
,mkdir
)。 - 解释这些命令 🧐。
- 调用操作系统内核执行相应的功能。
- 将执行结果返回并显示给用户 🖥️。
简单来说,没有 Shell,我们就很难方便地直接与强大的操作系统内核打交道了!💻 (简直无法想象!)
2.常见的 Shell 类型
存在多种不同的 Shell 实现,它们在语法、功能和效率上可能有所差异 ✅:
- bash (Bourne Again SHell): 这是目前最流行、最常用 ⭐ 的 Shell,是绝大多数 Linux 发行版的默认 Shell。它兼容 sh,并增加了许多新特性(命令历史、命令补全、作业控制等)。我们后续的脚本主要会以 bash 为基础。
- sh (Bourne Shell): 一个早期且经典 📜 的 Unix Shell,由 Stephen Bourne 开发。许多旧的或要求高兼容性 🤝 的脚本仍会使用它。在很多系统中,
/bin/sh
可能是一个指向bash
(或其他 Shell) 的符号链接,但bash
在以sh
模式运行时会限制某些功能以保持兼容。 - zsh (Z Shell): 一个功能极其强大 💪 的 Shell,提供了比 bash 更丰富的功能、更强的自动补全 ✨、主题和插件系统(如 Oh My Zsh),深受许多开发者喜爱 ❤️。
- ksh (Korn Shell): 由 David Korn 开发,试图融合 sh 的脚本能力和 C Shell 的交互特性。
- csh/tcsh (C Shell / TENEX C Shell): 语法风格类似 C 语言,交互性较好,但脚本编写方面有时被认为不如 Bourne 系列 Shell。
小提示: 💡 你可以在终端输入 echo $SHELL
来查看你当前正在使用的 Shell 类型。
3.Shell 与 Shell 脚本的区别
这是一个非常基础但重要的概念 🤔:
- Shell (交互式): 指的是你直接在终端(命令行界面)中输入命令,按回车后立即看到执行结果的环境。这是一种你问我答式的交互方式 💬。
# 这就是在交互式 Shell 中输入命令
ls -l
pwd
- Shell 脚本 (非交互式): 是一个文本文件 📜,里面包含了一系列按照特定顺序编写的 Shell 命令。你可以一次性执行这个脚本文件,让计算机自动完成 🤖 一系列复杂的或重复性的任务,实现自动化。这是一种批量处理的执行方式 ⚙️。
# my_script.sh 文件内容可能像这样:
# #!/bin/bash
# echo "开始执行任务..."
# mkdir temp_dir
# cd temp_dir
# echo "任务完成!"
二、 编写第一个 Shell 脚本
1.脚本文件的创建与命名
创建一个 Shell 脚本非常简单:
- 使用文本编辑器: 打开你喜欢的文本编辑器(如
vim
,nano
,gedit
, VS Code 等)📝。 - 编写命令: 在文件中输入你的 Shell 命令。
- 保存文件: 将文件保存 💾。
- 命名约定 🏷️: 虽然不是强制性的,但强烈建议将 Shell 脚本文件以 .sh 后缀结尾(例如
my_first_script.sh
,backup_data.sh
)。这有助于识别文件类型 👀,并且让其他用户(以及未来的你 😅)更容易理解。📄
- 命名约定 🏷️: 虽然不是强制性的,但强烈建议将 Shell 脚本文件以 .sh 后缀结尾(例如
2.指定解释器 (Shebang)
这是 Shell 脚本中至关重要❗ 的一行! ✨
- 什么是 Shebang? 脚本文件的第一行内容,格式为
#!解释器路径
。 - 作用: 它告诉操作系统内核,当直接执行这个脚本文件时(即使用方法 2:
./script.sh
方式),应该调用哪个解释器来处理文件中的命令。 注意: 如果使用方法 1 (bash script.sh
) 或方法 3 (source script.sh
) 执行,Shebang 行实际上会被忽略 🤷♀️,因为解释器已经由用户显式指定 (方法 1) 或就是当前 Shell (方法 3)。 - 绝对要求: Shebang 行必须是脚本文件的绝对第一行,前面不能有任何字符,包括空格或空行。
常见的 Shebang 选项:
虽然 #!/bin/bash
是最常见的,尤其是在 Linux 环境中,但还有其他一些常用的选项,选择哪个取决于你的脚本需求和目标运行环境:
-
#!/bin/bash
:- 指定使用 Bourne Again Shell (bash) 来执行脚本。
- 优点: 可以使用 bash 提供的所有扩展功能 💪(如数组、双方括号
[[ ]]
条件测试、函数等)。 - 缺点: 如果系统没有安装 bash 或者 bash 不在
/bin/bash
路径下,脚本会执行失败 💥。依赖 bash 特性的脚本可移植性稍差。
-
#!/bin/sh
:- 指定使用 Bourne Shell (sh) 来执行脚本。
- 优点: 目标是编写符合 POSIX 标准 📜 的脚本,具有更好的可移植性 🌍。在很多系统中,
/bin/sh
可能是一个指向bash
、dash
或其他兼容 Shell 的符号链接。当bash
以sh
模式被调用时,它会禁用一些 bash 特有的扩展。 - 缺点: 不能使用 bash 等现代 Shell 的扩展语法和功能,编写复杂脚本可能更繁琐 😓。
-
#!/usr/bin/env <interpreter>
(例如#!/usr/bin/env bash
或#!/usr/bin/env python
):- 这是强烈推荐 👍 的一种方式,特别是对于需要分发 📦 的脚本。
env
是一个命令,它会在系统的PATH 环境变量 🗺️ 所指定的目录中查找第一个找到的<interpreter>
(如bash
,python
,perl
,node
等)并使用它来执行脚本。- 优点: 极大地提高了可移植性 🚀。不同系统或用户可能将解释器安装在不同的路径下(如
/usr/bin/bash
,/usr/local/bin/bash
,/opt/bin/bash
)。使用env
可以确保只要解释器在用户的 PATH 中,脚本就能找到它 👌。 - 缺点: 相比直接指定路径,会有极其微小的额外启动开销(查找解释器)。安全性方面,如果 PATH 被恶意篡改,可能会执行非预期的解释器(但这种情况很少见且通常已有更大的安全问题 😨)。
- 常见示例:
#!/usr/bin/env bash
(推荐 ✅ 的 bash 脚本 Shebang)#!/usr/bin/env sh
(推荐 ✅ 的可移植 sh 脚本 Shebang)#!/usr/bin/env python3
(用于 Python 3 脚本 🐍)#!/usr/bin/env perl
(用于 Perl 脚本 🐪)#!/usr/bin/env node
(用于 Node.js 脚本 🟢)
-
其他 Shell:
#!/bin/zsh
或#!/usr/bin/env zsh
: 指定使用 Z Shell。#!/bin/ksh
或#!/usr/bin/env ksh
: 指定使用 Korn Shell。
🤔 如何选择 Shebang?
- 如果你的脚本只在你自己控制的、确定安装了 bash 的 Linux 系统上运行,并且你需要 bash 的特性,
#!/bin/bash
或#!/usr/bin/env bash
都可以。 - 如果你希望脚本尽可能广泛地兼容 🌍 各种 Unix-like 系统(包括 macOS, BSD 等),并且只使用了 sh 的标准功能,那么使用
#!/bin/sh
或#!/usr/bin/env sh
是更安全、更推荐的选择 ✅。 - 为了最大化可移植性 🚀,通常首选推荐使用
#!/usr/bin/env <interpreter>
的形式 👍。
3.脚本的执行方式
你有三种主要的方式来运行你的 Shell 脚本 ▶️:
- 作为解释器的参数执行:
- 这种方式不需要给脚本文件设置执行权限 🔑。
- 你直接调用 Shell 解释器 (如
bash
或sh
),并将脚本文件名作为参数传递给它。 - 优点: 简单直接,无需关心执行权限。
- 注意: 脚本在子 Shell 🐣 (subshell) 中执行,脚本中定义的变量、函数或对环境的修改(如
cd
)在脚本结束后不会影响当前的 Shell 环境 🏠。 - 命令格式:
bash my_script.sh
# 或者,如果脚本兼容 sh
sh my_script.sh
- 赋予执行权限后直接运行:
- 第一步:添加执行权限 🔑: 使用
chmod
命令给脚本文件添加执行权限 (x)。
- 第一步:添加执行权限 🔑: 使用
chmod +x my_script.sh
+x
表示为所有用户(所有者、同组用户、其他用户)添加执行权限。你也可以使用更精细的权限设置,如 chmod u+x my_script.sh
只为文件所有者添加执行权限。
- 第二步:直接执行:如果脚本文件位于当前目录,你需要使用
./
来告诉 Shell 在当前目录下查找并执行该文件:
./my_script.sh
- 如果脚本文件位于系统的 PATH 环境变量 🗺️ 所包含的目录中,或者你指定了完整的绝对/相对路径,则可以直接使用脚本名或路径执行:
# 假设 /opt/scripts 在 PATH 中,且 my_script.sh 在该目录下
my_script.sh
# 或者使用绝对路径
/path/to/your/script/my_script.sh
# 或者使用相对路径
../scripts/my_script.sh
- 优点: 这是最标准、常用 ✅ 的执行方式,特别是对于需要分发的工具脚本。Shebang 行
#!
决定了使用哪个解释器。 - 注意: 脚本同样在子 Shell 🐣 (subshell) 中执行,对当前 Shell 环境没有持久影响 🏠。
- 为什么需要
./
? 出于安全考虑 🛡️。Linux/Unix 系统默认不会在当前目录下查找可执行文件(除非当前目录被显式添加到了 PATH 环境变量中)。使用./
可以明确指定执行当前目录下的文件,防止意外执行了与系统命令同名的恶意脚本 😈。
- 使用
source
或.
命令在当前 Shell 环境 🏠 中执行: 🎯source
是一个 Shell 内建命令,它的简写形式是一个点 (.
)。- 这种方式不需要给脚本文件设置执行权限 🔑(只需要读权限
r
即可 📖)。 - 命令格式:
source my_script.sh
# 或者使用点号 (点号和脚本名之间必须有空格!)
. my_script.sh
- 核心区别: 核心区别: 使用
source
或.
执行时,脚本中的命令直接在当前的 Shell 环境中 🏠 执行,而不是启动一个新的子 Shell 🐣。 - 优点/用途: 这意味着脚本中定义的变量、函数、别名 (alias),或者执行的
cd
、export
等命令,在脚本执行完毕后会保留在当前的 Shell 会话中 ✅。因此,它常用于:- 加载配置文件 ⚙️ (如
.bashrc
,.profile
,/etc/profile
)。 - 设置环境变量 🌐 供后续命令使用。
- 定义可以在当前终端后续使用的函数库 📚。
- 在脚本中切换目录 (
cd
) 后,希望停留在那个新目录 👉。
- 加载配置文件 ⚙️ (如
- 注意: 必须确保脚本内容是你希望在当前环境中执行的,因为它可能直接修改 💥 你当前的工作环境。要谨慎使用!⚠️
🎯 执行方式对比小结:
执行方式 | 需要执行权限 (x)? 🔑 | 在子 Shell 中执行? 🐣 | 对当前 Shell 环境的影响 🏠 | 主要用途 🎯 |
---|---|---|---|---|
bash script.sh | 否 ❌ | 是 ✅ | 无 ❌ | 运行一次性任务,不需改变当前环境 |
./script.sh (需+x) | 是 ✅ | 是 ✅ | 无 ❌ | 标准的脚本执行 ✅,分发工具脚本 |
source script.sh | 否 (需r) 📖 | 否 ❌ | 有 (持久) ✅ | 加载配置/环境/函数 ⚙️,改变当前环境 |
三、注释与可读性
编写清晰易懂 ✨ 的脚本至关重要,而注释是实现这一目标的关键工具 🛠️。
1.单行注释
- 在 Shell 脚本中,使用 # 符号来表示单行注释 💬。
- 从
#
开始,直到该行的末尾,所有的内容都会被 Shell 解释器忽略 🙈,不会被执行。 - 注释可以单独占一行,也可以放在命令的后面。
#!/bin/bash# 这是一个完整的单行注释,用于说明脚本的目的
# Author: Your Name
# Date: 2025-5-2echo "Hello, World!" # 这也是一个注释,解释这行命令的作用# 下面定义一个变量
USER_NAME="Alice" # 为变量赋值
2.多行注释的实现方式
Shell 本身没有提供像 C 语言 /* ... */
或 Python """ ... """
那样的原生多行注释块 🧱 语法。但是,可以通过一些技巧 🎩 来实现类似的效果:
- 方法一:使用 Here Document (推荐用于注释大段代码或文本)
将你想要注释掉的内容通过 Here Document (<<LIMITER ... LIMITER
) 重定向给一个空命令:
(冒号是一个内置的不做任何事情的命令)。LIMITER
可以是任何不出现在注释内容中的字符串,通常使用EOF
或COMMENT
。在起始LIMITER
前加上单引号 (: <<'EOF'
) 可以阻止其中的变量和命令替换。
#!/bin/bashecho "这行代码会执行": <<'MY_MULTI_LINE_COMMENT'
这里是第一行注释内容。
这里是第二行注释内容。
这整块代码/文字都不会被执行。
可以包含 $VARIABLES 或 `commands`,因为用了 'MY_MULTI_LINE_COMMENT'。
MY_MULTI_LINE_COMMENTecho "这行代码也会执行"
- 方法二:连续使用单行注释
这是最简单直接的方法,只需在每一行注释前都加上#
。对于解释性的多行文字,这种方式也很常用。
#!/bin/bash# ==================================
# 这是一个多行注释块
# 用来详细说明某个复杂函数的逻辑
# 或者记录一些重要的注意事项
# ==================================
calculate_sum() {
# 函数内部的注释
local result=$(($1 + $2)) # 计算总和
echo $result
}sum=$(calculate_sum 10 20)
echo "计算结果是: $sum"
3.良好的注释习惯与代码可读性
注释的终极目标 🏆 是提升代码的可读性 👀 和可维护性 🔧。遵循以下原则:
- 解释“为什么”(Why 🤔),而不是“干什么”(What ✅): 好的代码(比如有意义的变量名和函数名)本身应该能说明它在做什么。注释应该聚焦于解释为什么选择这种实现方式、背后的逻辑、潜在的陷阱 ⚠️ 或重要的上下文。
# 不好的注释 (冗余 🤷)
# i = i + 1 # 把 i 加 1# 好的注释 (解释原因 👍)
# 使用特定的算法ID,因为旧版本存在兼容性问题
algorithm_id=3
- 保持注释简洁且同步 🔄: 注释应该清晰明了,避免冗长。最重要的是,当代码发生变化时,务必更新相关的注释,否则过时的注释比没有注释更糟糕!💣
- 注释复杂 🤯 或不直观的部分: 对于复杂的正则表达式、算法、重要的业务逻辑或临时的 Workaround,添加注释非常有帮助 🙏。
- 文件头注释 ራስ: 在脚本文件的开头添加注释块,说明脚本的用途、作者、创建/修改日期、版本号、使用方法等信息,是一个非常好的实践 ⭐。
#!/usr/bin/env bash
# ==============================================================================
# Script Name: backup_database.sh
# Description: Performs a daily backup of the production PostgreSQL database.
# Author: Your Name <your.email@example.com>
# Date Created: 2023-5-2
# Last Modified: 2023-5-2
# Version: 1.2
# Usage: ./backup_database.sh
# Notes: Requires pg_dump command and write access to BACKUP_DIR.
# Recommend running via cron.
# ==============================================================================
- 利用空行和(代码块外的)缩进 🏗️: 合理地使用空行分隔逻辑块。在非代码块的文本部分,可以使用缩进(如列表项)来组织内容,提高结构清晰度。
- 写给未来的你 🔮 和他人 🤝: 记住,你写的代码和注释,很可能在几个月或几年后需要被你自己或其他同事阅读和维护。清晰的注释是对未来时间和精力的投资 💰。
四、Shell 脚本基础练习题 🧠✍️
题目一:基础概念
❓ 简述 Shell 在 Linux/Unix 系统中的主要作用是什么?它扮演了什么角色?
题目二:Shebang
❓ Shell 脚本的第一行 #!/bin/bash 有什么作用?它通常被称为什么?
题目三:执行权限
❓ 如何让一个名为 my_script.sh 的 Shell 脚本文件,能够直接通过 ./my_script.sh 的方式运行?请写出关键命令。
题目四:执行方式辨析
❓ 执行 Shell 脚本时,使用 bash script.sh 和 source script.sh (或 . script.sh) 的主要区别是什么?哪种方式会影响当前的 Shell 环境? 🤔
题目五:注释
❓ 在 Shell 脚本中,如何添加单行注释?请给出表示注释的符号。
题目六:多行注释模拟
❓ Shell 没有原生的多行注释块语法。请描述一种常用的、基于 Here Document 的方法来模拟多行注释。📝
题目七:Shebang 最佳实践
❓ 为什么通常推荐使用 #!/usr/bin/env bash 而不是直接使用 #!/bin/bash 作为 Shebang? 主要优势是什么? 🚀
参考答案 ✅💡
答案一:
Shell 主要作用是作为用户 👤 与 操作系统内核 之间的命令行解释器。它扮演着翻译官 🗣️ 的角色,负责接收、解释用户的命令,调用内核执行,并将结果返回给用户 🖥️。它是实现与系统交互 ↔️ 的桥梁 🌉。
答案二:
#!/bin/bash 的作用是指定解释器。当脚本被直接执行时 (例如通过 ./script.sh),操作系统会根据这一行找到 /bin/bash 解释器来处理脚本中的命令 ✨。这一行通常被称为 Shebang。
答案三:
为了让 my_script.sh 可以通过 ./my_script.sh 直接运行,需要给它添加执行权限 🔑。关键命令是:
chmod +x my_script.sh
答案四:
主要区别在于执行环境:
- bash script.sh 会启动一个新的子 Shell (subshell) 🐣 来执行脚本。脚本中的变量定义、函数、cd 等操作不会影响当前的 Shell 环境 🏠。
- source script.sh (或 . script.sh) 则是在当前的 Shell 环境 🏠 中直接执行脚本的命令。脚本中定义的变量、函数、cd 等操作会保留在当前 Shell 会话中 ✅。
因此,source 或 . 方式会影响当前的 Shell 环境。
答案五:
在 Shell 脚本中,使用 # 符号来添加单行注释 💬。从 # 到行尾的内容都会被解释器忽略 🙈。
答案六:
一种常用的模拟多行注释的方法是使用 Here Document 并将其重定向给一个空命令 :。格式如下:
: <<'任意分隔符'
这里是第一行注释。
这里是第二行注释。
这整块内容都不会被执行。
任意分隔符
使用单引号包裹起始分隔符 (如 ‘任意分隔符’) 可以阻止其中的变量和命令替换,使其更像纯粹的注释块。
答案七:
推荐使用 #!/usr/bin/env bash 的主要优势在于提高了脚本的可移植性 🚀🌍。
- #!/bin/bash 写死了 bash 解释器的绝对路径。如果用户的 bash 不在这个位置 (例如在 /usr/local/bin/bash),脚本就无法直接执行 💥。
- #!/usr/bin/env bash 利用 env 命令在用户的PATH 环境变量 🗺️ 中查找 bash 解释器。只要用户的 PATH 中能找到 bash,无论它安装在哪里,脚本都能正确找到并执行 👌。这使得脚本在不同系统、不同环境下的适应性更强 💪。
相关文章:
一、Shell 脚本基础
一、Shell 简介 1.Shell 的定义与作用 Shell,通常被称为命令行解释器 (Command Line Interpreter),是用户 👤 与 Linux/Unix 操作系统内核进行交互 ↔️ 的“桥梁” 🌉。它扮演着翻译官 🗣️ 的角色: 接…...
redis持久化-RDB
redis持久化-RDB 文档 redis单机安装redis常用的五种数据类型redis数据类型-位图bitmapredis数据类型-基数统计HyperLogLogredis数据类型-地理空间GEOredis数据类型-流Streamredis数据类型-位域bitfield 官方文档 官网操作命令指南页面:https://redis.io/docs/l…...
经典算法 石子合并问题
石子合并问题 问题描述 在一个园形操场的四周摆放N堆石子,现要将石子有次序地合并成一堆.规定每次只能选相邻的2堆合并成新的一堆,并将新的一堆的石子数,记为该次合并的得分。试设计出一个算法,计算出将N堆石子合并成1堆最大得分和最小得分。 输入描述…...
2025A卷华为OD机试真题-数组二叉树(C++/Java/Python)-100分
2025华为OD机试题库-(2025A卷+E卷+D卷)-(JAVA、Python、C++) 目录 题目描述 输入描述 输出描述 示例 1 示例 2 解题思路 代码 c++ java python 题目描述 二叉树也可以用数组来存储,给定一个数组,树的根节点的值储存在下标1,对于储存在下标n的节点,他的左子节点…...
NHANES指标推荐:TyG指数
文章题目:Association between the Triglyceride-glucose index and fragility fractures among US adults: insights from NHANES DOI:10.1186/s13098-025-01669-w 中文标题:美国成年人甘油三酯-葡萄糖指数与脆性骨折之间的关联:…...
文件操作--文件下载读取漏洞
本文主要内容 文件下载 产生 任意语言代码下载功能函数 检测 白盒 代码审计 黑盒 漏扫工具、公开漏洞、手工看参数值及功能点(资源下载) 利用 常见文件 后台首页日志等可见文件 敏感文件 数据库配置文件、各种接口文件、密匙…...
4.0/Q2,Charls最新文章解读
文章题目:The nonlinear association of ratio of total cholesterol to high density lipoprotein with cognition ability: evidence from a community cohort in China DOI:10.3389/fnut.2025.1525348 中文标题:总胆固醇与高密度脂蛋白比值…...
Linux-常用监控工具
以下是对 Linux 系统中常用监控工具(netstat、ss、dmesg)的系统性介绍,涵盖其核心功能、典型用法及实际应用场景,帮助您分析系统状态和内核参数调整后的效果: 1. netstat -s:网络协议栈统计监控 功能 net…...
【HarmonyOS Next】地图使用详解(三)标点定位问题
背景 在使用geoLocationManager的getCurrentLocation方法获得的用户定位经纬度的坐标系为 WGS84 ,但是mapkit使用的是GCJ02坐标系。因此,我们在使用获取用户经纬度然后直接生成标记时,会出现坐标偏移问题。如下: 解决方案 使用…...
Linux运维中常用的磁盘监控方式
在Linux运维中,磁盘监控是一项关键任务,因为它能帮助我们预防磁盘空间不足或性能问题导致的服务中断或数据丢失。让我们来看看有哪些常用的磁盘监控方法吧! 1. 查看磁盘使用情况(df命令) df命令用于显示文件系统的…...
前端面经-VUE3篇--vue3基础知识(二)计算属性(computed)、监听属性(Watch)
一、计算属性(computed) 计算属性(Computed Properties)是 Vue 中一种特殊的响应式数据,它能基于已有的响应式数据动态计算出新的数据。 计算属性有以下特性: 自动缓存:只有当它依赖的响应式数据发生变化时ÿ…...
双向链表详解
一、双向链表介绍 二、实现双向链表 1.定义双向链表的结构 2.双向链表的初始化 3.双向链表的尾插 4.双向链表的头插 5.双向链表的打印 6.双向链表的尾删 7.双向链表的头删 8.查找指定位置的数据 9.在指定位置之后插入数据 10.删除指定位置的数据 11.链表的销毁 三、…...
基于SpringBoot+Vue实现的电影推荐平台功能一
一、前言介绍: 1.1 项目摘要 2023年全球流媒体用户突破15亿,用户面临海量内容选择困难,传统推荐方式存在信息过载、推荐精准度低等问题。传统推荐系统存在响应延迟高(平均>2s)。随着互联网的快速发展,…...
预订接口优化:使用本地消息表保证订单生成、库存扣减的一致性
🎯 本文介绍了一种优化预订接口的方法,通过引入本地消息表解决分布式事务中的最终一致性问题。原先的实现是在一个事务中同时扣减库存和创建订单,容易因网络不稳定导致数据不一致。改进后的方法将业务操作和消息发送封装在本地事务中…...
深度学习与 PyTorch 基础
笔记 1 深度学习简介 1.1 深度学习概念 深度学习是机器学习的一类算法, 以人工神经网络为结构, 可以实现自动提取特征 深度学习核心思想是人工神经网络为结构, 自动提取特征 1.2 深度学习特点 自动提取特征 解释性差 大量数据和高性能计算能力 非线性转换(引入非线性因…...
libevent库详解:高性能异步IO的利器
目录 一、libevent 简介 主要特点: 二、事件模型原理 1. event_base 2. event 3. evconnlistener(TCP监听器) 4. bufferevent 简化流程如下: 三、libevent 使用示例 1. 创建事件主循环 2. 创建监听器(TCP&a…...
第一章:A Primer on Memory Consistency and Cache Coherence - 2nd Edition
引言: 许多现代计算机系统,包括同构和异构架构的系统,都在硬件层面支持共享内存。在共享内存系统中,每个处理器核心都可以对单一的共享地址空间进行读写操作。对于共享内存计算机而言,内存一致性模型定义了其内存系统在…...
NVIDIA Omniverse在数字孪生中的算力消耗模型构建方法
引言:虚拟实验室的算力经济学 在高校虚拟实验室建设中,数字孪生系统的实时物理仿真精度与算力成本之间存在显著矛盾。以H800 GPU集群为例,单个8卡节点每秒可处理2.3亿个物理粒子交互,但若未建立精准的算力消耗模型,资…...
C++ 动态内存管理详讲
1. 四个全局函数的定义与作用 这四个函数只负责空间的开辟和释放,不会调构造和析构 (1) ::operator new cpp void* operator new(size_t size); // 全局版本 功能:分配 size 字节的未初始化内存。 底层实现:调用 malloc(size)。 调用场…...
纹理对象创建
纹理对象通俗点就是贴图,像游戏的皮肤什么就是纹理。常间的结构就是激活纹理单元(0-15有16个),将纹理对象挂在纹理单元上,纹理采样器需要采哪个样品就与哪个单元挂钩就行了,加载纹理对象需要用到stb_image库…...
如何利用dify 生成Fine‑tune 需要的Alpaca 格式数据
如果你选择llamafactory 格式进行微调,它只是格式是Alpaca格式,dify 的agent dsl 如下,你可以导入本地的dify 或者导入cloud 版本的;测试版本是0.1.5 app:description: 上传文件,基于文件内容,使用 Silico…...
软件第三方测试:关键部分、意义、流程及方法全解析?
软件第三方测试是保障软件质量的关键部分,它由专业的机构来开展,这个机构不隶属于开发方和使用方,能以客观公正的视角找出软件问题。 测试意义 软件第三方测试意义重大,它依靠专业技术,依照严格流程,对软…...
贪心算法解决会议安排问题
文章目录 前言 一、什么是贪心算法? 贪心算法的基本概念:贪心算法并不从整体最优上加以考虑,所做的选择只是在某种意义上的局部最优选择。 二、会议安排题目 1.题目理解 2.思路剖析 总结 前言 本文将主要介绍贪心算法需要注意的地方以…...
高露洁牙膏是哪个国家的品牌?高露洁牙膏哪一款最好?
高露洁是来自于美国一个比较有知名度的品牌,在1806年的时候创立。总部是在美国纽约公园大道,在1873年时,高露洁就已经开始销售罐装牙膏。 在1896年时期推出可折叠管牙膏,在口腔护理产品发展的过程中拥有着不容忽视的地位。在1992…...
lin接口在线计算数据帧的校验位
在线校验计算链接:https://linchecksumcalculator.machsystems.cz/ 插入图片:...
Linux-07-Shell
一、Shell概述: Shell是一个命令行解释器,它接受应用程序/用户命令,然后调用操作系统内核 二、Shell中的变量: 1.系统预定义的变量: $HOME,$PWD,$SHELL,$USER等 2.用户自定义的变量: (1).基本语法: 定义变量:变量名变量值,注意前后不能…...
【云盘】使用阿里云盘托管项目大文件
【云盘】使用阿里云盘托管项目大文件 由于经常需要切换服务器运行项目实验,不同服务器在项目实验过程中会产生不同的数据、模型等较大文件,不能像代码那样能够使用git托管,因此考虑使用阿里云盘作为”第三方平台“托管这些大文件。 一、使用…...
《缓存策略:移动应用网络请求的“效能密钥” 》
用户体验无疑是重中之重,而网络请求性能,恰似一座桥梁,连接着用户与应用丰富的内容和功能。当网络不佳或者请求频繁时,缓慢的响应速度常常让用户兴致索然,甚至可能导致用户流失。此时,缓存策略就如同一位幕…...
深入解析C++11委托构造函数:消除冗余初始化的利器
一、传统构造函数的痛点 在C11之前,当多个构造函数需要执行相同的初始化逻辑时,开发者往往面临两难选择: class DataProcessor {std::string dataPath;bool verbose;int bufferSize; public:// 基础版本DataProcessor(const std::string&am…...
文章七《深度学习调优与超参数优化》
🚀 文章7:深度学习调优与超参数优化——你的AI模型需要一场"整容手术" 一、模型调优核心策略:像调整游戏装备一样优化模型 1. 学习率调整:掌控训练的"油门踏板" 比喻:把模型训练想象成赛车游戏&…...
python入门(1)变量与输入输出
一、变量 使用规则 变量名值例子 a13变量名规则 变量名可以用大小写字母、数字、下划线。 数字、下划线不可开头 例子 name name1 1name name_first _first 二、输入输出 输出print print(*objects,sep"",end"\n") objects:多个要输出的值 sep:每个…...
藏文情感分析器入门学习实践
🎯 项目目标: 输入一段藏文短句。自动分析这句话的情感倾向:积极(正面)/消极(负面)/中立。 🔍 技术原理简介 情感分析是什么? 情感分析(Sentiment Analysi…...
爱胜品ICSP YPS-1133DN Plus黑白激光打印机报“自动进纸盒进纸失败”处理方法之一
故障现象如下图提示: 用户的爱胜品ICSP YPS-1133DN Plus黑白激光打印机在工作过程中提示自动进纸盒进纸失败并且红色故障灯闪烁; 给出常见故障一般处理建议如下: 当您的爱胜品ICSP YPS-1133DN Plus 黑白激光打印机出现“自动进纸盒进纸失败”…...
数据库索引重建与优化操作在数据库性能维护与数据更新频繁场景下的应用
数据库索引重建与优化操作在数据库性能维护与数据更新频繁场景下的应用 数据库索引的作用与重要性 索引的定义与作用 数据库索引是一种特殊的数据结构,用于加快数据库表的数据检索速度。它类似于书籍的目录,能够快速定位到需要的数据页,而不必…...
前端应用开发技术历程的简要概览
前端应用开发技术详解 一、萌芽期(1990s - 2004) 技术特征 HTML 3.2 / HTML 4.01 是主流版本。 样式用 CSS1/CSS2,但大部分样式写在 <style> 标签甚至行内。 动态效果主要通过 JavaScript 控制 DOM,兼容性极差。 代表事…...
SPOJ 11576 TRIP2 - A Famous King’s Trip 【Tarjan+欧拉回路】
自我吐槽 (哭 题目传送门 SPOJ 洛谷 题目大意 让你在简单无向图上删去2条边,使该图联通并存在欧拉回路 输出字典序最小的一对边 思路 考虑到存在欧拉回路的充要条件,即 i n x ≡ 0 ( m o d 2 ) ∀ i ( 1 ≤ i ≤ n ) in_x\equiv 0 (\m…...
DeepSeek R1:强化学习范式的推理强化模型
定位与目标 DeepSeek R1 的推出并非 DeepSeek V3 的简单迭代,而是一次在训练范式上的大胆探索。与传统大模型主要依靠监督微调(SFT)后进行强化学习不同,R1 将重点放在推理能力和行为对齐上,尝试通过大规模强化学习直接激发模型的推理潜力。其目标是利用强化学习的反馈机制,…...
ubuntu22.04安装显卡驱动与cuda+cuDNN
背景: 紧接前文:Proxmox VE 8.4 显卡直通完整指南:NVIDIA 2080 Ti 实战。在R740服务器完成了proxmox的安装,并且安装了一张2080ti 魔改22g显存的的显卡。配置完了proxmox显卡直通,并将显卡挂载到了vm 301(…...
使用python爬取百度搜索中关于python相关的数据信息
Python爬取百度搜索"Python"相关数据信息 一、准备工作 在开始爬取之前,需要了解以下几点: 百度搜索有反爬机制,需要合理设置请求头百度搜索结果页面结构可能会变化需要遵守robots.txt协议(百度允许爬取搜索结果&…...
Bootstrap(自助法):无需假设分布的统计推断工具
核心思想 Bootstrap 是一种重采样(Resampling)技术,通过在原始数据中有放回地重复抽样,生成大量新样本集,用于估计统计量(如均值、方差)的分布或模型性能的不确定性。 …...
lib和dll介绍和VS2019生成实例
目录 lib文件和dll文件的作用dll和lib的优缺点VS2019 编译YOLOv5的dll和lib lib文件和dll文件的作用 (1)lib是编译时需要的,dll是运行时需要的。 如果要完成源代码的编译,有lib就够了。 如果也使动态连接的程序运行起来,有dll就够了。 在开发…...
tinycudann安装过程加ubuntu18.04gcc版本的升级(成功版!!!!)
使用的是 Linux,安装以下软件包 sudo apt-get install build-essential git安装 CUDA 并将 CUDA 安装添加到您的 PATH。 例如,如果您有 CUDA 12.6.3,请将以下内容添加到您的/usr/local/~/.bashrcexport PATH"/usr/local/cuda-12.6.3/bi…...
数字智慧方案5869丨智慧健康医疗养老大数据整体规划方案(76页PPT)(文末有下载方式)
资料解读:智慧健康医疗养老大数据整体规划方案 详细资料请看本解读文章的最后内容。 随着科技的飞速发展,健康医疗领域正经历着一场深刻的变革。特别是在大数据和人工智能技术的推动下,智慧健康医疗养老的整体规划方案逐渐浮出水面。本文将…...
使用huggingface_hub需要注意的事项
在安装huggingface_hub的时候要注意如果你的python是放在c盘下时记得用管理员模式命令行来安装huggingface_hub,否则安装过程会报错,之后也不会有huggingface-cli命令。 如果安装时因为没有用管理员权限安装而报错了,可以先卸载huggingface-…...
Matplotlib核心课程-2
4.1 数据加载、储存 4.1.1 从数据文件读取数据 导入支持库: import numpy as np from pandas import Series,DataFrame import pandas as pd 从csv文件读取数据,一般方法: pd.read_csv(../data/ex1.csv,encodinggbk) 从csv文件读取数据&#…...
友元函数和友元类
友元 友元是 C 提供的一种 打破封装 的机制,允许 友元函数 或 友元类 访问某个类的 非公有成员(private/protected)。 友元函数 友元函数 可以 直接访问 类的所有 成员,它是 定义在类外部 的 普通函数 ,不属于任何类…...
5.2刷题
P1064 [NOIP 2006 提高组] 金明的预算方案 背包+附属品DP #include<bits/stdc.h> using namespace std; #define int long long int n, m, v, p, q; struct node{int id, v, s, f; }a[100]; int b[32010], dp[32010]; bool cmp(node a, node b){if(a.id b.…...
用VNA进行天线阻抗匹配的实例大图
比如我这天线,在7Mhz时不谐振,我进行匹配 天线的阻抗很高,大约是在500-1400欧,而等效电容电感很小。 所以我考虑使用阻抗变压器降低阻抗。 1。测试天线阻抗,电阻相当高,等效电容很小。 2。通过磁环匹配到…...
普通IT的股票交易成长史--20250502 突破(1)
声明:本文章的内容只是自己学习的总结,不构成投资建议。文中观点基本来自yt站方方土priceaction,综合自己的观点得出。感谢他们的无私分享。 送给自己的话: 仓位就是生命,绝对不能满仓!!&#…...
[预备知识]5. 优化理论(一)
优化理论 梯度下降(Gradient Descent) 数学原理与可视化 梯度下降是优化领域的基石算法,其核心思想是沿负梯度方向迭代更新参数。数学表达式为: θ t 1 θ t − α ∇ θ J ( θ t ) \theta_{t1} \theta_t - \alpha \nabla…...