01-Jvm内存模型

jvm的内存模型包含什么?程序计数器(寄存器)作用:记住下一条jvm执行的执行地址。程序执行过程中cpu切换任务执行,再次返回是必须知道程序执行到哪一步了。程序计数器是线程私有的不存在内存移除虚拟机栈栈内存模型后进先出。虚拟机栈包含了栈帧。每一个线程只能有一个活动栈帧,对应当前正在执行的方法。每一次方法调用都会存在一个栈帧。栈内存溢出:栈帧过多(方法调用嵌套太多,不能正常返回。无限递归)栈帧过大(

- 阅读全文 -

04-多线程----自定义线程池实现

自定义线程池的实现自定义阻塞队列/** * 阻塞队列 存放任务 * @param <T> */@Slf4j(topic = "c.BlockingQueue")class BlockingQueue<T> { //任务队列 private Deque<T> queue = new ArrayDeque<>();

- 阅读全文 -

03-多线程----无锁解决并发的方案

1、问题多线程模拟银行取钱操作,代码如下:public interface Demo4 { //获取当前的余额 Integer getBalance(); // 取款 void withdraw(Integer amount); //操作某一个账户 static void demo(Demo4 account) { long start = Sys

- 阅读全文 -

Retrofit的Url组合规则

BaseUrl和URL有关的注解中提供的值最后结果http://localhost:4567/path/to/other//posthttp://localhost:4567/posthttp://localhost:4567/path/to/other/posthttp://localhost:4567/path/to/other/posthttp://localhost:4567/path/t

- 阅读全文 -

04-Redis进阶,雪崩,击穿,穿透

什么是Redis雪崩?怎么解决?热点数据会做缓存(首页数据),一般缓存都是定时任务刷新,或者是查不到的时候去更新缓存,定时任务刷新就会有一个问题。例子:假如首页key失效时间为12小时,中午12点刷新数据,刚好有个热点活动,用户大量涌入,缓存key全部都失效了,此时数据查询全部落在数据库,数据库可能直接挂掉。重启数据库后又会直接挂掉。这就是缓存雪崩的现象。缓存雪崩是大面积的key失效。或者缓存挂掉

- 阅读全文 -

03-Redis基础

部分来源,自己总结。https://juejin.cn/post/6844903982066827277你们的项目为啥要用到redis传统关系型数据库例如mysql已经不适用与所有的场景,比如:秒杀扣库存,app小程序首页访问高峰等访问流量高峰,所以引入缓存中间件。redis的数据结构有哪些?String list set sortedset hash应用场景:String ->如果有大量的

- 阅读全文 -

02-Redis分布式锁

setnxsetnx key value将key的值设置为value,当且仅当value不存在的情况。如果key存在,不做任何操作。set if not exist删除锁问题?业务执行过程中出现异常。没有删除锁,造成死锁。解决异常处理,finally处理,删除锁。还有问题?系统挂了怎么办哪?业务执行过程中,系统挂了,死锁了 。解决:设置超时时间还有问题?还没有设置超时时间就挂了,死锁了。两行代码设

- 阅读全文 -

01-Redis相关

redis单线程redis持久化基于内存存储,关机后数据失效。某一时刻,将数据写入磁盘。存储位置在配置文件的dir配置。默认文件名称:dffilenamerdb触发持久化bgsave命令save命令,会造成线程阻塞 shutdownrdb默认开启。dump.rdb文件reids复制一个一摸一样的进程进行持久化。将数据写入临时文件持久化结束后替换上次持久化的文件。不影响主进程。查看进程可以看到。可以

- 阅读全文 -

Jdk8 Map的一个新特性

Map1.computeIfAbsentcomputeIfAbsent方法jdk8新特性,使用map.get("key")时当返回值为null时,我们要给它一个需要计算的值,可以使用。2.putIfAbsentputIfAbsent方法jdk8新特性,使用map.get("key")时当返回值为null时,我们要给它一个默认值,可以使用。

- 阅读全文 -