类字节码:揭开Java虚拟机运行机制的神秘面纱
概述 计算机是不能直接运行java代码的,必须要先运行java虚拟机,再由java虚拟机运行编译后的java代码。 因为在cpu层面看来计算机中所有的操作都是一个个指令的运行汇集而成的,java是高级语言,只有人类才能理解其逻辑,计算机是无法识别的,所以java代码必须要先编译成字节码文件,jvm才 ...
第一批被龙虾气到的人出现了
引言 我朋友,一个脾气温和、情绪稳定的成年人,今天,在电脑前憋出了他今年第一句字正腔圆的国骂。 对象不是甲方,不是队友,而是一个AI——确切说,是一个花了他不少钱、号称能当“私人数字助理”的玩意儿,花名龙虾。 事情得从头说起。那天下午,他喜气洋洋地跟我显摆,说也养了个龙虾,能自动整理AI资讯,能给它 ...
从业务开发视角聊聊可观测体系建设
本文探讨了分布式架构下可观测体系的建设实践,提出了基于业务视角的可观测体系建设框架:明确业务核心边界、建立指标体系(业务指标+SLO指标)、构建多维度观测(业务观测、链路观测、异常观测、变更观测)和固化排障路径,以游戏中心项目为例,介绍了项目在问题发现与问题定位上的实践,有效提升了问题发现与故障处理... ...
NIO的零拷贝如何实现高效数据传输?
Java NIO零拷贝 在 Java NIO 中的通道(Channel)就相当于操作系统的内核空间(kernel space)的缓冲区,而缓冲区(Buffer)对应的相当于操作系统的用户空间(user space)中的用户缓冲区(user buffer)。 通道(Channel)是全双工的(双向传输 ...
Java 实现企业微信扫码登录
一、场景 Web 系统登录页面“企业微信”图标,点击后调取企业微信扫码登录页面,扫码成功后判断系统账号与企业微信用户ID绑定情况,有则直接登录,无则跳转到绑定登录页面,用户手动输入个人账号密码进行绑定,首次绑定后后续无需再绑定。 二、企业微信应用相关配置 1、新建企微应用 进入企微管理后台,应用管理 ...
NIO:解开非阻塞I/O高并发编程的秘密
流与块 Standard IO是对字节流的读写,在进行IO之前,首先创建一个流对象,流对象进行读写操作都是按字节 ,一个字节一个字节的来读或写。而NIO把IO抽象成块,类似磁盘的读写,每次IO操作的单位都是一个块,块被读入内存之后就是一个byte[],NIO一次可以读或写多个字节。 I/O 与 NI ...
剑指offer-81、⼆叉搜索树的最近公共祖先
题⽬描述 给定⼀个⼆叉搜索树, 找到该树中两个指定节点的最近公共祖先。 对于该题的最近的公共祖先定义:对于有根树T的两个结点p 、q ,最近公共祖先LCA(T,p,q)表示⼀个结点x ,满⾜x 是p 和q 的祖先且x 的深度尽可能⼤。在这⾥,⼀个节点也可以是它⾃⼰的祖先. ⼆叉搜索树是若它的左⼦树不 ...
BIO详解:解锁阻塞IO的使用方式
关于同步/异步,阻塞/非阻塞,Unix IO模型,可以先看这篇文章网络系统 - Unix IO模型 BIO概述 阻塞式IO。也就是说io没有就绪的时候,操作IO当前线程会被阻塞。也就是用户线程需要等待IO线程完成 服务器实现模式为一个连接一个线程,也就是说,客户端每当有一个连接请求的时候,服务器就需 ...
PipelinR:在Java中实现优雅的CQRS架构
使用中介者模式轻松实现命令查询职责分离,构建高内聚、低耦合的应用系统 一、知识点回顾 1. 什么是CQRS? CQRS是Command Query Responsibility Segregation的缩写,一般称作命令查询职责分离。从字面意思理解,就是将命令(写入)和查询(读取)的责任划分到不同的 ...
剑指offer-80、⼆叉树中和为某⼀值的路径(二)
题⽬描述 给定⼀个⼆叉树root和⼀个整数值 sum ,求该树有多少路径的的节点值之和等于 sum 。 该题路径定义不需要从根节点开始,也不需要在叶⼦节点结束,但是⼀定是从⽗亲节点往下到孩⼦节点 总节点数⽬为 n 保证最后返回的路径个数在整形范围内 假如⼆叉树 root 为 {1,2,3,4,5,4 ...
springboot~jpa优雅的软删除能力
之前写过关于springboot~jpa优雅的处理isDelete的默认值的文章,今天说一下在jpa或者其它类型的Repository中实现软删除的方法,主要借助了自定义的仓储的能力。 优雅的引用方式 /** * 开启软删除的能力 * * @author lind * @date 2025/9/8 ...
剑指offer-79、最⻓不含重复字符的⼦字符串
题目描述 请从字符串中找出⼀个最⻓的不包含重复字符的⼦字符串,计算该最⻓⼦字符串的⻓度。 数据范围: ⻓度⼩于40000 示例1 输⼊:"abcabcbb" 返回值:3 说明:因为⽆重复字符的最⻓⼦串是"abc",所以其⻓度为 3。 示例2 输⼊:"bbbbb" 返回值:1 说明:因为⽆重复字符的最 ...
虚拟线程深度解析:轻量并发编程的未来趋势
这是Java19新增的预览版功能,到Java21正式可以使用 简介 虚拟线程是一种用户态下的线程,类似go语言中的goroutines 和Erlang中的processes,虚拟线程并非比线程快,而是提高了应用的吞吐量,相比于传统的线程是由操作系统调度来看,虚拟线程是我们自己程序调度的线程。如果你对 ...
解密synchronized:从对象头到内存屏障,搞懂Java锁的底层原理
解密synchronized:从对象头到内存屏障,搞懂Java锁的底层原理 一、引言 在 Java 并发编程的领域中,多线程环境下的数据一致性和线程安全是至关重要的课题。而 synchronized 关键字,作为 Java 语言提供的内置同步机制,就如同一位忠诚的守护者,在保障多线程安全方面发挥着不 ...
Flink实时计算心智模型——流、窗口、水位线、状态与Checkpoint的协作
Flink实时计算心智模型——流、窗口、水位线、状态与Checkpoint的协作 在实时计算领域,Flink凭借其强大的流处理能力、低延迟特性和高可靠性,成为当前最主流的框架之一。但对于很多初学者甚至资深开发者而言,Flink的核心概念——流、窗口、水位线、状态与Checkpoint,往往是“单独能 ...
如何解决高并发下的短信延迟?从选型到接入的3个关键点
在分布式架构中,短信服务(SMS)常被视为业务链路的“最后一公里”。无论是 618 秒杀场景下的身份校验,还是应对验证码爆破等安全攻击,短信的实时性直接影响到用户转化率与资金安全。一旦短信延迟超过 10 秒,用户流失率将呈指数级增长。 作为后端架构师,解决短信延迟不应仅停留在代码层面,而需从底层通信 ...
springboot~ImportBeanDefinitionRegistrar在自定义RPC框架中的使用
一、自定义RPC框架使用场景示例 1. 需求场景:服务注册与发现的自动配置 入口注解设计: @Target(ElementType.TYPE) @Retention(RetentionPolicy.RUNTIME) @Documented @Import(RpcComponentRegistrar. ...
Condition底层机制剖析:多线程等待与通知机制
概述 Condition 是一个多线程协调通信的工具类,可以让某些线程一起等待某个条件(condition),只有满足条件时,线程才会被唤醒。 在使用Lock之前,使用的最多的同步方式应该是synchronized关键字来实现同步方式了。配合Object的wait()、notify()系列方法可以实 ...
多租户架构设计
1、多租户架构设计 请设计一个支撑千万会员的鞋服会员SCRM(SaaS)多租户架构,重点说明如何在促销期间应对流量十倍激增,以及如何保障新旧SaaS客户体验稳定。 需求分析 设计支撑千万会员的鞋服会员多租户架构 促销期间应对流量十倍激增 保障新旧SaaS客户体验稳定 项目设计 程序涉及到的数据库表 ...
剑指offer-78、求平⽅根
题⽬描述 给定⼀个⾮负整数 x ,计算并返回 x 的平⽅根,即实现 int sqrt(int x) 函数。 正数的平⽅根有两个,只输出其中的正数平⽅根。如果平⽅根不是整数,输出只保留整数的部分,⼩数部分将被舍去。 示例1 输⼊:8 返回值:2 解释:8 的平⽅根是 2.82842…,由于⼩数部分将被 ...


