操作系统(1)多线程
在当今计算机科学领域,多线程技术已成为提高程序性能和响应能力的关键手段。无论是高性能计算、Web服务器还是图形用户界面应用程序,多线程都发挥着不可替代的作用。本文将全面介绍操作系统多线程的概念、实现原理、同步机制以及实际应用场景,帮助开发者更好地理解和运用这一重要技术。
一、线程的基本概念
1.1 什么是线程
线程(Thread)是操作系统能够进行运算调度的最小单位,它被包含在进程之中,是进程中的实际运作单位。一个进程可以包含多个线程,这些线程共享进程的资源(如内存空间、文件描述符等),但每个线程拥有自己独立的程序计数器、寄存器集合和栈空间。
与进程相比,线程的创建、切换和销毁开销更小,这使得线程成为实现并发编程的高效工具。
1.2 线程与进程的区别
特性 | 特性 | 线程 |
资源占用 | 独立的内存空间和资源 | 共享进程资源 |
创建开销 | 较大 | 较小 |
切换开销 | 较大 | 较小 |
通信方式 | IPC(管道、消息队列等 | 共享内存 |
独立性 | 独立运行 | 依赖进程存在 |
安全性 | 相互隔离 | 容易相互影响 |
二、多线程的实现方式
2.1 用户级线程(ULT)
用户级线程完全在用户空间实现,内核对此一无所知。线程库(如POSIX的pthread)负责线程的创建、调度和同步。
优点:
- 线程切换无需内核模式切换,速度快
- 可以自定义调度算法
- 可移植性强
缺点:
- 一个线程阻塞会导致整个进程阻塞
- 无法利用多核处理器的并行能力
2.2 内核级线程(KLT)
内核级线程由操作系统内核直接支持,线程管理由内核完成。
优点:
- 一个线程阻塞不会影响其他线程
- 可以充分利用多核处理器
- 内核可以更好地进行调度决策
缺点:
- 线程操作需要系统调用,开销较大
- 可移植性较差
2.3 混合实现
现代操作系统通常采用混合实现方式,如Windows的线程模型和Linux的NPTL(Native POSIX Thread Library)实现。
三、多线程编程模型(java)
3.1 创建线程
public class SimpleThread extends Thread {@Overridepublic void run() {// 线程执行的代码System.out.println("线程正在运行: " + this.getName());}public static void main(String[] args) {SimpleThread thread = new SimpleThread();thread.start(); // 启动线程}
}
3.2 线程同步机制
多线程编程中最关键的挑战是处理共享资源的并发访问问题。以下是常见的同步机制:
3.2.1 互斥锁(Mutex)
import java.util.concurrent.locks.ReentrantLock;public class MutexExample {private static final ReentrantLock lock = new ReentrantLock();private static int sharedCounter = 0;public static void main(String[] args) {Thread t1 = new Thread(MutexExample::incrementCounter);Thread t2 = new Thread(MutexExample::incrementCounter);t1.start();t2.start();try {t1.join();t2.join();} catch (InterruptedException e) {e.printStackTrace();}System.out.println("Final counter value: " + sharedCounter);}private static void incrementCounter() {lock.lock();try {for (int i = 0; i < 1000; i++) {sharedCounter++;}} finally {lock.unlock();}}
}
3.2.2 条件变量(Condition Variable)
import java.util.concurrent.locks.Condition;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;public class ConditionExample {private static final Lock lock = new ReentrantLock();private static final Condition condition = lock.newCondition();private static boolean ready = false;public static void main(String[] args) {Thread waiter = new Thread(() -> {lock.lock();try {System.out.println("等待线程开始等待...");while (!ready) {condition.await();}System.out.println("等待线程被唤醒!");} catch (InterruptedException e) {e.printStackTrace();} finally {lock.unlock();}});Thread notifier = new Thread(() -> {lock.lock();try {Thread.sleep(2000); // 模拟工作ready = true;System.out.println("通知线程发送通知");condition.signal();} catch (InterruptedException e) {e.printStackTrace();} finally {lock.unlock();}});waiter.start();notifier.start();}
}
3.2.3 信号量(Semaphore)
import java.util.concurrent.Semaphore;public class SemaphoreExample {private static final Semaphore semaphore = new Semaphore(3); // 允许3个线程同时访问public static void main(String[] args) {for (int i = 1; i <= 5; i++) {final int threadId = i;new Thread(() -> {try {System.out.println("线程" + threadId + "尝试获取许可");semaphore.acquire();System.out.println("线程" + threadId + "获取了许可");Thread.sleep(2000); // 模拟工作System.out.println("线程" + threadId + "释放许可");semaphore.release();} catch (InterruptedException e) {e.printStackTrace();}}).start();}}
}
3.2.4 读写锁(Read-Write Lock)
import java.util.concurrent.locks.ReadWriteLock;
import java.util.concurrent.locks.ReentrantReadWriteLock;public class ReadWriteLockExample {private static final ReadWriteLock rwLock = new ReentrantReadWriteLock();private static int sharedData = 0;public static void main(String[] args) {// 创建2个读线程for (int i = 1; i <= 2; i++) {final int readerId = i;new Thread(() -> {rwLock.readLock().lock();try {System.out.println("读线程" + readerId + "读取数据: " + sharedData);Thread.sleep(1000);} catch (InterruptedException e) {e.printStackTrace();} finally {rwLock.readLock().unlock();}}).start();}// 创建1个写线程new Thread(() -> {rwLock.writeLock().lock();try {System.out.println("写线程开始写入数据");sharedData++;Thread.sleep(2000);System.out.println("写线程完成写入,新数据: " + sharedData);} catch (InterruptedException e) {e.printStackTrace();} finally {rwLock.writeLock().unlock();}}).start();}
}
四、多线程编程的常见问题
4.1 竞态条件(Race Condition)
当多个线程同时访问共享资源且至少有一个线程进行写操作时,如果没有适当的同步机制,程序的执行结果可能依赖于线程调度的顺序,导致不可预测的行为。
4.2 死锁(Deadlock)
死锁是指两个或多个线程互相等待对方释放资源,导致所有线程都无法继续执行的情况。死锁的四个必要条件:
1. 互斥条件
2. 占有并等待
3. 非抢占条件
4. 循环等待条件
避免死锁的策略包括:
- 按照固定顺序获取锁
- 使用超时机制
- 死锁检测与恢复
4.3 活锁(Livelock)
活锁是指线程虽然没有被阻塞,但由于不断重复相同的操作而无法继续前进的情况。例如,两个线程互相"礼让"资源导致都无法获得资源。
4.4 优先级反转(Priority Inversion)
高优先级线程被低优先级线程阻塞,因为低优先级线程持有了高优先级线程需要的资源,而中间优先级的线程又抢占了低优先级线程的CPU时间。
五、现代多线程编程实践
5.1 线程池
频繁创建和销毁线程开销较大,线程池通过预先创建一组线程并重复使用它们来提高性能。
5.2 无锁编程(Lock-Free Programming)
无锁编程通过原子操作和CAS(Compare-And-Swap)指令实现线程安全,避免了传统锁带来的性能问题和死锁风险。
5.3 协程(Coroutine)
协程是一种更轻量级的并发编程模型,由程序员显式控制协程的切换,避免了线程上下文切换的开销。
六、多线程在不同语言中的实现
6.1 Java多线程
public class Main {public static void main(String[] args) {Thread thread = new Thread(() -> {System.out.println("Hello from thread!");});thread.start();try {thread.join();} catch (InterruptedException e) {e.printStackTrace();}}
}
```
6.2 Python多线程
```python
import threadingdef worker():print("Hello from thread!")thread = threading.Thread(target=worker)
thread.start()
thread.join()
```
注意:由于GIL(全局解释器锁)的存在,Python的线程在CPU密集型任务中无法实现真正的并行。
七、多线程性能优化
7.1 减少锁的争用
- 使用细粒度锁
- 采用读写锁替代互斥锁
- 使用无锁数据结构
- 实现锁分离(如分离读锁和写锁)
7.2 避免虚假共享(False Sharing)
当多个线程频繁访问同一缓存行中的不同变量时,会导致缓存行在CPU核心间频繁无效化,造成性能下降。解决方案包括:
- 对齐关键变量到缓存行大小
- 使用填充(padding)隔离频繁访问的变量
- 将频繁访问的变量分配到不同缓存行
7.3 负载均衡
确保工作均匀分配到各个线程,避免某些线程空闲而其他线程过载的情况。
八、多线程调试与测试
8.1 常见调试工具
- Valgrind (Helgrind/DRD)**:检测线程错误
- GDB:支持多线程调试
- Intel Inspector:线程错误检测工具
- TSAN (ThreadSanitizer):数据竞争检测器
8.2 多线程测试策略
- 压力测试:高并发下长时间运行
- 随机延迟测试:在关键点插入随机延迟
- 确定性测试:控制线程调度顺序
- 静态分析:使用工具分析潜在问题
九、多线程应用场景
9.1 Web服务器
现代Web服务器如Nginx、Apache使用多线程/多进程模型处理并发请求。
9.2 图形用户界面
GUI应用程序通常使用主线程处理界面事件,工作线程执行耗时操作以避免界面冻结。
9.3 科学计算
将大规模计算任务分解为多个子任务并行执行。
9.4 数据库系统
数据库管理系统使用多线程处理并发查询和事务。
十、未来趋势
10.1 异步编程模型
async/await等异步编程模式逐渐流行,提供了更高效的并发处理方式。
10.2 协程与纤程
更轻量级的并发原语,如C++20协程、Go goroutine等。
10.3 异构计算
结合CPU多线程与GPU/FPGA等加速器的异构计算架构。
十一. 结语
多线程编程是提高程序性能的重要手段,但也带来了复杂性和新的挑战。掌握多线程技术需要理解底层原理、熟悉同步机制,并通过实践积累经验。随着计算机硬件向多核方向发展,多线程编程的重要性只会越来越高。希望本文能为您的多线程编程之旅提供有价值的参考。
相关文章:
操作系统(1)多线程
在当今计算机科学领域,多线程技术已成为提高程序性能和响应能力的关键手段。无论是高性能计算、Web服务器还是图形用户界面应用程序,多线程都发挥着不可替代的作用。本文将全面介绍操作系统多线程的概念、实现原理、同步机制以及实际应用场景,…...
系统架构设计师:设计模式——创建型设计模式
一、创建型设计模式 创建型模式抽象了实例化过程,它们帮助一个系统独立于如何创建、组合和表示它的那些对象。一个类创建型模式使用继承改变被实例化的类,而一个对象创建型模式将实例化委托给另一个对象。 随着系统演化得越来越依赖于对象复合而不是类…...
使用Set和Map解题思路
前言 Set和Map这两种数据结构,在解决一些题上,效率很高。跟大家简单分享一些题以及如何使用Set和Map去解决这些题目。 题目链接 136. 只出现一次的数字 - 力扣(LeetCode) 138. 随机链表的复制 - 力扣(LeetCode) 旧…...
Java 算法入门:从基础概念到实战示例
在计算机科学领域,算法如同魔法咒语,能够将无序的数据转化为有价值的信息。对于 Java 开发者而言,掌握算法不仅是提升编程能力的关键,更是解决复杂问题的核心武器。本文将带领你走进 Java 算法的世界,从基础概念入手&a…...
【大模型】图像生成:ESRGAN:增强型超分辨率生成对抗网络的革命性突破
深度解析ESRGAN:增强型超分辨率生成对抗网络的革命性突破 技术演进与架构创新核心改进亮点 环境配置与快速入门硬件要求安装步骤 实战全流程解析1. 单图像超分辨率重建2. 自定义数据集训练3. 视频超分处理 核心技术深度解析1. 残差密集块(RRDB࿰…...
记录搭建自己的应用中心-需求看板搭建
记录搭建自己的应用中心-需求看板搭建 人员管理新增用户组织用户登录和操作看板状态看板任务通知任务详情 人员管理 由于不是所有人都有应用管理权限,所以额外做了一套应用登录权限,做了一个新的组织人员表,一个登录账户下的所有应用人员共享…...
探秘数据结构:构建高效算法的灵魂密码
摘要 数据结构作为计算机科学的基石,其设计与优化直接影响算法效率、资源利用和系统可靠性。本文系统阐述数据结构的基础理论、分类及其核心操作,涵盖数组、链表、栈、队列、树、图、哈希表与堆等经典类型。深入探讨各结构的应用场景与性能对比…...
多节点监测任务分配方法比较与分析
多监测节点任务分配方法是分布式系统、物联网(IoT)、工业监测等领域的核心技术,其核心目标是在资源受限条件下高效分配任务,以优化系统性能。以下从方法分类、对比分析、应用场景选择及挑战等方面进行系统阐述: 图1 多…...
spring-boot-maven-plugin 将spring打包成单个jar的工作原理
spring-boot-maven-plugin 是 Spring Boot 的 Maven 插件,它的核心功能是将 Spring Boot 项目打包成一个独立的、可执行的 Fat JAR(包含所有依赖的 JAR 包)。以下是它的工作原理详解: 1. 默认 Maven 打包 vs Spring Boot 插件打包…...
盐化行业数字化转型规划详细方案(124页PPT)(文末有下载方式)
资料解读:《盐化行业数字化转型规划详细解决方案》 详细资料请看本解读文章的最后内容。 该文档聚焦盐化行业数字化转型,全面阐述了盐化企业信息化建设的规划方案,涵盖战略、架构、实施计划、风险及效益等多个方面,旨在通过数字化…...
开源革命:从技术共享到产业变革——卓伊凡的开源实践与思考-优雅草卓伊凡
开源革命:从技术共享到产业变革——卓伊凡的开源实践与思考-优雅草卓伊凡 一、开源的本质与行业意义 1.1 开源软件的定义与内涵 当卓伊凡被问及”软件开源是什么”时,他给出了一个生动的比喻:”开源就像将食谱公之于众的面包师,…...
解锁 C++26 的未来:从语言标准演进到实战突破
一、C26 的战略定位与开发进展 C26 的开发已进入功能冻结阶段,预计 2026 年正式发布。作为 C 标准委员会三年一迭代的重要版本,其核心改进聚焦于并发与并行性的深度优化,同时在内存管理、元编程等领域实现重大突破。根据 ISO C 委员会主席 H…...
terraform实现本地加密与解密
在 Terraform 中实现本地加密与解密(不依赖云服务),可以通过 OpenSSL 或 GPG 等本地加密工具配合 External Provider 实现。以下是完整的安全实现方案: 一、基础架构设计 # 文件结构 . ├── secrets │ ├── encrypt.sh …...
黄雀在后:外卖大战新变局,淘宝+饿了么开启电商大零售时代
当所有人以为美团和京东的“口水战”硝烟渐散,外卖大战告一段落时,“螳螂捕蝉,黄雀在后”,淘宝闪购联合饿了么“闪现”外卖战场,外卖烽火再度燃起。 4 月30日,淘宝天猫旗下即时零售业务“小时达”正式升级…...
基本功能学习
一.enum枚举使用 E_SENSOR_REQ_NONE 的定义及用途 在传感器驱动开发或者电源管理模块中,E_SENSOR_REQ_NONE通常被用来表示一种特殊的状态或请求模式。这种状态可能用于指示当前没有活动的传感器请求,或者是默认初始化状态下的一种占位符。 可能的定义…...
59常用控件_QComboBox的使用
目录 代码示例:使用下拉框模拟麦当劳点餐 代码示例:从文件中加载下拉框的选项 QComboBox表示下拉框 核心属性 属性说明currentText当前选中的文本currentIndex当前选中的条目下标。 从 0 开始计算。如果当前没有条目被选中,值为 -1editable是否允许修改…...
卡洛诗西餐的文化破圈之路
在餐饮市场的版图上,西餐曾长期被贴上“高端”“舶来品”“纪念日专属”的标签,直到卡洛诗以高性价比西餐的定位破局,将意大利风情与家庭餐桌无缝衔接。这场从异国符号到家常选择的转型,不仅是商业模式的创新,更是一部…...
Python-57:Base32编码和解码问题
问题描述 你需要实现一个 Base32 的编码和解码函数。 相比于 Base32,你可能更熟悉 Base64,Base64 是非常常见的用字符串形式表示二进制数据的方式,在邮件附件、Web 中的图片中都有广泛的应用。 Base32 是 Base64 的变种,与 Bas…...
【排序算法】八大经典排序算法详解
一、直接选择排序(Selection Sort)算法思想算法步骤特性分析 二、堆排序(Heap Sort)算法思想关键步骤特性分析 三、直接插入排序(Insertion Sort)算法思想算法步骤特性分析 四、希尔排序(Shell …...
近端策略优化PPO详解:python从零实现
🧠 向所有学习者致敬! “学习不是装满一桶水,而是点燃一把火。” —— 叶芝 我的博客主页: https://lizheng.blog.csdn.net 🌐 欢迎点击加入AI人工智能社区! 🚀 让我们一起努力,共创…...
C# System.Text.Json终极指南(十):从基础到高性能序列化实战
一、JSON序列化革命:System.Text.Json的架构优势 1.1 核心组件解析 1.2 性能基准测试(.NET 8) 操作Newtonsoft.JsonSystem.Text.Json性能提升简单对象序列化1,200 ns450 ns2.7x大型对象反序列化15 ms5.2 ms2.9x内存分配(1k次操作)45 MB12 MB3.75x二、基础序列化操作精解 …...
Centos7.9 安装mysql5.7
1.配置镜像(7.9的镜像过期了) 2.备份原有的 CentOS 基础源配置文件 sudo cp /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.bak 3.更换为国内镜像源 sudo vi /etc/yum.repos.d/CentOS-Base.repo 将文件内容替换为以下内容&am…...
Qt指南针
Qt写的指南针demo. 运行结果 滑动调整指针角度 实现代码 h文件 #ifndef COMPASS_H #define COMPASS_H#include <QWidget> #include <QColor>class Compass : public QWidget {Q_OBJECT// 可自定义属性Q_PROPERTY(QColor backgroundColor READ backgroundColor WRI…...
杜邦分析法
杜邦分析法(DuPont Analysis)是一种用于分析企业财务状况和经营绩效的综合分析方法,由美国杜邦公司在20世纪20年代率先采用,故得名。以下是其相关内容介绍: 核心指标与分解 净资产收益率(ROE):杜邦分析法的核心指标,反映股东权益的收益水平,用以衡量公司运用自有资本…...
给U盘加上图标
电脑插入U盘后,U盘的那个标志没有特色,我们可以换成有意义的照片作为U盘图标,插上U盘就能看到,多么地浪漫。那该如何设置呢?一起来看看吧 选择一张ICO格式的图片到U盘里 PNG转ICO - 在线转换图标文件PNG转ICO - 免费…...
人工智能对未来工作的影响
人工智能对未来工作的影响是多方面的,既包括对就业结构的改变,也涉及工作方式、职业技能需求以及社会政策的调整。以下是对人工智能对未来工作影响的详细分析: 一、就业结构的变革 岗位替代与消失 人工智能技术在许多领域展现出强大的自动化…...
RocketMQ常见面试题一
1. RocketMQ 是什么?它的核心组件有哪些? 答:RocketMQ 是阿里巴巴开源的一款分布式消息中间件,支持高吞吐、低延迟、高可用的消息发布与订阅。 核心组件: NameServer:轻量级注册中心,管理 Broker 的元数据(路由信息),无状态。 Broker:消息存储和转发节点,分为 Mas…...
C++调试(壹):初步认识WinDbg和dump文件
目录 1.前言 2.WinDbg是什么? 3.WinDbg安装 4.Dump文件是什么? 5.生成Dump文件的场景 前言 这是一个关于C调试的博客,该系列博客主要是讲解如何使用WinDbg工具结合dump文件调试程序。在日常开发过程中,我们往往无法完…...
centos7 离线安装python3 保留python2
一、事前准备: (1)查看centos具体版本 cat /etc/redhat-releaseCentOS Linux release 7.4.1708 (Core) (2)查看linux中当前python版本 centos7 默认安装python2.7.5 (3)查看python3的依赖&#…...
【dify—9】Chatflow实战——博客文章生成器
目录 一、创建Chatflow 二、创建变量 三、添加时间工具 四、编写提示词 五、回复输出 六、运行 第一部分 安装difydocker教程:【difydocker安装教程】-CSDN博客 第二部分 dock重装教程:【dify—2】docker重装-CSDN博客 第三部分 dify拉取镜像&…...
华为OD机试真题——斗地主之顺子(2025A卷:100分)Java/python/JavaScript/C/C++/GO最佳实现
2025 A卷 100分 题型 本专栏内全部题目均提供Java、python、JavaScript、C、C、GO六种语言的最佳实现方式; 并且每种语言均涵盖详细的问题分析、解题思路、代码实现、代码详解、3个测试用例以及综合分析; 本文收录于专栏:《2025华为OD真题目录…...
3.2/Q2,Charls最新文章解读
文章题目:Internet usage elevates elderly obesity: evidence from a difference-in-differences analysis of the broadband China policy DOI:10.1186/s13690-025-01565-9 中文标题:互联网使用导致老年人肥胖:中国宽带政策差异…...
Seata服务端开启事务核心源码解析
文章目录 概述一、doGlobalBegin1.1、createGlobalSession1.2、addSessionLifecycleListener1.3、begin 概述 Seata服务端作为TC角色,用于接收客户端标注了GlobalTransactional也就是TM角色的开启事务,提交/回滚事务请求,维护全局和分支事务的…...
Seata服务端回滚事务核心源码解析
文章目录 前言一、doGlobalRollback3.1、changeGlobalStatus3.2、doGlobalRollback 前言 本篇介绍Seata服务端接收到客户端TM回滚请求,进行处理并且驱动所有的RM进行回滚的源码。 一、doGlobalRollback doGlobalRollback是全局回滚的方法: 首先依旧…...
PMP-第九章 项目资源管理(一)
项目资源管理概述 项目资源管理包括识别、获取和管理所需资源以完成项目的各个过程资源主要分为实物资源和人力资源;实物资源包括设备、材料和基础设施等团队资源或人员指的是人力资源团队资源管理与项目干系人管理有重叠的部分,本章重点关注组成项目团…...
【Unity】MVP框架的使用例子
在提到MVP之前,可以先看看这篇MVC的帖子: 【Unity】MVC的简单分享以及一个在UI中使用的例子 MVC的不足之处: 在MVC的使用中,会发现View层直接调用了Model层的引用,即这两个层之间存在着一定的耦合性,而MV…...
Matlab/Simulink - BLDC直流无刷电机仿真基础教程(四) - PWM调制模拟
Matlab/Simulink - BLDC直流无刷电机仿真基础教程(四) - PWM调制模拟 前言一、PWM调制技术基本原理二、仿真模型中加入PWM调制三、逆变电路MOS管添加体二极管四、模拟添加机械负载五、仿真模型与控制框图文章相关模型文件下载链接参考链接 前言 本系列文…...
x86架构详解:定义、应用及特点
一、x86架构的定义 x86 是由Intel公司开发的复杂指令集(CISC)处理器架构,起源于1978年的Intel 8086处理器,后续扩展至32位(IA-32)和64位(x86-64)。其名称来源于早期处理器型号的“8…...
C++学习-入门到精通-【3】控制语句、赋值、自增和自减运算符
C学习-入门到精通-【3】控制语句、赋值、自增和自减运算符 控制语句、赋值、自增和自减运算符 C学习-入门到精通-【3】控制语句、赋值、自增和自减运算符一、什么是算法二、伪代码三、控制结构顺序结构选择结构if语句if...else语句switch语句 循环结构while语句 四、算法详述&a…...
【Bootstrap V4系列】学习入门教程之 页面内容排版
Bootstrap V4 学习入门教程之 页面内容排版 按钮上的指针排版一、Global settings 全局设置二、Headings 标题2.1 Customizing headings 自定义标题2.2 Display headings 显示标题2.3 Lead 引导 三、Blockquotes 块引用3.1 Naming a source 命名源3.2 Alignment 对齐 四、Lists…...
GTA5(传承/增强) 13980+真车 超跑 大型载具MOD整合包+最新GTA6大型地图MOD 5月最新更新
1500超跑载具 1000普通超跑 1500真车超跑 各种军载具1000 各种普通跑车 船舶 飞机 1000 人物1500 添加式led载具1000 超级英雄最新版 添加添加式武器MOD1000 添加地图MOD500 添加超跑载具2000 当前共计1.2wMOD 4月2日更新 新增770menyoo地图 当前共计12770 新增48款超级英雄最新…...
目标文件的段结构及核心组件详解
目标文件(如 .o 或 .obj)是编译器生成的中间文件,其结构遵循 ELF(Linux)或 COFF(Windows)格式。以下是其核心段(Section)和关键机制的详细解析: 1. 目标文件的…...
60常用控件_QSpinBox的使用
目录 代码示例:调整麦当劳购物车中的份数 使⽤ QSpinBox 或者 QDoubleSpinBox 表⽰ "微调框", 它是带有按钮的输⼊框. 可以⽤来输⼊整 数/浮点数. 通过点击按钮来修改数值⼤⼩. 由于 SpinBox 和 QDoubleSpinBox ⽤法基本相同, 就只介绍 SpinBox 的…...
数据库Mysql_约束
将失败当作自己的老师,即使他会使自己难堪 ----------陳長生. 1.什么是数据库约束 数据库约束是在数据库中对表中的内容设定条件或者规则,设置了这些规则能使得数据更具体有准确性,可靠性。 2.约束类型 NOT NULL设置列不能为空UNIQUE设置列…...
C++笔记-继承(下)(包含派生类的默认成员函数,菱形继承等)
一.派生类的默认成员函数 1.14个常见默认成员函数 默认成员函数,默认的意思就是指我们不写,编译器会自动为我们生成一个,那么在派生类中,这几个成员函数是如何生成的呢? 1.派生类的构造函数必须调用基类的构造函数初…...
DeepSeek V3 训练策略:FP8混合精度与多Token预测
近年来,大规模语言模型取得重大突破,但其训练与部署成本也随之攀升。DeepSeek 系列开源模型致力于通过优化模型结构和训练策略来降低成本、提升性能。DeepSeek V3 融合了多种先进技术(如 FP8 低精度训练、DualPipe 双流水线机制、多Token 预测目标等),在保证模型能力的同时…...
开始一个vue项目
一、创建vite项目和配置 1、查看npm版本: npm --version 根据版本选择创建命令 # npm 6.x npm create vitelatest my-vue-product --template vue # npm 7 npm create vitelatest my-vue-product -- --template vue 2、依次执行: npm install n…...
世纪华通:从财报数据看其在游戏领域的成功与未来
引言 日前,世纪华通发布了2024年及2025年第一季度的财务报告。报告显示,公司不仅在过去一年取得了显著的营收增长,而且在国内外市场均有出色表现。特别是《无尽冬日》和《Whiteout Survival》等游戏的成功,为世纪华通带来了巨大的…...
ruoyi-plus Spring Boot + MyBatis 中 BaseEntity 的设计与动态查询实践
一、BaseEntity 设计解析 以下是一个典型的 BaseEntity 设计示例: @Data public class BaseEntity implements Serializable {@Serialprivate static final long serialVersionUID =...
MCP:智能家居的“大脑”,如何引领未来居住革命
MCP:智能家居的“大脑”,如何引领未来居住革命 一、引言:MCP与智能家居的未来 随着智能家居的迅猛发展,越来越多的家庭开始拥有各种智能设备,从智能灯泡、智能门锁到智能音响,每一个设备都在为生活提供便利与舒适。然而,尽管这些设备各自具备了独立的功能,但它们之间往…...