设计模式
创建型单例模式饿汉式(在使用时进行实例化,线程不安全)
123456789101112131415public class achieve1 { private static achieve1 singleton ; // 私有化构造器 禁止外部构造 不能防止反射破环 private achieve1(){ } // 给外界提供获取实例方法 线程不安全 // 不安全的原因:同时多个线程去构造实例 public static achieve1 getInstance(){ if(singleton == null) { singleton = new achieve1(); } return singleton; }}
懒汉模式要变成线程安全的除了用饿汉模式之外,还有两种方法:
加synchronized关键字
此方法是最简单又有效的方法,不过对性能上会有所损失。比如两个线程同时调用这个实例 ...
读集合源码
Arraylist底层数据结构
1transient Object[] elementData; //元素数据底层数组实现
默认构造函数
12345public MyArrayList(){ //数组默认大小 elementData = new Object[10]; size = 0; }
简单实现增删改查方法
12345678910111213141516171819202122232425262728293031323334353637// add方法public void add(T t){ elementData[size++] = t;}// get方法public Object get(int index){ if(index > size){ throw new RuntimeException("数组没有"+index+"这个元素"); } return ele ...
javase
for 循环的执行顺序12345678910111213static boolean foo(char c){ System.out.print(c); return true; } public static void main(String[] args) { int i =0; for(foo('A');foo('B')&&(i<2);foo('C')){ i++; foo('D'); } }// 输出 ABDC BDCB
try catch finally当Java程序执行try块、catch块时遇到了return或throw语句,这两个语句都会导致该方法立即结束,但是系统执行这两个语句并不会结束该方法,而是去寻找该异常处理流程中是否包含finally块,如果没有finally块,程序立即执行return或throw语句,方法终止;如果有final ...
openResty
介绍
OpenResty 是一个基于 Nginx 与 Lua 的高性能 Web 平台,其内部集成了大量精良的 Lua 库、第三方模块以及大多数的依赖项。用于方便地搭建能够处理超高并发、扩展性极高的动态 Web 应用、Web 服务和动态网关。
OpenResty 通过汇聚各种设计精良的 Nginx 模块(主要由 OpenResty 团队自主开发),从而将 Nginx 有效地变成一个强大的通用 Web 应用平台。这样,Web 开发人员和系统工程师可以使用 Lua 脚本语言调动 Nginx 支持的各种 C 以及 Lua 模块,快速构造出足以胜任 10K 乃至 1000K 以上单机并发连接的高性能 Web 应用系统。
OpenResty 的目标是让你的 Web 服务直接跑在 Nginx 服务内部,充分利用 Nginx 的非阻塞 I/O 模型,不仅仅对 HTTP 客户端请求,甚至于对远程后端诸如 MySQL、PostgreSQL、Memcached 以及 Redis 等都进行一致的高性能响应。”
引用站外地址
Op ...
自建VPN订阅工作流
前提准备不想搭建可以使用博主搭建的,下滑就能找到
github账号
cloudflare账号
引用站外地址
用到的Onezyh开源的项目
https://github.com/Onezyh/Worker-Vless-2-USB
引用站外地址
YouTuBe视频教程
https://www.youtube.com/watch?v=hTohhSFMvBs
开始搭建部署部署workers
部署
选择Workers和pages页面,然后点击创建应用程序。
开始创建worker,创建完后部署。
编辑代码
部署完成后点击编辑代码。
打开Onezyh开源的项目。
将_worker.js的代码内容复制粘贴到worker中然后从新部署。
部署自动获取订阅信息站点
...
JIT
JIT优化技术 我们知道,想要把高级语言转变成计算机认识的机器语言有两种方式,分别是编译和解释,虽然Java转成机器语言的过程中有一个步骤是要编译成字节码,但是,这里的字节码并不能在机器上直接执行。
所以,JVM中内置了解释器(interpreter),在运行时对字节码进行解释翻译成机器码,然后再执行。
解释器的执行方式是一边翻译,一边执行,因此执行效率很低。为了解决这样的低效问题,HotSpot引入了JIT技术(Just-In-Time)。
有了JIT技术之后,JVM还是通过解释器进行解释执行。但是,当JVM发现某个方法或代码块运行时执行的特别频繁的时候,就会认为这是“热点代码”(Hot Spot Code)。然后JIT会把部分“热点代码”翻译成本地机器相关的机器码,并进行优化,然后再把翻译后的机器码缓存起来,以备下次使用。
扩展知识HotSpot虚拟机中内置了两个JIT编译器:Client Complier和Server Complier,分别用在客户端和服务端,目前主流的HotSpot虚拟机中默认是采用解释器与其中一个编译器直接配合的方式工作。
当 JVM 执行代码时,它并不立 ...
Redis 主从复制
主从模式Redis 单机部署一般存在如下几个问题:
机器故障,导致 Redis 不可用,数据丢失
容量瓶颈:容量不能水平扩展
QPS 瓶颈:一台机器的处理能力、网络宽带总是有限的,如果能够划分一些流量到其他机器,可以有效解决 QPS 问题
Redis 提供的主从复制功能,实现了一份数据存在多个相同的副本,它是实现 Redis 高可用的基础,作用有如下几个:
数据冗余:主从复制实现了数据的热备份,是 Redis 持久化之外的一种数据冗余方式
故障恢复:当主节点出现故障时,可以将从节点晋升为主节点继续提供服务,实现快速的故障恢复
读写分离:主从复制可以实现读写分离,主节点写,从节点读,读写分离提高了服务器的负载能力
高可用的基石:主从复制是哨兵和集群能够实施的基础,因此说主从复制是 Redis 高可用的基础
配置主从复制默认情况下,Redis 所有节点都是主节点,节点与节点之间互不干涉,而参与主从复制的节点则是划分了主节点(master)和从节点(slave),它具有如下几个特点:
主节点下有一个或者多个从节点
每一个从节点只能有一个主节点
数据的复制是单向的,只能由主节点复制到 ...
JMH - Java 代码性能测试
JMH - Java 代码性能测试的终极利器、必须掌握JMH 介绍那么如何对 Java 程序进行一次精准的性能测试呢?难道需要掌握很多 JVM 优化细节吗?难道要研究如何避免,并进行正确编码才能进行严格的性能测试吗?显然不是,如果是这样的话,未免过于困难了,好在有一款一款官方的微基准测试工具 - JMH.
JMH 的全名是 Java Microbenchmark Harness,它是由 Java 虚拟机团队开发的一款用于 Java 微基准测试工具。用自己开发的工具测试自己开发的另一款工具,以子之矛,攻子之盾果真手到擒来,如臂使指。使用 JMH 可以让你方便快速的进行一次严格的代码基准测试,并且有多种测试模式,多种测试维度可供选择;而且使用简单、增加注解便可启动测试。
JMH 使用12345678910<dependency> <groupId>org.openjdk.jmh</groupId> <artifactId>jmh-core</artifactId> <version>1.36</ ...
虚拟线程
虚拟线程线程术语定义操作系统线程(OS Thread):由操作系统管理,是操作系统调度的基本单位。
平台线程(Platform Thread):Java.Lang.Thread 类的每个实例,都是一个平台线程,是 Java 对操作系统线程的包装,与操作系统是 1:1 映射。
虚拟线程(Virtual Thread):一种轻量级,由 JVM 管理的线程。对应的实例 java.lang.VirtualThread 这个类。
载体线程(Carrier Thread):指真正负责执行虚拟线程中任务的平台线程。一个虚拟线程装载到一个平台线程之后,那么这个平台线程就被称为虚拟线程的载体线程。
虚拟线程定义JDK 中 java.lang.Thread 的每个实例都是一个平台线程。平台线程在底层操作系统线程上运行 Java 代码,并在代码的整个生命周期内独占操作系统线程,平台线程实例本质是由系统内核的线程调度程序进行调度,并且平台线程的数量受限于操作系统线程的数量。
而虚拟线程(Virtual Thread)它不与特定的操作系统线程相绑定。它在平台线程上运行 Java 代码,但在代码的整个生命周期内 ...
新生赛
题 A 最大化网格图中正方形空洞的面积
题目描述题 解给你一个网格图,由 n + 2 条 横线段 和 m + 2 条 竖线段 组成,一开始所有区域均为 1 x 1 的单元格。所有线段的编号从 1 开始。给你两个整数 n 和 m 。同时给你两个整数数组 hBars 和 vBars 。hBars 包含区间 [2, n + 1] 内 互不相同 的横线段编号。vBars 包含 [2, m + 1] 内 互不相同的 竖线段编号。如果满足以下条件之一,你可以 移除 两个数组中的部分线段:如果移除的是横线段,它必须是 hBars 中的值。如果移除的是竖线段,它必须是 vBars 中的值。输入描述:两个正整数 1 ≤ n ≤ 10^9 ,1 ≤ m ≤ 10^9 。接下来两个数组1 <= hBars.length <= 1002 <= hBars[i] <= n + 11 <= vBars.length <= 1002 <= vBars[i] <= m + 1输出描述:请你输出移除一些线段后(可 ...