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

并发学习之synchronized,JVM内存图,线程基础知识

文章目录

  • Java内存图
    • 内存图区域介绍
    • 执行流程
  • 进程和线程
    • 概念解释
    • 线程的6种状态
    • 简述等待队列和同步队列(阻塞队列)
    • 线程之间是独立的
  • synchronized
    • 静态方法
    • 非静态方法
    • 代码块

知识总结:

  • 方法区存储类信息
  • 正在执行的程序叫进程,进程会开辟内存空间
  • 程序的执行过程 :线程
  • 线程的执行-----》方法的入栈出栈
  • Java创建线程-----》Java创建一个又一个栈

Java内存图

Java内存的主要组成部分:

  • 虚拟机栈
  • 堆区
  • 方法区
  • 本地方法栈
  • 程序计数器

在这里插入图片描述

内存图区域介绍

  1. 虚拟机栈:每个线程都会有自己的虚拟机栈,是线程私有的区域。
    • 虚拟机栈主要用于存储栈帧,每个方法被调用时都会创建一个表栈帧。栈帧包含方法的局部变量,操作数栈和其他等。
      • 操作数栈:主要用于 方法执行过程中的数据计算和临时存储。它的行为类似于传统CPU的 运算寄存器,但采用 栈结构(LIFO) 来存储和操作数据。
  2. **堆:**堆是一个线程共享区域,是Java内存管理的核心区域。
    • 通过new关键字创建的对象实例和数组都存储在堆中。
  3. 方法区:方法区是一个线程共享区域,主要用于存储类的相关信息,比如类的字段,方法的定义,常量等。
    • 常量池:常量池位于方法区中,用于存放编译期生成的各种字面量和符号引用。
      • 字面量:指的是在源代码中直接给出的数据值,比如直接写在源代码中的数字,字符串,字符,布尔值等。他们是常量的直观表达方式,在编译阶段就会确定下来。例如:在int num = 10;10为整形字面量。在String str = "hello"中,“hello”为字符串字面量。
      • 符号引用:符号引用是一种间接引用,它在编译时用于表示类、方法、字段等在常量池中的引用。符号引用主要包括类和接口的全限定名、字段的名称和描述符、方法的名称和描述符等信息。这些信息在编译阶段被存储在常量池中,用于在运行时解析和定位实际的类、方法和字段等实体。(符号引用是在编译阶段放到常量池的。)
  4. **本地方法栈:**是线程的私有区域,主要为Native方法(使用非Java语言编写的方法,如C/C++)提供服务,用于存储Native方法的调用栈信息,支持Java程序对Native的调用。
  5. **程序计数器:**每个线程都有一个程序计数器,是线程的私有区域。主要用于存储线程正在执行的字节码指令的地址,使得线程能够按照正确的顺序执行字节码指令,当线程执行Java方法时,程序计数器记录当前执行的字节码地址;执行Native方法时,程序计数器的值为undefined。

执行流程

  1. 编译:.java 到.class 的过程叫编译 。在这个过程中,Java 编译器(如 javac 命令 )对.java 源文件进行词法分析、语法分析、语义分析等操作,将符合 Java 语法规则的代码转换为字节码形式的.class 文件。字节码是一种与平台无关的中间代码,可被 Java 虚拟机(JVM)识别并执行,从而实现 “一次编写,到处运行” 的特性 。

  2. **类加载:**Java 虚拟机(JVM)将.class 字节码文件加载到内存中,此过程由类加载器完成。

    • 加载时会检查字节码文件的格式等是否正确,然后在方法区创建对应的类模板,存放类的结构信息,比如字段、方法等。例如 Demo.class 会被加载,其类信息放入方法区。
  3. 连接

    • 验证:确保被加载的类字节码文件符合 JVM 规范,比如文件格式、语义等方面的校验,保障程序运行安全。
    • 准备:为类的静态变量分配内存并设置默认初始值,如静态变量 static int num; 此时会被赋予默认值 0 。
    • 解析:将常量池中的符号引用转换为直接引用,使 JVM 能直接定位到类、方法、字段等实体。
  4. 初始化

    对类的静态变量赋予程序员设定的初始值,执行静态代码块。若有多个静态变量和静态代码块,按代码中出现的顺序执行初始化操作。

  5. 执行

    • 程序从 main 方法开始执行,在虚拟机栈中为 main 方法创建栈帧。栈帧里存放局部变量、操作数栈等信息。执行过程中,遇到对象创建指令,会在堆中分配内存创建对象。比如执行到 new 关键字时,就在堆中开辟空间构建对象实例。
    • 当调用其他方法时,为被调用方法创建新栈帧并压入虚拟机栈,方法执行完,对应栈帧弹出,返回上一层调用方法继续执行。

进程和线程

概念解释

  1. 进程:进程是正在执行的程序的实例。
    • 进程是资源分配的基本单位。
    • 不同进程之间内存隔离(一个进程崩溃通常不会影响其他进程)。
    • 启动一个Java程序时,JVM就是一个进程。
  2. 线程:线程是进程内的执行单元,负责执行程序代码。一个进程可以包含多个线程,所有线程共享进程的内存空间(如堆、方法区),但每个线程有自己的栈。
    • Java创建一个线程就是在虚拟机栈中创建一个又一个栈。
    • 线程是CPU调度的基本单位。
    • 线程共享进程资源,但有自己的程序计数器、栈和局部变量。
  3. 线程的执行 → 方法的入栈出栈
    • 栈(Stack):每个线程拥有独立的栈,用于存储方法调用的上下文(局部变量、方法参数、返回地址等)。
    • 入栈(Push):调用方法时,JVM会创建一个栈帧(Stack Frame)并入栈。
    • 出栈(Pop):方法执行完毕后,栈帧被弹出,控制权返回给调用者。

线程的6种状态

  1. 新建

    • 描述:线程创建但未被启动。

    • 触发条件

      Thread thread = new Thread(); // 此时状态为 NEW(新建)
      
  2. 可运行/就绪

    • 线程已启动,正在 JVM 中执行或等待 CPU 调度。

    • 包含两种情况

      • Ready:等待操作系统分配 CPU 时间片。
      • Running:正在执行。
    • 触发条件

      thread.start(); // 进入 RUNNABLE 状态
      
  3. BLOCKED(阻塞)

    • 描述:线程因竞争 同步锁 被阻塞(如 synchronized)。是被动的。
    • 触发条件
      • 线程尝试获取一个已被其他线程持有的锁。
  4. WAITING(无限等待)

    • 描述:线程主动进入等待状态,直到被其他线程显式唤醒。
    • 触发方法
      • Object.wait()(未指定超时)
      • Thread.join()(未指定超时)
      • LockSupport.park()
  5. TIMED_WAITING(超时等待)

    • 描述:线程主动进入限时等待状态,超时后自动唤醒。
    • 超时后进入就绪态
    • 触发方法
      • Thread.sleep(long millis)
      • Object.wait(long timeout)
      • Thread.join(long millis)
      • LockSupport.parkNanos()
  6. TERMINATED(终止)

    • 描述:线程执行完毕或异常退出。
    • 触发条件
      • run() 方法执行结束。
      • 线程抛出未捕获异常。

简述等待队列和同步队列(阻塞队列)

特性等待队列(Wait Queue)同步队列(Sync Queue)
触发条件调用 Object.wait()竞争锁失败(如 synchronizedlock.lock()
是否释放锁wait() 会释放锁)(线程仍持有竞争资格)
唤醒机制notify()/notifyAll()锁释放后自动唤醒队头线程
典型应用生产者-消费者模型ReentrantLocksynchronized

线程之间是独立的

在这里插入图片描述

  • 线程之间是相互独立的,main,t1,t2相互独立,结果会立马输出0,不会管t1,t2线程的任务是否执行完
  • 输出结果为0
  • 加上t1.join()和t2.join()方法,就会等待t1,t2线程执行完毕再输出,结果将不再是0。由于两个线程之间会相互覆盖,最终结果也会小于2000000。

synchronized

  • 加在静态方法上:锁定的是类
  • 加在非静态方法:锁定的是方法的调用者,当前实例。
  • 修饰代码块:锁定的是传入的对象

静态方法

public class Test {public static void main(String[] args) {Thread thread = new Thread(new Runnable() {@Overridepublic void run() {SyncTest.test();}});Thread thread1 = new Thread(new Runnable() {@Overridepublic void run() {SyncTest.test();}});thread.start();thread1.start();}
}
public class SyncTest {public static void test(){System.out.println("进入静态方法锁"+Thread.currentThread().getName());//模拟耗时操作try {Thread.sleep(2000);} catch (InterruptedException e) {throw new RuntimeException(e);}System.out.println("静态方法锁结束"+Thread.currentThread().getName());}
}

结果(执行顺序不定):

在这里插入图片描述

非静态方法

两个线程操作不同实例时不会阻塞,操作同一实例时会阻塞。

下面这个例子Thread-2必须等待Thread-0释放锁。

public class Test {public static void main(String[] args) {SyncTest syncTest1 = new SyncTest();SyncTest syncTest2 = new SyncTest();Thread thread = new Thread(new Runnable() {@Overridepublic void run() {syncTest1.test1();}});Thread thread1 = new Thread(new Runnable() {@Overridepublic void run() {syncTest2.test1();}});Thread  thread2 = new Thread(new Runnable() {@Overridepublic void run() {syncTest1.test1();}});thread.start();thread1.start();thread2.start();}
}
public synchronized void test1()
{System.out.println("进入同步方法锁"+Thread.currentThread().getName());//模拟耗时操作try {Thread.sleep(2000);} catch (InterruptedException e) {throw new RuntimeException(e);}System.out.println("同步方法锁结束"+Thread.currentThread().getName());
}
输出:
进入同步方法锁Thread-0
进入同步方法锁Thread-1
同步方法锁结束Thread-1
同步方法锁结束Thread-0
进入同步方法锁Thread-2
同步方法锁结束Thread-2

代码块

锁的是传入的对象,两个线程使用不同锁对象时不会阻塞,使用相同锁对象时会阻塞。

下面这个例子Thread-2必须等待Thread-0释放锁。

public class SyncTest {private final Object lock1 = new Object();private final Object lock2 = new Object();public void customLock1() {synchronized (lock1) {System.out.println(Thread.currentThread().getName() + " 进入 lock1 代码块");try {Thread.sleep(2000);} catch (InterruptedException e) {e.printStackTrace();}System.out.println(Thread.currentThread().getName() + " 离开 lock1 代码块");}}public void customLock2() {synchronized (lock2) {System.out.println(Thread.currentThread().getName() + " 进入 lock2 代码块");try {Thread.sleep(2000);} catch (InterruptedException e) {e.printStackTrace();}System.out.println(Thread.currentThread().getName() + " 离开 lock2 代码块");}}}public class Test {public static void main(String[] args) {SyncTest instance  = new SyncTest();Thread thread = new Thread(new Runnable() {@Overridepublic void run() {instance.customLock1();}});Thread thread1 = new Thread(new Runnable() {@Overridepublic void run() {instance.customLock2();}});Thread  thread2 = new Thread(new Runnable() {@Overridepublic void run() {//锁住的是同一个对象,会阻塞instance.customLock1();}});thread.start();thread1.start();thread2.start();}
}
输出:
Thread-1 进入 lock2 代码块
Thread-0 进入 lock1 代码块
Thread-0 离开 lock1 代码块
Thread-1 离开 lock2 代码块
Thread-2 进入 lock1 代码块
Thread-2 离开 lock1 代码块

相关文章:

并发学习之synchronized,JVM内存图,线程基础知识

文章目录 Java内存图内存图区域介绍执行流程 进程和线程概念解释线程的6种状态简述等待队列和同步队列(阻塞队列)线程之间是独立的 synchronized静态方法非静态方法代码块 知识总结: 方法区存储类信息正在执行的程序叫进程,进程会…...

使用Docker部署Nacos

sudo systemctl start docker sudo systemctl enable docker docker --version 步骤 2: 拉取 Nacos Docker 镜像 拉取 Nacos 镜像: 你可以从 Docker Hub 上拉取官方的 Nacos 镜像,使用以下命令: docker pull nacos/nacos-server 这会从 …...

如何 naive UI n-data-table 改变行移动光标背景色

默认是light 灰&#xff0c;想换个显眼包色&#xff0c;折腾半天&#xff0c;可以了。 无废话上代码&#xff1a; <template><n-data-tablesize"small":columns"columns":data"sortedDataList":bordered"true":row-key"…...

Maven 插件扩展点与自定义生命周期

&#x1f9d1; 博主简介&#xff1a;CSDN博客专家&#xff0c;历代文学网&#xff08;PC端可以访问&#xff1a;https://literature.sinhy.com/#/?__c1000&#xff0c;移动端可微信小程序搜索“历代文学”&#xff09;总架构师&#xff0c;15年工作经验&#xff0c;精通Java编…...

Redis的发布订阅模型是什么,有哪些缺点?

Redis 发布订阅模型概述 Redis 发布订阅&#xff08;Pub/Sub&#xff09;是一种消息广播模式&#xff0c;核心角色包括&#xff1a; 发布者&#xff08;Publisher&#xff09;&#xff1a;向指定频道&#xff08;Channel&#xff09;发送消息。频道&#xff08;Channel&#…...

【EDA软件】【联合Modelsim仿真使用方法】

背景 业界EDA工具仿真功能是必备的&#xff0c;例如Vivado自带仿真工具&#xff0c;且无需联合外部仿真工具&#xff0c;例如MoodelSim。 FUXI工具仿真功能需要联合Modelsim&#xff0c;才能实现仿真功能。 方法一&#xff1a;FUXI联合ModelSim 1 添加testbench文件 新建to…...

C语言_动态内存管理

1. 为什么存在动态内存分配 ? 当前&#xff0c;我们掌握的内存开辟方式有&#xff1a; int val22;// 在栈空间上开辟四个字节 char arr[10]{0};// 在栈空间上开辟10个字节的连续空间而上述的开辟空间的方式有两个特点&#xff1a; 空间开辟大小示固定的数组在申明的时候&am…...

使用Langfuse和RAGAS,搭建高可靠RAG应用

大家好&#xff0c;在人工智能领域&#xff0c;RAG系统融合了检索方法与生成式AI模型&#xff0c;相比纯大语言模型&#xff0c;提升了准确性、减少幻觉且更具可审计性。不过&#xff0c;在实际应用中&#xff0c;当建好RAG系统投入使用时&#xff0c;如何判断接收信息是否正确…...

MySQL 数据库优化:ShardingSphere 原理及实践

在高并发、大数据量的业务场景下,MySQL 作为关系型数据库的核心存储引擎,其性能和扩展性面临严峻挑战。ShardingSphere 作为 Apache 顶级开源项目,提供了分布式数据库解决方案,通过分库分表、读写分离、弹性迁移等能力,帮助开发者实现 MySQL 的水平扩展与性能优化。 本文…...

【Redis】零碎知识点(易忘 / 易错)总结回顾

一、Redis 是一种基于键值对&#xff08;key-value&#xff09;的 NoSQL 数据库 二、Redis 会将所有数据都存放在内存中&#xff0c;所以它的读写性能非常惊人 Redis 还可以将内存的数据利用快照和日志的形式保存到硬盘上&#xff0c;这样在发生类似断电或者机器故障时&#xf…...

谷歌浏览器(Google Chrome)136.0.7103.93便携增强版|Win中文|安装教程

软件下载 【名称】&#xff1a;谷歌浏览器&#xff08;Google Chrome&#xff09;136.0.7103.93 【大小】&#xff1a;170M 【语言】&#xff1a;简体中文 【安装环境】&#xff1a;Win10/Win11 【夸克网盘下载链接】&#xff08;务必手机注册&#xff09;&#xff1a; h…...

【滑动窗口】LeetCode 209题解 | 长度最小的子数组

长度最小的子数组 前言&#xff1a;滑动窗口一、题目链接二、题目三、算法原理解法一&#xff1a;暴力枚举解法二&#xff1a;利用单调性&#xff0c;用滑动窗口解决问题那么怎么用滑动窗口解决问题&#xff1f;分析滑动窗口的时间复杂度 四、编写代码 前言&#xff1a;滑动窗口…...

WebXR教学 07 项目5 贪吃蛇小游戏

WebXR教学 07 项目5 贪吃蛇小游戏 index.html <!DOCTYPE html> <html> <head><title>3D贪吃蛇小游戏</title><style>body { margin: 0; }canvas { display: block; }#score {position: absolute;top: 20px;left: 20px;color: white;font-…...

2.1.3

# Load the data file_path finance数据集.csv data pd.__________(file_path) --- data pd.read_csv(file_path) # 识别数值列用于箱线图 numeric_cols data.select_dtypes(include[float64, int64]).__________ --- numeric_cols data.select_dtypes(include[flo…...

StreamCap v0.0.1 直播录制工具 支持批量录制和直播监控

—————【下 载 地 址】——————— 【​本章下载一】&#xff1a;https://drive.uc.cn/s/2fa520a8880d4 【​本章下载二】&#xff1a;https://pan.xunlei.com/s/VOQDt_3v0DYPxrql5y2zxgO1A1?pwd2kqi# 【百款黑科技】&#xff1a;https://ucnygalh6wle.feishu.cn/wiki/…...

小蜗牛拨号助手用户使用手册

一、软件简介 小蜗牛拨号助手是一款便捷实用的拨号辅助工具&#xff0c;能自动识别剪贴板中的电话号码&#xff0c;支持快速拨号操作。最小化或关闭窗口后&#xff0c;程序将在系统后台运行&#xff0c;还可设置开机自启&#xff0c;方便随时使用&#xff0c;提升拨号效率。 …...

​哈夫曼树(Huffman Tree)

​​1. 基本概念​ 哈夫曼树&#xff08;Huffman Tree&#xff09;&#xff0c;又称最优二叉树&#xff0c;是一种带权路径长度&#xff08;WPL, Weighted Path Length&#xff09;最短的二叉树。它主要用于数据压缩和编码优化&#xff0c;通过为不同权值的节点分配不同长度的…...

布隆过滤器和布谷鸟过滤器

原文链接&#xff1a;布隆过滤器和布谷鸟过滤器 布隆过滤器 介绍 布隆过滤器&#xff08;Bloom Filter&#xff09;是 1970 年由布隆提出的。它实际上是一个很长的二进制向量和一系列随机映射函数&#xff0c;检查值是“可能在集合中”还是“绝对不在集合中” 空间效率高&a…...

Vue+Vite学习笔记

Cesium与Vue集成&#xff1a;详解Cesium-Vue项目搭建与运行步骤指南 - 云原生实践 为什么按照这篇↑完成三步会有能打开的网址&#xff0c;不止localhost8080还有用127.0.0.1那个表示的。 用这个构建&#xff0c;出来的是localhost:5173&#xff1f;...

UE 材质基础 第一天

课程&#xff1a;虚幻引擎【UE5】材质宝典【初学者材质基础入门系列】-北冥没有鱼啊_-稍后再看-哔哩哔哩视频 随便记录一些 黑色是0到负无穷&#xff0c;白色是1到无穷 各向异性 有点类似于高光&#xff0c;可以配合切线来使用&#xff0c;R G B 相当于 X Y Z轴&#xff0c;切…...

网络编程中的直接内存与零拷贝

本篇文章会介绍 JDK 与 Linux 网络编程中的直接内存与零拷贝的相关知识&#xff0c;最后还会介绍一下 Linux 系统与 JDK 对网络通信的实现。 1、直接内存 所有的网络通信和应用程序中&#xff08;任何语言&#xff09;&#xff0c;每个 TCP Socket 的内核中都有一个发送缓冲区…...

语音转文字

语音转文字工具大全 1. 网易 网易见外&#xff08;网页&#xff09; 地址&#xff1a;网易见外 - AI智能语音转写听翻平台 特点&#xff1a;完全免费&#xff0c;支持音频转文字&#xff0c;每日上限2小时 有道云笔记&#xff08;安卓&#xff0f;iOS&#xff09; 地址&a…...

软件设计师考试《综合知识》创建型设计模式考点分析

软件设计师考试《综合知识》创建型设计模式考点分析 1. 分值占比与考察趋势&#xff08;75分制&#xff09; 模式名称近5年题量分值占比高频考察点最新趋势抽象工厂模式45.33%产品族创建/跨平台应用结合微服务配置考查(2023)工厂方法模式56.67%单一产品扩展/日志系统与IoC容器…...

【八股战神篇】Java集合高频面试题

专栏简介 八股战神篇专栏是基于各平台共上千篇面经&#xff0c;上万道面试题&#xff0c;进行综合排序提炼出排序前百的高频面试题&#xff0c;并对这些高频八股进行关联分析&#xff0c;将每个高频面试题可能进行延伸的题目再次进行排序选出高频延伸八股题。面试官都是以点破…...

STM32F103定时器1每毫秒中断一次

定时器溢出中断&#xff0c;在程序设计中经常用到。在使用TIM1和TIM8溢出中断时&#xff0c;需要注意“TIM_TimeBaseStructure.TIM_RepetitionCounter0;”&#xff0c;它表示溢出一次&#xff0c;并可以设置中断标志位。 TIM1_Interrupt_Initializtion(1000,72); //当arr1…...

BC 范式与 4NF

接下来我们详细解释 BC 范式&#xff08;Boyce-Codd范式&#xff0c;简称 BCNF&#xff09;&#xff0c;并通过具体例子说明其定义和应用。 一、BC范式的定义 BC范式&#xff08;Boyce-Codd范式&#xff0c;BCNF&#xff09;是数据库规范化理论中的一种范式&#xff0c;它比第…...

Data whale LLM universe

使用LLM API开发应用 基本概念 Prompt Prompt 最初指的是自然语言处理研究人员为下游任务设计的一种任务专属的输入模板。 Temperature 使用Temperature参数控制LLM生成结果的随机性和创造性&#xff0c;一般取值设置在0~1之间&#xff0c;当取值接近1的时候预测的随机性较…...

数据结构第七章(四)-B树和B+树

数据结构第七章&#xff08;四&#xff09; B树和B树一、B树1.B树2.B树的高度 二、B树的插入删除1.插入2.删除 三、B树1.B树2.B树的查找3.B树和B树的区别 总结 B树和B树 还记得我们的二叉排序树BST吗&#xff1f;比如就是下面这个&#xff1a; 结构体也就关键字和左右指针&…...

如何利用 Python 获取京东商品 SKU 信息接口详细说明

在电商领域&#xff0c;SKU&#xff08;Stock Keeping Unit&#xff0c;库存进出计量的基本单元&#xff09;信息是商品管理的核心数据之一。它不仅包含了商品的规格、价格、库存等关键信息&#xff0c;还直接影响到库存管理、价格策略和市场分析等多个方面。京东作为国内知名的…...

【机器学习】第二章模型的评估与选择

A.关键概念 2.1 经验误差和过拟合 经验误差与泛化误差&#xff1a;学习器在训练集上的误差为经验误差&#xff0c;在新样本上的误差为泛化误差 过拟合&#xff1a;学习器训练过度后&#xff0c;把训练样本自身的一些特点当作所有潜在样本具有一般性质&#xff0c;使得泛化性能…...

[PMIC]PMIC重要知识点总结

PMIC重要知识点总结 摘要&#xff1a;PMIC (Power Management Integrated Circuit) 是现代电子设备中至关重要的组件&#xff0c;负责电源管理&#xff0c;包括电压调节、电源转换、电池管理和功耗优化等。PMIC 中的数字部分主要涉及控制逻辑、状态机、寄存器配置、通信接口&am…...

LVGL- Calendar 日历控件

1 日历控件 1.1 日历背景 lv_calendar 是 LVGL&#xff08;Light and Versatile Graphics Library&#xff09;提供的标准 GUI 控件之一&#xff0c;用于显示日历视图。它支持用户查看某年某月的完整日历&#xff0c;还可以实现点击日期、标记日期、导航月份等操作。这个控件…...

ubuntu安装google chrome

更新系统 sudo apt update安装依赖 sudo apt install curl software-properties-common apt-transport-https ca-certificates -y导入 GPG key curl -fSsL https://dl.google.com/linux/linux_signing_key.pub | gpg --dearmor | sudo tee /usr/share/keyrings/google-chrom…...

如何开发专业小模型

在专业领域场景下&#xff0c;通过针对性优化大模型的词汇表、分词器和模型结构&#xff0c;确实可以实现参数规模的显著缩减而不损失专业能力。这种优化思路与嵌入式设备的字库剪裁有相似性&#xff0c;但需要结合大模型的特性进行系统性设计。以下从技术可行性、实现方法和潜…...

EXO 可以将 Mac M4 和 Mac Air 连接起来,并通过 Ollama 运行 DeepSeek 模型

EXO 可以将 Mac M4 和 Mac Air 连接起来&#xff0c;并通过 Ollama 运行 DeepSeek 模型。以下是具体实现方法&#xff1a; 1. EXO 的分布式计算能力 EXO 是一个支持 分布式 AI 计算 的开源框架&#xff0c;能够将多台 Mac 设备&#xff08;如 M4 和 Mac Air&#xff09;组合成…...

Git Worktree 使用

新入职了一家公司&#xff0c;发现不同项目用的使用一个 git 仓库管理。不久之后我看到这篇文章。 Git 的设计部​​分是为了支持实验。一旦你确定你的工作被安全地跟踪&#xff0c;并且存在安全的状态&#xff0c;以便在出现严重错误时可以恢复&#xff0c;你就不会害怕尝试新…...

【Linux网络】内网穿透

内网穿透 基本概念 内网穿透&#xff08;Port Forwarding/NAT穿透&#xff09; 是一种网络技术&#xff0c;主要用于解决处于 内网&#xff08;局域网&#xff09;中的设备无法直接被公网访问 的问题。 1. 核心原理 内网与公网的隔离&#xff1a;家庭、企业等局域网内的设备…...

反射机制动态解析

代码解释与注释 package com.xie.javase.reflect;import java.lang.reflect.Field; import java.lang.reflect.Modifier;public class ReflectTest01 {public static void main(String[] args) throws ClassNotFoundException {// 1. 获取java.util.HashMap类的Class对象Class…...

10 分钟打造一款超级马里奥小游戏,重拾20 年前的乐趣

我正在参加CodeBuddy「首席试玩官」内容创作大赛&#xff0c;本文所使用的 CodeBuddy 免费下载链接&#xff1a;腾讯云代码助手 CodeBuddy - AI 时代的智能编程伙伴 你好&#xff0c;我是悟空。 前言 小时候看到村里的大朋友家里都有一款 FC 游戏机&#xff0c;然后旁边还放…...

鸿蒙ArkUI体验:Hexo博客客户端开发心得

最近部门也在跟进鸿蒙平台的业务开发&#xff0c;自己主要是做 Android 开发&#xff0c;主要使用 Kotlin/Java 语言。&#xff0c;需要对新的开发平台和开发模式进行学习&#xff0c;在业余时间开了个项目练手&#xff0c;做了个基于 Hexo 博客内容开发的App。鸿蒙主要使用Ark…...

人工智能100问☞第25问:什么是循环神经网络(RNN)?

目录 一、通俗解释 二、专业解析 三、权威参考 循环神经网络(RNN)是一种通过“记忆”序列中历史信息来处理时序数据的神经网络,可捕捉前后数据的关联性,擅长处理语言、语音等序列化任务。 一、通俗解释 想象你在和朋友聊天,每说一句话都会根据之前的对话内容调整语气…...

【springcloud学习(dalston.sr1)】Zuul路由访问映射规则配置及使用(含源代码)(十二)

该系列项目整体介绍及源代码请参照前面写的一篇文章【springcloud学习(dalston.sr1)】项目整体介绍&#xff08;含源代码&#xff09;&#xff08;一&#xff09; springcloud学习&#xff08;dalston.sr1&#xff09;系统文章汇总如下&#xff1a; 【springcloud学习(dalston…...

STM32IIC协议基础及Cube配置

STM32IIC协议基础及Cube配置 一&#xff0c;IC协议简介1&#xff0c;核心特点2&#xff0c;应用场景 二&#xff0c;IC协议基础概念1&#xff0c;总线结构2&#xff0c;主从架构3&#xff0c;设备寻址4&#xff0c;起始和停止条件5&#xff0c;数据传输6&#xff0c;应答机制 三…...

Python异常模块和包

异常 当检测到一个错误时&#xff0c;Python解释器就无法继续执行了&#xff0c;反而出现了一些错误的提示&#xff0c;这就是所谓的“异常”, 也就是我们常说的BUG 例如&#xff1a;以r方式打开一个不存在的文件。 f open(‘python1.txt’,‘r’,encoding‘utf-8’) 当我们…...

每日算法刷题Day9 5.17:leetcode定长滑动窗口3道题,用时1h

9. 1652.拆炸弹(简单&#xff0c;学习) 1652. 拆炸弹 - 力扣&#xff08;LeetCode&#xff09; 思想 为了获得正确的密码&#xff0c;你需要替换掉每一个数字。所有数字会 同时 被替换。 如果 k > 0 &#xff0c;将第 i 个数字用 接下来 k 个数字之和替换。如果 k < 0…...

题单:递归求和

宣布一个重要的事情&#xff0c;我的洛谷有个号叫 题目描述 给一个数组 a:a[0],a[1],...,a[n−1]a:a[0],a[1],...,a[n−1] 请用递归的方式出数组的所有数之和。 提示&#xff1a;递推方程 f(x)f(x−1)a[x]f(x)f(x−1)a[x]; 输入格式 第一行一个正整数 n (n≤100)n (n≤100)…...

手动实现 Transformer 模型

本文使用 Pytorch 库手动实现了传统 Transformer 模型中的多头自注意力机制、残差连接和层归一化、前馈层、编码器、解码器等子模块&#xff0c;进而实现了对 Transformer 模型的构建。 """ Title: 解析 Transformer Time: 2025/5/10 Author: Michael Jie &quo…...

【鸿蒙开发避坑】使用全局状态变量控制动画时,动画异常甚至动画方向与预期相反的原因分析以及解决方案

【鸿蒙开发避坑】使用全局状态变量控制动画&#xff0c;动画异常甚至动画方向相反的原因分析以及解决方案 一、问题复现1、问题描述2、问题示意图 二、原因深度解析1、查看文档2、调试3、原因总结&#xff1a;&#xff08;1&#xff09;第一次进入播放页面功能一切正常的原因&a…...

天拓四方锂电池卷绕机 PLC 物联网解决方案

近年来&#xff0c;锂电制造行业作为新能源领域的核心支柱产业&#xff0c;呈现出迅猛发展的态势&#xff0c;市场需求持续高涨。在此背景下&#xff0c;行业内对产品质量、生产效率以及成本控制等方面提出了更为严苛的要求。锂电制造流程涵盖混料、涂布、辊压、分切、制片、卷…...

RFID系统:技术解析与应用全景

一、技术架构与运行逻辑 RFID&#xff08;Radio Frequency Identification&#xff09;系统通过无线电波实现非接触式数据交互&#xff0c;其核心由三部分组成&#xff1a; 电子标签&#xff08;Tag&#xff09;&#xff1a; 无源标签&#xff1a;依赖读写器电磁场供电&…...