- JUC(java.util.concurrent)并发包是Java并发编程的核心工具,由Doug Lea设计。它基于volatile和CAS操作实现线程安全,通过AQS框架维护同步状态。文章分析了Lock的获取与释放机制,展示了volatile变量state如何保证可见性和有序性,以及CAS操作如何确保原子性。 JUC(java.util.concurrent)并发包是Java并发编程的核心工具,由Doug Lea设计。它基于volatile和CAS操作实现线程安全,通过AQS框架维护同步状态。文章分析了Lock的获取与释放机制,展示了volatile变量state如何保证可见性和有序性,以及CAS操作如何确保原子性。
- 本文深入比较了 Java 中普通互斥锁与读写锁的核心机制、性能差异及适用场景,提供详细代码示例与 JMH 测试结果,帮助开发者根据读写比例合理选择锁类型,并讲解了锁降级、锁升级、饥饿问题及性能优化策略。 本文深入比较了 Java 中普通互斥锁与读写锁的核心机制、性能差异及适用场景,提供详细代码示例与 JMH 测试结果,帮助开发者根据读写比例合理选择锁类型,并讲解了锁降级、锁升级、饥饿问题及性能优化策略。
- 1 简介本文示例如何实验Python 实现并发任务的两种方式写出对应版本 2 密集IO任务方案:使用 concurrent.futures.ThreadPoolExecutor适合 I/O 密集任务(比如网络请求、文件操作) from concurrent.futures import ThreadPoolExecutor, as_completed def worker(i)... 1 简介本文示例如何实验Python 实现并发任务的两种方式写出对应版本 2 密集IO任务方案:使用 concurrent.futures.ThreadPoolExecutor适合 I/O 密集任务(比如网络请求、文件操作) from concurrent.futures import ThreadPoolExecutor, as_completed def worker(i)...
- 本文介绍了Java并发编程中的管程(Monitor)机制及其实现模型MESA。管程通过入口等待队列和条件变量等待队列解决线程互斥与同步问题,Java的synchronized关键字参考了MESA模型但只支持一个条件变量。文章详细分析了synchronized的实现原理,包括字节码层面的monitorenter/monitorexit指令和性能优化策略(偏向锁、轻量级锁等),并给出使用注意事项 本文介绍了Java并发编程中的管程(Monitor)机制及其实现模型MESA。管程通过入口等待队列和条件变量等待队列解决线程互斥与同步问题,Java的synchronized关键字参考了MESA模型但只支持一个条件变量。文章详细分析了synchronized的实现原理,包括字节码层面的monitorenter/monitorexit指令和性能优化策略(偏向锁、轻量级锁等),并给出使用注意事项
- 本文聚焦灵墟纪元苍梧山脉场景流式加载问题,针对传统方案因预加载策略僵化、资源分块不合理等导致的“地形透明”“内存过载”等问题,提出五大优化方案:动态预加载半径+行为预测、自适应资源分块+优先级排序、内存冷热数据动态置换+池化复用、多核线程池调度+异步资源传输、纹理LOD渐进加载+Mipmap链动态生成。 本文聚焦灵墟纪元苍梧山脉场景流式加载问题,针对传统方案因预加载策略僵化、资源分块不合理等导致的“地形透明”“内存过载”等问题,提出五大优化方案:动态预加载半径+行为预测、自适应资源分块+优先级排序、内存冷热数据动态置换+池化复用、多核线程池调度+异步资源传输、纹理LOD渐进加载+Mipmap链动态生成。
- 本文介绍了Java中synchronized关键字的原理与应用。临界区是多线程环境下需要保护的共享资源访问区域,synchronized通过对象锁机制实现互斥访问。文章详细说明了synchronized两种使用方式(修饰方法和代码块),并通过happens-before规则和内存语义分析其实现原理。synchronized不仅提供互斥访问,还具备类似volatile的内存可见性保障,确保线程间数据 本文介绍了Java中synchronized关键字的原理与应用。临界区是多线程环境下需要保护的共享资源访问区域,synchronized通过对象锁机制实现互斥访问。文章详细说明了synchronized两种使用方式(修饰方法和代码块),并通过happens-before规则和内存语义分析其实现原理。synchronized不仅提供互斥访问,还具备类似volatile的内存可见性保障,确保线程间数据
- 一个线程的一生:从“出生”到“退场”,看鸿蒙任务调度的灵魂设计 一个线程的一生:从“出生”到“退场”,看鸿蒙任务调度的灵魂设计
- 本文探讨并发编程的两种范式:显式同步约束(如Java共享内存模型)和隐式因果传递(如Golang消息传递模型)。Java通过synchronized、volatile等机制实现线程同步,要求开发者显式控制共享资源访问,但带来较大心智负担;Golang则通过Channel实现隐式编排,以通信代替共享。文章将分析两者如何确保内存可见性和数据因果序,展现并发编程哲学的差异。 本文探讨并发编程的两种范式:显式同步约束(如Java共享内存模型)和隐式因果传递(如Golang消息传递模型)。Java通过synchronized、volatile等机制实现线程同步,要求开发者显式控制共享资源访问,但带来较大心智负担;Golang则通过Channel实现隐式编排,以通信代替共享。文章将分析两者如何确保内存可见性和数据因果序,展现并发编程哲学的差异。
- 不是华而不实的选择:鸿蒙为什么执着于“微内核”?作者:Echo_Wish 一、引子:微内核 vs 宏内核,到底谁更香?你有没有发现一个有趣的现象:同样是操作系统,Linux、Windows这些主流系统都用的是宏内核(Monolithic Kernel);而鸿蒙(HarmonyOS),却偏偏反其道而行,选择了**微内核(Microkernel)**路线。不少人吐槽说:“微内核太理想化了吧,性... 不是华而不实的选择:鸿蒙为什么执着于“微内核”?作者:Echo_Wish 一、引子:微内核 vs 宏内核,到底谁更香?你有没有发现一个有趣的现象:同样是操作系统,Linux、Windows这些主流系统都用的是宏内核(Monolithic Kernel);而鸿蒙(HarmonyOS),却偏偏反其道而行,选择了**微内核(Microkernel)**路线。不少人吐槽说:“微内核太理想化了吧,性...
- 一、什么是线程池?核心思想: 线程池是一种基于“池化”思想来管理线程的工具。它预先创建好一定数量的线程,放入一个“池子”中,当有任务需要执行时,就从池子中取出一个空闲线程来执行任务,任务执行完毕后,线程并不被销毁,而是返回池中等待执行下一个任务。为什么需要线程池?在深入原理之前,我们先想想如果不使用线程池,我们如何处理多任务:// 原始方式:为每个任务创建一个新线程for (int i = ... 一、什么是线程池?核心思想: 线程池是一种基于“池化”思想来管理线程的工具。它预先创建好一定数量的线程,放入一个“池子”中,当有任务需要执行时,就从池子中取出一个空闲线程来执行任务,任务执行完毕后,线程并不被销毁,而是返回池中等待执行下一个任务。为什么需要线程池?在深入原理之前,我们先想想如果不使用线程池,我们如何处理多任务:// 原始方式:为每个任务创建一个新线程for (int i = ...
- Quorum机制是分布式系统中实现数据一致性的核心方法,基于鸽巢原理确保读写操作在副本间相遇。通过设定副本数N、写一致性级别W和读一致性级别R三要素,当W+R>N时可保证强一致性。不同NWR组合能优化读写性能或容错性。该机制还可用于Leader选举,通过版本号比较和副本同步确保数据一致性。Quorum机制在分布式系统中平衡了一致性、可用性和容错性需求。 Quorum机制是分布式系统中实现数据一致性的核心方法,基于鸽巢原理确保读写操作在副本间相遇。通过设定副本数N、写一致性级别W和读一致性级别R三要素,当W+R>N时可保证强一致性。不同NWR组合能优化读写性能或容错性。该机制还可用于Leader选举,通过版本号比较和副本同步确保数据一致性。Quorum机制在分布式系统中平衡了一致性、可用性和容错性需求。
- InputDispatcherInputDispatcher 是 Android 输入系统(InputFlinger)的核心组件,负责将输入事件(如触摸、按键)从系统层分发给目标应用窗口。它在 Input ANR(Application Not Responding) 的检测和触发过程中扮演关键角色,主要涉及 事件分发、超时监控、ANR 触发 三个核心机制。 事件分发InputManage... InputDispatcherInputDispatcher 是 Android 输入系统(InputFlinger)的核心组件,负责将输入事件(如触摸、按键)从系统层分发给目标应用窗口。它在 Input ANR(Application Not Responding) 的检测和触发过程中扮演关键角色,主要涉及 事件分发、超时监控、ANR 触发 三个核心机制。 事件分发InputManage...
- 管理Linux服务器就像身兼两职:既是“医生”,又是“城市规划师”。作为“医生”,你得用ps和top给系统“体检”,看看哪些进程在运行;必要时用kill命令做“外科手术”,终止掉问题进程。作为“规划师”,你得先用fdisk把“土地”(磁盘)划分成“地块”(分区),再用mkfs铺上“地基”(文件系统),最后用mount把地块“挂牌”使用。而df和du就是你随时查看“土地”使用情况的测量工具。 管理Linux服务器就像身兼两职:既是“医生”,又是“城市规划师”。作为“医生”,你得用ps和top给系统“体检”,看看哪些进程在运行;必要时用kill命令做“外科手术”,终止掉问题进程。作为“规划师”,你得先用fdisk把“土地”(磁盘)划分成“地块”(分区),再用mkfs铺上“地基”(文件系统),最后用mount把地块“挂牌”使用。而df和du就是你随时查看“土地”使用情况的测量工具。
- 1 简介使用多个返回值的错误处理,本文从设计哲学、语言特性 和 工程实践 三个层面来分析 Golang 的多返回值错误处理机制与 Python3 的异常机制的区别与优势。Golang 的多返回值错误处理机制概述在 Go 中,一个函数常常写成如下形式: func ReadConfig(path string) (Config, error) { // ... if er... 1 简介使用多个返回值的错误处理,本文从设计哲学、语言特性 和 工程实践 三个层面来分析 Golang 的多返回值错误处理机制与 Python3 的异常机制的区别与优势。Golang 的多返回值错误处理机制概述在 Go 中,一个函数常常写成如下形式: func ReadConfig(path string) (Config, error) { // ... if er...
- 人工智能(AI)正以惊人的速度推动着科技的进步,其中,AI操作系统作为支撑AI应用的核心平台,正逐渐成为未来发展的重要方向。本文将介绍“Agent OS”的概念,它是为AI智能体(Agent)量身定制的一种操作系统架构,旨在为多智能体系统提供高效、灵活且智能化的操作环境。 人工智能(AI)正以惊人的速度推动着科技的进步,其中,AI操作系统作为支撑AI应用的核心平台,正逐渐成为未来发展的重要方向。本文将介绍“Agent OS”的概念,它是为AI智能体(Agent)量身定制的一种操作系统架构,旨在为多智能体系统提供高效、灵活且智能化的操作环境。
上滑加载中
推荐直播
-
Skill 构建 × 智能创作:基于华为云码道的 AI 内容生产提效方案2026/03/25 周三 19:00-20:00
余伟,华为云软件研发工程师/万邵业(万少),华为云HCDE开发者专家
本次直播带来两大实战:华为云码道 Skill-Creator 手把手搭建专属知识库 Skill;如何用码道提效 OpenClaw 小说文本,打造从大纲到成稿的 AI 原创小说全链路。技术干货 + OPC创作思路,一次讲透!
回顾中 -
码道新技能,AI 新生产力——从自动视频生成到开源项目解析2026/04/08 周三 19:00-21:00
童得力-华为云开发者生态运营总监/何文强-无人机企业AI提效负责人
本次华为云码道 Skill 实战活动,聚焦两大 AI 开发场景:通过实战教学,带你打造 AI 编程自动生成视频 Skill,并实现对 GitHub 热门开源项目的智能知识抽取,手把手掌握 Skill 开发全流程,用 AI 提升研发效率与内容生产力。
回顾中 -
华为云码道:零代码股票智能决策平台全功能实战2026/04/18 周六 10:00-12:00
秦拳德-中软国际教育卓越研究院研究员、华为云金牌讲师、云原生技术专家
利用Tushare接口获取实时行情数据,采用Transformer算法进行时序预测与涨跌分析,并集成DeepSeek API提供智能解读。同时,项目深度结合华为云CodeArts(码道)的代码智能体能力,实现代码一键推送至云端代码仓库,建立起高效、可协作的团队开发新范式。开发者可快速上手,从零打造功能完整的个股筛选、智能分析与风险管控产品。
回顾中
热门标签