设计模式
创建型单例模式饿汉式(在使用时进行实例化,线程不安全)
123456789101112131415public class achieve1 { private static achieve1 singleton ; // 私有化构造器 禁止外部构造 不能防止反射破环 private achieve1(){ } // 给外界提供获取实例方法 线程不安全 // 不安全的原因:同时多个线程去构造实例 public static achieve1 getInstance(){ if(singleton == null) { singleton = new achieve1(); } return singleton; }}
懒汉模式要变成线程安全的除了用饿汉模式之外,还有两种方法:
加synchronized关键字
此方法是最简单又有效的方法,不过对性能上会有所损失。比如两个线程同时调用这个实例 ...
数据库知识点补充
存储引擎
查看表的存储引擎12345678910111213mysql> show create table bills;+-------+---------------------------------------------------| Table | Create Table |+-------+--------------------------------------------------| bills | CREATE TABLE `bills` ( `id` int NOT NULL AUTO_INCREMENT, `username` varchar(20) DEFAULT NULL, `money` double DEFAULT NULL, PRIMARY KEY (`id`)) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci |+-------+----------------------------------------- ...
限流
限流的经典算法
常见限流用法固定窗口限流首先维护一个计数器,将单位时间段当做一个窗口,计数器记录这个窗口接收请求的次数。
当次数少于限流阀值,就允许访问,并且计数器+1
当次数大于限流阀值,就拒绝访问。
当前的时间窗口过去之后,计数器清零。
假设单位时间是1秒,限流阀值为3。在单位时间1秒内,每来一个请求,计数器就加1,如果计数器累加的次数超过限流阀值3,后续的请求全部拒绝。等到1s结束后,计数器清0,重新开始计数。如下图:
伪代码
123456789101112131415161718/** * 固定窗口时间算法 * @return */ boolean fixedWindowsTryAcquire() { long windowUnit = 1; //设置窗口时间单位 long lastTime = 0; // 初始时间 long currentTime = System.currentTimeMillis(); //获取系统当前时间 if (currentTime - lastRequestTime > windowUn ...
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 ...
抖音有声小说
前因该死的抖音小说推广,每每看到高潮结束,然后就是各种广告和软件下载。
程序员能受这气?直接开搞。
后果
找书源
爬取小说内容
文字转语音
首先找一个书源
笔趣阁(很全但是有”DDoS protection by Cloudflare”)
铅笔小说 没有很多权限,很适合我这种半吊子选手
开爬
首先看url是否正确读取
12345678910import urllib.request as ururl = "https://www.23qb.net/book/232488/90659053.html"req = ur.Request(url)req.add_header("User-Agent", "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.116 Safari/537.36")response = ur.urlopen(req)html = response.rea ...
牛客周赛
题 A 游游的7的倍数
题目描述题 解游游拿到了一个正整数x,她希望在x中添加一个数字,使它成为7的倍数。你能帮帮她吗?输入描述:一个正整数x。1 ≤ x ≤ 10^9输出描述:x添加一个数字后形成的数。请务必保证操作的合法性,且一定是7的倍数。如果有多解,输出任意一个合法解。可以证明,至少存在一个正确答案。案例1234输入 1输出 21思路:每十个数里一定有至少一个7的倍数,因此枚举个位即可。123456789101112131415import java.util.Scanner;// 注意类名必须为 Main, 不要有任何 package xxx 信息public class Main { public static void main(String[] args) { Scanner in = new Scanner(System.in); long n = in.nextLong(); for (int i = 0; i < 10; i++ ...
首次项目部署
1. 服务器配置
2 核 4G(Centos 7)CentOS 安装 Docker官方网站上有各种环境下的安装指南,这里主要介绍 Docker CE 在 CentOS 上的安装。2.1 卸载(可选)如果之前安装过旧版本的 Docker,可以使用下面命令卸载:12345678yum remove docker \ docker-client \ docker-client-latest \ docker-common \ docker-latest \ docker-latest-logrotate \ docker-logrotate \ docker-engine
2.2 安装 Docker123456789101112131415# 1、yum 包更新到最新 sudo yum update # 2、作用:安装需要的软件包, yum-util 提供y ...
java发送邮箱
引入依赖12345678910<dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-mail</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency></dependencies>
配置文件123456789101112131415161718spring: mail: host: smt ...
计算机组成原理期末复习
计算机系统知识要点:√ 冯·诺依曼计算机核心思想与工作方式
冯诺依曼核心思想是基于硬件结构的计算机科学。他提出了冯诺依曼架构,这是一种通用的计算机硬件结构,以便可以执行任意的算法。他的工作方式是通过设计通用的硬件结构来实现计算,这样程序员就可以通过编写软件来使用该硬件结构。
可概括为 ‘存储程序’ 和 ‘程序控制’
冯诺依曼的核心思想对当今的计算机科学产生了深远的影响,并且被认为是计算机科学的基石之一。
基本思想:
1. 采用“存储程序”工作方式
2. 计算机由运算器、控制器、存储器、输入、输出设备组成
3. 存储器中存放指令和数据
4. 内部以二进制表示指令和数据
工作方式:
按地址访问指令并自动按序执行程序
√二进制的意义
二进制是一种表示数字的方式,其中数字是由0和1组成的。它是计算机科学的基础,因为计算机内部的运算和存储都是以二进制的形式进行的。
在二进制系统中,数字的每一位都代表一个特定的权值。例如,在一个8位二进制系统中,最左边的位代表2的7次方,第二位代表2的6次方,以此类推。每一位 ...
读集合源码
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 ...