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

CMake实践:指定gcc版本编译和交叉编译

目录

1.指定gcc版本编译

1.1.通过CMake参数来实现

1.2.使用 RPATH/RUNPATH 直接指定库路径

1.3.使用符号链接和 LD_LIBRARY_PATH

1.4.使用 wrapper 脚本封装 LD_LIBRARY_PATH

2.交叉编译

2.1.基本用法

2.2.工具链文件关键配置

2.3.多平台工具链示例

2.4.注意事项

2.5.相关资源

相关链接


1.指定gcc版本编译

        背景

        现在项目上碰到一种情况,在麒麟V4系统上正在维护的程序是gcc5.4.0编译出来的,现在增加一个需求需要用到了一个第三方库,第三方库编译需要C++20支持,那么就必须升级gcc到gcc9.3.0,安装完gcc9.3.0,因为程序一直是在gcc5.4.0环境下编译的,代码太多,用gcc9.3.0编译怕出问题,又不想改它。于是在相当一段时间,系统中共存gcc5.4.0和gcc9.3.0两个版本,在CMake编译的时候就需要指定gcc版本,下面就来说说实现方案。

1.1.通过CMake参数来实现

1.通过环境变量指定编译器

临时设置 CC 和 CXX 环境变量,仅对当前终端会话有效:

# 设置环境变量指向 GCC 9.3.0
export CC=/usr/bin/gcc-9.3.0
export CXX=/usr/bin/g++-9.3.0# 运行 CMake
cmake -S . -B build
cmake --build build

如果 GCC 9.3.0 的路径不是 /usr/bin/gcc-9.3.0,可以通过以下命令查找:

find /usr -name "gcc-9.3.0" 2>/dev/null  # 查找 GCC 9.3.0
find /usr -name "g++-9.3.0" 2>/dev/null  # 查找 G++ 9.3.0或whichis gcc
whichis g++

2.在 CMake 命令中直接指定

cmake -S . -B build \-DCMAKE_C_COMPILER=/usr/bin/gcc-9.3.0 \-DCMAKE_CXX_COMPILER=/usr/bin/g++-9.3.0cmake --build build

3.使用工具链文件(推荐)

创建一个工具链文件(如 gcc93.toolchain.cmake),集中管理编译器配置:

# gcc93.toolchain.cmake
set(CMAKE_C_COMPILER /usr/bin/gcc-9.3.0)
set(CMAKE_CXX_COMPILER /usr/bin/g++-9.3.0)# 可选:指定 C/C++ 标准
set(CMAKE_C_STANDARD 11)
set(CMAKE_CXX_STANDARD 17)

然后在运行 CMake 时指定该工具链文件:

cmake -S . -B build -DCMAKE_TOOLCHAIN_FILE=/path/to/gcc93.toolchain.cmake
cmake --build build

验证编译器版本

在 CMake 配置过程中,可以通过打印编译器版本来确认是否使用了正确的 GCC:

cd build
cmake -LA | grep "CMAKE_C.*COMPILER"  # 查看 C/C++ 编译器配置

或者在 CMakeLists.txt 中添加以下代码:

message(STATUS "C 编译器: ${CMAKE_C_COMPILER}")
message(STATUS "C++ 编译器: ${CMAKE_CXX_COMPILER}")# 打印编译器版本
execute_process(COMMAND ${CMAKE_C_COMPILER} --versionOUTPUT_VARIABLE gcc_version
)
message(STATUS "GCC 版本: ${gcc_version}")

1.2.使用 RPATH/RUNPATH 直接指定库路径

通过在编译时设置 RPATH 或 RUNPATH,让可执行程序直接从指定路径加载动态库。

示例步骤:

1.创建版本化的库目录

mkdir -p /opt/libfoo/v1 /opt/libfoo/v2
cp libfoo.so.1.0.0 /opt/libfoo/v1/
cp libfoo.so.2.0.0 /opt/libfoo/v2/

2.编译时指定 RPATH

# 程序 A 链接 v1
g++ -o program_a src/a.cpp -L/opt/libfoo/v1 -lfoo \-Wl,-rpath=/opt/libfoo/v1# 程序 B 链接 v2
g++ -o program_b src/b.cpp -L/opt/libfoo/v2 -lfoo \-Wl,-rpath=/opt/libfoo/v2

3.验证链接的库版本

ldd program_a  # 应显示 /opt/libfoo/v1/libfoo.so.1
ldd program_b  # 应显示 /opt/libfoo/v2/libfoo.so.2

1.3.使用符号链接和 LD_LIBRARY_PATH

通过环境变量 LD_LIBRARY_PATH 临时覆盖系统默认库搜索路径。

示例步骤:

1.创建版本化的库目录

mkdir -p ~/libfoo/v1 ~/libfoo/v2
cp libfoo.so.1.0.0 ~/libfoo/v1/
cp libfoo.so.2.0.0 ~/libfoo/v2/# 创建符号链接
cd ~/libfoo/v1 && ln -s libfoo.so.1.0.0 libfoo.so.1
cd ~/libfoo/v2 && ln -s libfoo.so.2.0.0 libfoo.so.2

2.编译程序(不指定 RPATH)

# 程序 A 链接 v1
g++ -o program_a src/a.cpp -L~/libfoo/v1 -lfoo# 程序 B 链接 v2
g++ -o program_b src/b.cpp -L~/libfoo/v2 -lfoo

3.运行时指定库路径

# 运行程序 A(使用 v1)
LD_LIBRARY_PATH=~/libfoo/v1 ./program_a# 运行程序 B(使用 v2)
LD_LIBRARY_PATH=~/libfoo/v2 ./program_b

1.4.使用 wrapper 脚本封装 LD_LIBRARY_PATH

创建脚本包装程序执行,自动设置正确的库路径。

示例步骤:

1.创建 wrapper 脚本

# program_a_wrapper.sh
#!/bin/bash
LD_LIBRARY_PATH=~/libfoo/v1:$LD_LIBRARY_PATH
export LD_LIBRARY_PATH
exec ~/bin/program_a "$@"
# program_b_wrapper.sh
#!/bin/bash
LD_LIBRARY_PATH=~/libfoo/v2:$LD_LIBRARY_PATH
export LD_LIBRARY_PATH
exec ~/bin/program_b "$@"

2.添加执行权限

chmod +x program_a_wrapper.sh program_b_wrapper.sh

1.5.使用符号版本控制(高级)

通过修改库的符号版本信息,让不同版本的符号共存于同一库文件中。

示例步骤:

1.创建版本脚本(libfoo.map)

LIBFOO_1.0 {global:func_v1;local:*;
};LIBFOO_2.0 {global:func_v2;local:*;
} LIBFOO_1.0;

2.编译库时指定版本脚本

# 编译 libfoo.so.2 包含两个版本的符号
g++ -shared -fPIC -o libfoo.so.2.0.0 src/foo.cpp \-Wl,--version-script=libfoo.map

3.程序选择性链接特定版本符号

# 程序 A 链接 v1 符号
g++ -o program_a src/a.cpp -L. -lfoo -Wl,-u,func_v1# 程序 B 链接 v2 符号
g++ -o program_b src/b.cpp -L. -lfoo -Wl,-u,func_v2

2.交叉编译

CMAKE_TOOLCHAIN_FILE 是 CMake 中用于配置交叉编译环境的核心变量。通过指定该变量,可覆盖默认的编译器、工具链和系统搜索路径,实现为不同平台(如嵌入式设备、移动平台)构建软件。

2.1.基本用法

1.定义工具链文件

创建一个 .cmake 文件(如 arm_toolchain.cmake),内容示例:

# 指定目标系统
set(CMAKE_SYSTEM_NAME Linux)
set(CMAKE_SYSTEM_PROCESSOR arm)# 指定交叉编译工具
set(CMAKE_C_COMPILER arm-linux-gnueabihf-gcc)
set(CMAKE_CXX_COMPILER arm-linux-gnueabihf-g++)
set(CMAKE_AR arm-linux-gnueabihf-ar)
set(CMAKE_RANLIB arm-linux-gnueabihf-ranlib)# 指定系统根目录(可选)
set(CMAKE_SYSROOT /path/to/arm-sysroot)# 仅搜索 sysroot 中的文件(避免主机系统污染)
set(CMAKE_FIND_ROOT_PATH_MODE_PROGRAM NEVER)
set(CMAKE_FIND_ROOT_PATH_MODE_LIBRARY ONLY)
set(CMAKE_FIND_ROOT_PATH_MODE_INCLUDE ONLY)
set(CMAKE_FIND_ROOT_PATH_MODE_PACKAGE ONLY)

2.调用 CMake 时指定工具链文件

cmake -S . -B build -DCMAKE_TOOLCHAIN_FILE=path/to/arm_toolchain.cmake

2.2.工具链文件关键配置

1.必选配置项

变量名描述
CMAKE_SYSTEM_NAME目标系统名称(如 LinuxWindowsDarwin
CMAKE_SYSTEM_PROCESSOR目标处理器架构(如 armaarch64x86_64
CMAKE_C_COMPILERC 编译器路径
CMAKE_CXX_COMPILERC++ 编译器路径

2.可选配置项

变量名描述
CMAKE_SYSROOT目标系统根目录(包含 includelib 等目录)
CMAKE_FIND_ROOT_PATH自定义搜索路径(覆盖 CMAKE_SYSROOT
CMAKE_AR/CMAKE_RANLIB归档工具和索引工具(用于静态库)
CMAKE_STRIPstrip 工具(用于去除调试信息)
CMAKE_EXE_LINKER_FLAGS链接器选项(如 -static

2.3.多平台工具链示例

1.ARM 嵌入式 Linux 工具链

set(CMAKE_SYSTEM_NAME Linux)
set(CMAKE_SYSTEM_PROCESSOR arm)# 编译器路径(根据实际工具链调整)
set(CMAKE_C_COMPILER /opt/gcc-arm-none-eabi/bin/arm-none-eabi-gcc)
set(CMAKE_CXX_COMPILER /opt/gcc-arm-none-eabi/bin/arm-none-eabi-g++)# 不使用系统库(裸机开发)
set(CMAKE_TRY_COMPILE_TARGET_TYPE STATIC_LIBRARY)

2.Android NDK 工具链

set(CMAKE_SYSTEM_NAME Android)
set(CMAKE_SYSTEM_VERSION 21)  # API 级别
set(CMAKE_ANDROID_ARCH_ABI arm64-v8a)  # 架构# 指定 NDK 路径
set(CMAKE_ANDROID_NDK /path/to/android-ndk)# 使用 NDK 自带的 CMake 工具链
set(CMAKE_TOOLCHAIN_FILE ${CMAKE_ANDROID_NDK}/build/cmake/android.toolchain.cmake)

3.Windows 交叉编译(从 Linux 到 Windows)

set(CMAKE_SYSTEM_NAME Windows)
set(CMAKE_SYSTEM_PROCESSOR x86_64)# 使用 mingw-w64 工具链
set(CMAKE_C_COMPILER x86_64-w64-mingw32-gcc)
set(CMAKE_CXX_COMPILER x86_64-w64-mingw32-g++)
set(CMAKE_RC_COMPILER x86_64-w64-mingw32-windres)  # Windows 资源编译器# 生成 .exe 后缀
set(CMAKE_EXECUTABLE_SUFFIX .exe)

2.4.注意事项

1.集中管理工具链文件

将工具链文件放在项目根目录的 cmake/toolchains/ 目录下,便于版本控制。

2.使用环境变量简化调用

export MY_ARM_TOOLCHAIN=/path/to/arm_toolchain.cmake
cmake -S . -B build -DCMAKE_TOOLCHAIN_FILE=$MY_ARM_TOOLCHAIN

3.工具链文件可继承

复杂项目可创建基础工具链文件,再通过 include() 包含特定平台的配置。

4.测试工具链有效性

使用 try_compile() 在工具链文件中验证编译环境是否正常:

try_compile(COMPILER_WORKS ${CMAKE_BINARY_DIR}/test_compileSOURCES ${CMAKE_CURRENT_LIST_DIR}/test.cOUTPUT_VARIABLE COMPILE_OUTPUT)if(NOT COMPILER_WORKS)message(FATAL_ERROR "编译测试失败: ${COMPILE_OUTPUT}")
endif()

2.5.相关资源

  • CMake 官方工具链文档
    cmake-toolchains(7) — CMake 4.0.3 Documentation

  • Android NDK 工具链示例
    https://developer.android.com/ndk/guides/cmake

  • 跨平台工具链集合
    https://github.com/leetal/ios-cmake(iOS 交叉编译)
    https://github.com/lebedevRI/cmake-toolchains(各种平台工具链)

相关链接

  • CMake 官网 CMake - Upgrade Your Software Build System
  • CMake 官方文档:CMake Tutorial — CMake 4.0.3 Documentation
  • CMake 源码:https://github.com/Kitware/CMake
  • CMake 源码:CMake · GitLab
  • 中文版基础介绍:  CMake 入门实战 | HaHack
  • wiki:  Home · Wiki · CMake / Community · GitLab
  • Modern CMake 简体中文版: Introduction · Modern CMake

相关文章:

CMake实践:指定gcc版本编译和交叉编译

目录 1.指定gcc版本编译 1.1.通过CMake参数来实现 1.2.使用 RPATH/RUNPATH 直接指定库路径 1.3.使用符号链接和 LD_LIBRARY_PATH 1.4.使用 wrapper 脚本封装 LD_LIBRARY_PATH 2.交叉编译 2.1.基本用法 2.2.工具链文件关键配置 2.3.多平台工具链示例 2.4.注意事项 2.…...

【MySQL基础】MySQL内置函数全面解析:提升你的数据库操作效率

MySQL学习: https://blog.csdn.net/2301_80220607/category_12971838.html?spm1001.2014.3001.5482 前言: MySQL提供了丰富的内置函数来帮助开发者高效地处理数据。这些函数覆盖了字符串操作、数值计算、日期时间处理、流程控制等多个方面。本文将全面…...

OpenCV CUDA模块设备层-----在GPU上计算两个uchar1类型像素值的反正切(arctangent)比值函数atan2()

操作系统:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 编程语言:C11 算法描述 对输入的两个 uchar1 像素值 a 和 b,先分别归一化到 [0.0, 1.0] 浮点区间,然后计算它们的 四象限反正切函数。 函数原型…...

unity 半透明描线shader

效果如图 Shader "Custom/TransparentWithOutline_Fixed" {Properties{// 主材质属性_Color ("Main Color", Color) (1,1,1,1)_MainTex ("Base (RGB) Trans (A)", 2D) "white" {}_Glossiness ("Smoothness", Range(0,1)…...

react中使用antd的form表单去受控switch时初始值没有正确显示

解决方案 antd内api中有valuePropName熟悉 只需正常绑定当前元素触发事件即可...

01__QT的背景介绍和工程创建

一、QT软件的安装 1、qt的背景介绍 Qt 是一个跨平台的 图形界面库(重量级),1994年由罗威troll tech公司出品,它集成了网络、数据库、串口通信协议(RS232,蓝牙,NFC)、打印、PDF生成…...

Java Map 深度解析

一、HashMap 底层实现详解 1. 核心数据结构 HashMap 在 JDK 8 中的底层结构是 数组 链表 红黑树&#xff0c;其核心成员变量包括&#xff1a; transient Node<K,V>[] table;&#xff1a;哈希桶数组transient int size;&#xff1a;实际键值对数量int threshold;&…...

异地组网工具

目前手头上两台服务器&#xff08;一台主力&#xff0c;一台有gpu用来跑点深度学习任务&#xff09;&#xff0c;两台pc&#xff08;一台是主力&#xff0c;一台是便携碎片化时间随时赶工用&#xff09;&#xff1b; 之前组网的时候&#xff0c;用zerotiertailscale&#xff0…...

我们为什么要模拟

大约 25 年前&#xff0c;当我开始从事高速 PCB 设计时&#xff0c;速度很慢&#xff0c;层数少&#xff0c;介电常数和损耗角正切很高&#xff0c;设计裕量很宽&#xff0c;铜粗糙度无关紧要&#xff0c;玻璃编织样式也无关紧要。我们称电介质为“FR-4”&#xff0c;它们的特性…...

MySQL 三大日志:Redo、Undo 与 Binlog 详解

写在前面 关于三大日志&#xff0c;博主看了无数视频和文章&#xff0c;也是总结的非常精辟了&#xff01; 在 MySQL 数据库的运行机制中&#xff0c;Redo Log、Undo Log 和 Binlog 起着至关重要的作用&#xff0c;它们各司其职&#xff0c;共同保障数据库的数据安全、事务一…...

JMeter-SSE响应数据自动化3.0

背景 此次因为多了一些需要过滤排除的错误(数量很少)&#xff0c;还需要修改下JMeter的jtl文件输出数据&#xff08;后续统计数据需要&#xff09; 所以只涉及到JSR脚本的一些改动(此部分改动并不会影响到JMeter的HTML报告) 改动 主要通过设置JMeter中prev输出数据变量threadN…...

C#上位机通过WebApi访问WinCC

在智能工厂架构中&#xff0c;WinCC作为SCADA一级&#xff0c;负责着与上级MES和下级PLC及其他现场组件的联系。与下层通信&#xff0c;WinCC支持S7、MC、Modbus TCP、OPC等多种接口和协议。对上层通信&#xff0c;WinCC从7.5 SP2开始支持REST Api这种Web接口方式。 今天跟大家…...

【深度学习新浪潮】什么是端侧AI?

什么是端侧AI? 端侧AI的定义 端侧AI(Edge AI)是指在终端设备(如手机、智能家居、穿戴设备等)本地运行的人工智能技术,无需将数据上传至云端服务器,直接在设备端完成数据处理、模型推理和决策。其核心优势在于低延迟、高隐私性、减少网络依赖,尤其适合对实时性和数据安…...

Postman 的 Jenkins 管理 - 自动构建

目录 一、环境准备 创建 Postman 集合和环境 二、postman Postman 集合和环境并导出 1. 打开已完成并测试无误的 postman 项目脚本。 再次执行测试。 ​编辑​2. 导出&#xff08; 测试用例集、环境变量 两个文件&#xff09;**“不 支 持 中 文”** —— 全部改成英文&a…...

HomeBrew MAC PRO 安装教程

1、检查xcode工具 这个东西一般是有的&#xff0c;命令后输入以下内容即可 xcode-select --install如安装&#xff0c;结果为&#xff1a; 2、安装HomeBrew 方式1&#xff08;推荐&#xff09; /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebr…...

多模态大语言模型arxiv论文略读(129)

Task Success Prediction for Open-Vocabulary Manipulation Based on Multi-Level Aligned Representations ➡️ 论文标题&#xff1a;Task Success Prediction for Open-Vocabulary Manipulation Based on Multi-Level Aligned Representations ➡️ 论文作者&#xff1a;M…...

Android 实现 Toast 显示重叠问题,有效提升用户体验

Android 实现 Toast 显示重叠问题 在 Android 开发中&#xff0c;Toast 是一个非常常用的提示工具&#xff0c;能够为用户提供短暂的信息展示。然而&#xff0c;Toast 的默认实现中&#xff0c;存在一个体验上的问题&#xff0c;当多次触发 Toast 显示时&#xff0c;会导致多个…...

Spring Boot + MyBatis + Vue:构建高效全栈应用的实战指南

一、项目需求分析 假设我们需要开发一个简单的任务管理系统&#xff0c;用户可以通过该系统创建、查看和删除任务。以下是项目的基本需求&#xff1a; 用户管理&#xff1a;用户可以注册和登录系统。 任务管理&#xff1a;用户可以创建、查看和删除任务。 数据持久化&#x…...

语音情感识别:CNN-LSTM 和注意力增强 CNN-LSTM 模型的比较分析

摘要: 语音情感识别 &#xff08;SER&#xff09; 技术可帮助计算机理解语音中的人类情感&#xff0c;这在推进人机交互和心理健康诊断方面占据了关键地位。本研究的主要目标是通过创新的深度学习模型提高 SER 的准确性和泛化性。尽管它在人机交互和心理健康诊断等各个领域都很…...

Cursor Pro取消500次请求限制,无限用的体验更好了吗?

目录 前言 一、发生了什么&#xff1f;从"限量"到"无限"的升级 1.1 "顶配" Ultra 套餐的登场 1.2 Pro 套餐的"静默升级" 1.3 新旧方案对比 二、"无限"背后的体验&#xff1a;一个开发者的真实感受 三、Cursor 为何要…...

视频汇聚EasyCVR平台v3.7.2发布:新增全局搜索、播放器默认解码方式等4大功能

EasyCVR视频汇聚平台带着全新的v3.7.2版本重磅登场&#xff01;此次升级&#xff0c;绝非简单的功能堆砌&#xff0c;而是从用户体验、操作效率以及系统性能等多维度进行的深度优化与革新&#xff0c;旨在为大家带来更加强大、稳定且高效的视频监控管理体验。 一、全局功能搜索…...

2025年AI热潮:开发一款聚合AI系统,包含AI对话、视频、数字人、办公、客服、剪辑为一体的ai智能系统有多强

前言&#xff0c;我们了解了网上比较火的ai平台&#xff0c;比如&#xff1a; 抖音豆包AI、百度AI、阿里巴巴AI、腾讯AI、华为AI、DeepSeek、ChatGPT、文心一言、通义千问 一、系统概述 本聚合AI系统是一个集AI对话、图片生成、视频生成、视频剪辑、数字人创作、音乐制作、办公…...

DeepSeek 助力 Vue3 开发:打造丝滑的日历(Calendar),日历_项目里程碑示例(CalendarView01_22)

前言&#xff1a;哈喽&#xff0c;大家好&#xff0c;今天给大家分享一篇文章&#xff01;并提供具体代码帮助大家深入理解&#xff0c;彻底掌握&#xff01;创作不易&#xff0c;如果能帮助到大家或者给大家一些灵感和启发&#xff0c;欢迎收藏关注哦 &#x1f495; 目录 Deep…...

AWS数据库迁移实战:本地MySQL零停机上云方案

一、迁移场景 本地环境&#xff1a;自建MySQL 5.7&#xff08;数据量500GB&#xff09;&#xff0c;业务要求迁移停机时间<5分钟 目标架构&#xff1a; 二、迁移四步法 步骤1&#xff1a;环境准备&#xff08;耗时30分钟&#xff09; 1.1 创建Aurora MySQL # AWS CLI创…...

windows汇编

今天发现一个很好的视频&#xff0c;讲windows汇编/调试等。是个老太太讲的&#xff0c;但是讲的真好。 Create/Assemble/Link x64 Windows asm exe, Debugging Tools for Windows (WinDbg), stack shadow store. 照例边看边记录边实验。 1. install visual studio 2. instal…...

用 python 开发一个可调用工具的 AI Agent,实现电脑配置专业评价

在人工智能时代&#xff0c;AI Agent凭借其强大的任务处理能力&#xff0c;逐渐成为开发人员手中的得力工具。今天&#xff0c;我们就来一起动手&#xff0c;用Python打造一个能够调用工具的AI Agent&#xff0c;实现根据电脑信息对电脑配置进行专业评价的功能。 一、项目创建…...

Java自定义线程池(ThreadPoolExecutor)

Java线程池使用示例 下面将展示如何使用自定义线程池(ThreadPoolExecutor)来执行任务&#xff0c;包括提交Runnable任务、Callable任务&#xff0c;处理拒绝策略以及关闭线程池。 import java.util.concurrent.*;public class ThreadPoolDemo {// 自定义线程工厂&#xff08;…...

386. 字典序排数

386. 字典序排数 理解题目要求 题目要求我们生成从 1 到 n 的整数的字典序排列&#xff0c;并且要求&#xff1a; ​时间复杂度 O(n)​​&#xff1a;不能使用直接排序&#xff08;通常指的是使用标准的排序算法&#xff08;如快速排序、归并排序、堆排序等&#xff09;对数…...

Kaggle-Plant Seedlings Classification-(多分类+CNN+图形处理)

Plant Seedlings Classification 题意&#xff1a; 就是给出很多图片&#xff0c;预测出图片中的小草是什么类型的。 数据处理&#xff1a; 1.去除图片背景&#xff0c;只保留物体。 2.图片数据加强。 建立模型&#xff1a; 1.CNN的Sequential()&#xff0c;多层卷积块和…...

Android 应用多语言与系统语言偏好设置指南

文章目录 创建语言包以中文包为例 以系统为主导的“应用语言偏好设置”从你的应用调到“应用语言偏好设置” 创建语言包 我们可以使用一个很蹩脚的办法来实现&#xff1a; 以中文包为例 values是默认values-zh-rCN是简体中文values-zh-rTW是繁体&#xff08;台湾省&#xff…...

Excel学习01

Excel是微软公司开发的一款电子表格软件&#xff0c;可以广泛应用于数据处理、统计分析、图表制作、财务管理和自动化办公领域等。Excel在实际工作中使用的非常广泛&#xff0c;为此本次开始针对excel的使用进行一系列讲解。 展示使用的软件是WPS&#xff0c;它和excel的使用方…...

Loggers 配置解析(log4j.xml)

Loggers 配置解析 我们通过下面的例子来理解 log4j 的 Loggers 配置是如何决定日志输出规则的。 <Loggers><!-- 根Logger&#xff1a;全局配置 --><Root level"debug"><AppenderRef ref"consoleAppender" level"info"/&g…...

Matplotlib 绘图库使用技巧介绍

目录 前言 Matplotlib 简介 快速入门 图形结构解剖 常用绘图函数 子图与布局 单行多列子图&#xff1a; 网格布局&#xff1a; 自定义位置&#xff1a; 样式与标注 中文字体与科学计数 图例、网格、坐标轴 动态图与动画 三维绘图 常见问题与技巧 前言 Matplotli…...

服务器如何从http升级到https(nginx)

1.证书申请 可以到阿里云或者华为云去申请证书&#xff0c;申请完下载证书是个压缩包&#xff0c;然后解压 可以到到几个文件夹&#xff0c;找到 .Nginx 文件夹打开 会有两个文件&#xff0c;将这两个文件上传至nginx/conf/cert文件夹下&#xff08;cert需要手…...

解决戴尔电脑No bootable devices found问题

解决戴尔电脑No bootable devices found问题 一、调整BIOS设置 1、在关机状态下&#xff0c;打开计算机电源&#xff0c;在出现 Dell 徽标时按 F2 键以引导至 BIOS 设置菜单。 2、选择 Boot sequence&#xff08;引导顺序 &#xff09;并将选项从 Legacy&#xff08;传统 &…...

FPGA基础 -- Verilog 行为级建模之条件语句

Verilog 的行为级建模&#xff08;Behavioral Modeling&#xff09;中的条件语句&#xff08;Conditional Statements&#xff09;&#xff0c;逐步从基础到实际工程应用&#xff0c;适合有RTL开发基础但希望深入行为建模的人。 一、行为级建模简介 行为级建模&#xff08;Beh…...

最大公约数

题目描述 输入两个正整数a,b,求a,b的最大公约数。 输入 输入正整数a和b,中间用空格隔开 输出 输出最大公约数 样例输入 144 84样例输出 12程序分析 &#xff1a;运用辗转相除法&#xff08;欧几里得算法&#xff09; 用较大数除以较小数&#xff0c;取余数&#xff1b…...

springboot入门之路(一)

文章目录 1.Spring Boot介绍2.开发你的第一个Spring Boot应用2.1创建POM2.2yml和properties的配置区别yml配置properties配置 2.3springbootDemo代码2.4创建一个可执行jar 参考文档&#xff1a;SpringBoot参考指南&#xff1b;SpringBoot实战 1.Spring Boot介绍 Spring Boot使…...

vue | vue 插件化机制,全局注册 和 局部注册

组件插件化&#xff1a;提升组件的可复用性、扩展性和独立性 组件插件化实现方式 ├── 注册机制 │ ├── 全局注册&#xff08;app.use&#xff09;→ install, 循环注册, 配置项 │ └── 局部注册&#xff08;import components&#xff09; │ ├── 插件化能力…...

技术与情感交织的一生 (八)

目录 融合 东西厂公 接风宴 头痛 “巴巴罗萨” 突击 推进 助攻 96小时 寒冬 食堂 反攻 消耗 Delphi 西厂 内困 外患 “敦刻尔克” 多线作战 大撤退 资源 融合 东西厂公 初次来到纸箱厂&#xff0c;是主厂区&#xff0c;感觉很大&#xff0c;相对西面正在…...

基于python的web系统界面登录

#让我们的电脑可以支持服务访问 #需要一个web框架 #pip install Flask from flask import Flask, render_template,request from random import randint app Flask(__name__) app.route(/index) def index():uname request.args.get("uname")return f"主页&am…...

利用Java进行验证码的实现——算数验证码

我主要使用使用 Java Swing 库创建一个 GUI 窗口&#xff0c;然后在窗口中显示生成的算术验证码图片&#xff0c;并提供一个文本框和一个按钮&#xff0c;输入验证码并验证显示结果。 代码如下&#xff1a; package calculate; import javax.swing.*; import java.awt.*; imp…...

OpenStack入门体验

1.1云计算概述 相信大家都听到很多的阿里云、腾讯云、百度云等等这些词,那到底什么是云计算?云 计算又能做什么? 1.1.1什么是云计算 云计算(cloud computing)是一种基于网络的超级计算模式,基于用户的不同需求,提供所需的资源,包括计算资源、存储资源、网络资源等。云计算…...

实时中值滤波 + 低通滤波 示例程序(STM32环境)

一、功能概述 本示例实现两个滤波器&#xff1a; 中值滤波器&#xff08;Median Filter&#xff09;&#xff1a;对短期异常值&#xff08;如尖峰噪声&#xff09;有良好的抑制能力&#xff1b;低通滤波器&#xff08;Low-Pass Filter&#xff09;&#xff1a;对数据进行平滑…...

AppBarLayout+ CoordinatorLayout,ViewPager2为什么不会覆盖AppBarLayout

<?xml version"1.0" encoding"utf-8"?> <layout xmlns:android"http://schemas.android.com/apk/res/android"xmlns:app"http://schemas.android.com/apk/res-auto"xmlns:tools"http://schemas.android.com/tools&quo…...

C语言——枚举

目录 一、枚举的基本概念 1. 定义与语法 2. 枚举变量的声明 二、枚举的特性 1. 整型常量的本质 2. 作用域规则 3. 内存占用 三、枚举的使用场景 1. 替代宏定义常量 2. 状态机实现 3. 函数返回值类型 四、枚举与其他类型的对比 五、高级技巧与注意事项 1. 位掩码枚…...

148. 排序链表

题目&#xff1a; 给你链表的头结点 head &#xff0c;请将其按 升序 排列并返回 排序后的链表 。 示例1&#xff1a; 解题思路&#xff1a; 这道题是一道综合题&#xff0c;考察了链表中间节点合并有序链表。首先我们链表中间节点&#xff0c;然后从中间结点的前一个节点处断…...

26.【.NET8 实战--孢子记账--从单体到微服务--转向微服务】--单体转微服务--角色权限管理

在现代企业级应用中&#xff0c;角色权限管理是保障系统安全和提升用户体验的核心基础功能。一个高效的角色权限系统不仅能够有效防止越权访问&#xff0c;还能简化系统的维护和扩展。本文将系统性介绍角色权限管理的核心实现思路&#xff0c;包括架构设计、性能优化、安全机制…...

flowable查询最新定义的流程梳理

背景。使用ruoyi-flowable-plus进行二次开发。将项目与流程绑定后查询相关流程表单时发现问题。于是梳理逻辑汇总了下面的思维导图和相关代码。查询逻辑。流程定义Key 最流程新版本(orderByProcessDefinitionVersion) 取第一条流程实例 最新的一条版本记录。这里一定要用流程…...

kafka消费的模式及消息积压处理方案

目录 1、kafka消费的流程 2、kafka的消费模式 2.1、点对点模式 2.2、发布-订阅模式 3、consumer消息积压 3.1、处理方案 3.2、积压量 4、消息过期失效 5、kafka注意事项 Kafka消费积压(Consumer Lag)是指消费者处理消息的速度跟不上生产者发送消息的速度&#xff0c;导致消息在…...