摘要: 1.JS是单线程吗? 是的,到目前为止JS语言没有多线程的API,它的执行引擎只支持单线程,也就是一个JavaScript进程内只有一个线程。 2.与DOM的交互为什么不可以是多线程? 我觉得是可以的,但是如果有多线程可以操作DOM,则必须引入一个同步机制来保证线程安全。想象一个这样一个场景,用户提 阅读全文
posted @ 2020-11-08 16:56 猫毛·波拿巴 阅读(755) 评论(0) 推荐(0) 编辑
摘要: 概要 消息查询是什么? 消息查询就是根据用户提供的msgId从MQ中取出该消息 RocketMQ如果有多个节点如何查询? 问题:RocketMQ分布式结构中,数据分散在各个节点,即便是同一Topic的数据,也未必都在一个broker上。客户端怎么知道数据该去哪个节点上查? 猜想1:逐个访问broke 阅读全文
posted @ 2020-08-15 23:14 猫毛·波拿巴 阅读(1564) 评论(0) 推荐(0) 编辑
摘要: 消费者如何读取数据? 前一篇是生产者的处理,这一篇讲消费者的处理 我们都知道,消费者无非就是不停地从队列中读取数据,处理数据。但是与BlockedQueue不同的是,RingBuffer的消费者不会对队列进行上锁,那它是怎样实现的呢? 概括地说,就是通过CAS原子性地得到一个可消费的序号,然后再根据 阅读全文
posted @ 2020-05-12 22:34 猫毛·波拿巴 阅读(1076) 评论(0) 推荐(0) 编辑
摘要: 纯CAS为啥比加锁要快? 同样是修改数据,一个采用加锁的方式保证原子性,一个采用CAS的方式保证原子性。 都是能够达到目的的,但是常用的锁(例如显式的Lock和隐式的synchonized),都会把获取不到锁的线程挂起,相对于CAS的不挂起,多了挂起和唤醒的开销。 题外话:CAS与锁的关系 CAS只 阅读全文
posted @ 2020-05-10 16:34 猫毛·波拿巴 阅读(995) 评论(1) 推荐(0) 编辑
摘要: JDK中的Future特性 在介绍Netty的ChannelFuture之前,我们先来看看JDK中的Future是如何实现的。总的来说就是任务提交的时候会使用装饰器模式,将任务包装成一个FutureTask。当执行器执行该Task的时候,不仅仅会执行用户提交的任务,还会执行装饰器添加的额外操作,例如 阅读全文
posted @ 2020-05-01 20:25 猫毛·波拿巴 阅读(789) 评论(0) 推荐(1) 编辑
摘要: 前言 在学习SparkJava、Vert.x等轻量级Web框架的时候,都遇到过打包问题,这两个框架打包的时候都需要添加额外的Maven配置,并指定启动类才能得到可执行的JAR包; 而springboot项目,似乎都不需要额外的配置,直接package就可以得到可执行的JAR包,这是怎么回事呢? Ve 阅读全文
posted @ 2020-04-07 14:49 猫毛·波拿巴 阅读(2660) 评论(0) 推荐(1) 编辑
摘要: @EnableXX注解的使用场景 SpringBoot为开发人员提供了很多便利,例如如果想要定时功能,只要添加@EnableSchedule,即可配合@Schedule注解实现定时任务功能,不需要额外配置定时任务的处理线程,就可以直接使用(框架提供默认配置,在找不到用户自定配置的执行器时,使用默认配 阅读全文
posted @ 2020-04-06 18:40 猫毛·波拿巴 阅读(1441) 评论(0) 推荐(2) 编辑
摘要: 生产者和消费者之间为什么隔着一个队列? 首先,生产者与消费者由于速度的不一致,所以需要一个空间用于缓冲。这可以将生产者与消费者解耦,生产者产出数据的时候,不需要把数据交到消费者手上才行,只要把数据丢入缓冲区就好。这样就可以各做各的。 为什么缓冲区是一个队列? 通常情况下,这个缓冲区的数据结构是一个有 阅读全文
posted @ 2019-09-09 21:39 猫毛·波拿巴 阅读(345) 评论(0) 推荐(1) 编辑
摘要: hash表与平衡树查询数据的时间复杂度是多少? hash表为O(1),平衡树为O(logn) 这个时间复杂度是如何得出的? 时间复杂度是按照最糟糕的情况来的。但即使是最糟糕的情况,hash表也只需要计算一次,就可以定位到数据(对于常见的实现,实际上是定位到桶,然后在桶内遍历)。而对于平衡树,例如AV 阅读全文
posted @ 2019-07-27 10:59 猫毛·波拿巴 阅读(570) 评论(0) 推荐(0) 编辑
摘要: 什么时候需要进行需要原子操作? 很常见的例子,就是利用Redis实现分布式锁。 实现锁需要哪些条件? 我们知道要实现锁,就需要一个改变锁状态的方法。这个方法能原子地对锁的状态进行检查并修改。如果修改成功,则意味着获得了锁。对于硬件,它提供的就是test-and-set,compare-and-swa 阅读全文
posted @ 2019-07-26 15:49 猫毛·波拿巴 阅读(15886) 评论(2) 推荐(2) 编辑