E-COM-NET
首页
在线工具
Layui镜像站
SUI文档
联系我们
推荐频道
Java
PHP
C++
C
C#
Python
Ruby
go语言
Scala
Servlet
Vue
MySQL
NoSQL
Redis
CSS
Oracle
SQL Server
DB2
HBase
Http
HTML5
Spring
Ajax
Jquery
JavaScript
Json
XML
NodeJs
mybatis
Hibernate
算法
设计模式
shell
数据结构
大数据
JS
消息中间件
正则表达式
Tomcat
SQL
Nginx
Shiro
Maven
Linux
【源码解读】
Kafka 核心
源码解读
【六】--副本管理模块
文章目录1AbstractFetcherThread:拉取消息分几步?1.1课前案例1.2抽象基类:AbstractFetcherThread1.2.1类定义及字段1.2.2分区读取状态1.2.3重要方法1.3总结2ReplicaFetcherThread:Follower如何拉取Leader消息?2.1AbstractFetcherThread类:doWork方法2.2子类:ReplicaFet
-出发-
·
2023-04-09 16:59
kafka
kafka
大数据
云原生
MyBatis
源码解读
9 种设计模式,真是太有用了~
点击上方“程序IT圈”,选择“置顶公众号”每天早晨8点50分,准点开车打卡来源:crazyant|crazyant.net/2022.html虽然我们都知道有26个设计模式,但是大多停留在概念层面,真实开发中很少遇到,Mybatis源码中使用了大量的设计模式,阅读源码并观察设计模式在其中的应用,能够更深入的理解设计模式。Mybatis至少遇到了以下的设计模式的使用:Builder模式,例如SqlS
程序IT圈
·
2023-04-09 09:03
设计模式
java
mybatis
spring
ehcache
基于Java+SpringBoot+Vue在线培训考试系统设计与实现
可提供微服务项目搭建与毕业项目实战✌博主作品:《微服务实战》专栏是本人的实战经验总结,《Spring家族及微服务系列》专注Spring、SpringMVC、SpringBoot、SpringCloud系列、Nacos等
源码解读
卡布奇诺-海晨
·
2023-04-09 03:16
Java项目案例
java
spring
boot
mybatis
多线程相关
https://www.cnblogs.com/fengmin/p/5841014.html参考
源码解读
[图片上传中...
ruiying
·
2023-04-09 02:15
ReentrantLock
源码解读
前言写这篇文章之前,还是先安利一本书:《java并发编程的艺术》。这本书对锁的实现的很多细节都解释的还是很清楚的,加上自己配合源码进行理解,读懂ReentrantLock这个类的实现应该不是那么困难。本文只对独占模式进行分析。一行行分析ReentrantLock源码直接步入正题,先贴一段代码看看如何使用ReentrantLock:publicclassReentrantLockTest{publi
marsjhe
·
2023-04-08 18:06
Spark框架中分布式K-Means算法
源码解读
Spark中的K-Means实现采用K-Means||模式。1.何为K-Means||?K-Means||是解决K-Means++算法在大数据量情况下,初始化速度太慢而产生的一种算法。主要思路是改变每次遍历时候的取样规则。并非按照K-Means++算法,初始化每次遍历只获取一个样本,而是每次获取K个样本,重复该取样操作O(logn)次(n是样本的个数),然后再将这些抽样出来的样本聚类出K个点,最后
心之若涯
·
2023-04-08 13:51
源码解读
:PolarDB-X 中的窗口函数
为什么需要窗口函数?Window是一个常用且重要的功能,PolarDB-X作为一款分布式数据库,自然也支持了窗口函数。对于业务开发来讲,其可以大大简化业务SQL的设计,比如分组排序功能,如果支持窗口函数,则只需使用排序函数即可,例子如下。例:我现在有一张表,包含学生姓名,学生班级,学生成绩,现在请你帮我写一条SQL,实现对每个班级内的同学进行排名的需求?有窗口函数时:SELECTstudent_n
阿里云云栖号
·
2023-04-08 08:11
云栖号技术分享
数据库
java
sql
云计算
阿里云
Jpress – Jboot
源码解读
Jboot对Jfinal进行了封装,并且增加了很多,通用默认组件配置1.数据库2.代码生成封装3.微信调用4.配置类等5.定时任务6.服务容器Jpress还是比较不错的尽管文档不多,但是源码都有,认真看下,还是可以搞定的就是模块太多了,建议合并为3-4个,也方便升级另外一个封装的太多,不直观。功能都是有的,很贴心,还有导入wordpress我现在基本做到了,建表,生成代码,调整html页面字段,配
sho_ko
·
2023-04-07 09:06
Springboot基于Redisson实现Redis分布式可重入锁【案例到源码分析】
从官网到整合Springboot到
源码解读
,以单节点为例,小编的理解都在
掉发的小王
·
2023-04-07 08:44
Redis
redis
spring
boot
分布式
redisson
锁
[spr-boot] 最新Spring
源码解读
与设计详析完整
├──1.avi├──10.avi├──11.avi├──12.avi├──13.avi├──14.avi├──15.avi├──16.avi├──17.avi├──18.avi├──19.avi├──2.avi├──20.avi├──21.avi├──22.avi├──23.avi├──24.avi├──25.avi├──26.avi├──3.avi├──4.avi├──5.avi├──6.av
xiaonu
·
2023-04-07 04:32
Swift数据解析方案Codable
源码解读
前言在使用OC的项目中,对于网络请求获取json数据,然后进行解析成的自定义模型我们通常会用MJExtension来很方便的处理.在Swift中,我发现早期其实系统没有提供相应的API来解决类似的问题,直到Swift4.0的时候,发布了Codable来解决这个痛点.在使用Codable后,发现这个功能非常强大,使用起来非常方便,由于之前只是知道如何使用,并不知道深层次的原理,所以来学习一下Coda
Leesim
·
2023-04-07 00:21
RxSwift
源码解读
:dispose流程
上一篇文章解读了创建Observable和订阅Observable的流程,今天继续解读dispose源码。dispose即订阅取消,取消后相关内存资源释放,包括被观察者,观察者,之后无法再发送序列,也无法接收序列。我们可以对dispose事件进行订阅,这样订阅取消后会调用对应闭包。我们还是拿上一篇文章的代码举例:letobservable=Observable.create{(anyObserve
Oceanj
·
2023-04-06 20:48
Vite
源码解读
系列(图文结合) —— 本地开发服务器篇
我将会使用图文结合的方式,尽量让本篇文章显得不那么枯燥(显然对于
源码解读
类文章来说,这不是个简单的事情)。如果你还没有使用过Vite,那么你可以看看我的前两篇文章,我也是刚体验没两天呢。
晒兜斯
·
2023-04-06 13:49
前端成长之路
vue
源码
java TreeSet 和 TreeMap
源码解读
目录一、前言二、TreeSet详解1.TreeSet简介2.TreeSet的底层实现0°准备工作1°TreeSet构造器2°匿名内部类实现接口的多态3°TreeMap构造器4°add方法5°put方法和put方法6°继续添加元素7°修改比较器的比较原则三、TreeMap详解1.TreeMap简介2.TreeMap的底层实现0°准备工作1°TreeMap构造器2°add方法。3°外层put和内层pu
Cyan_RA9
·
2023-04-06 12:28
#
源码分析
java进阶
java
jvm
开发语言
源码分析
算法
React
源码解读
之React Fiber
开始之前,先讲一下该文章能帮你解决哪些问题?facebook为什么要使用重构ReactReactFiber是什么ReactFiber的核心算法-react是如何中断重启任务的reactfiber部分源码简化版前言该文章涉及的源码部分基于Reactv17.0.2whyReactFiber浏览器渲染过程从浏览器的运行机制谈起。大家都知道,浏览器是多进程多线程的,多进程包括主进程,渲染进程,插件进程,G
前端开发小陈
·
2023-04-06 08:03
react.js
javascript
前端
PostgreSQL
源码解读
(101)- 分区表#7(数据查询路由#4-prune partition#2)
本节是PG在查询分区表的时候如何确定查询的是哪个分区逻辑介绍的第二部分。在规划阶段,函数set_rel_size中,如RTE为分区表(rte->inh=T),则调用set_append_rel_size函数,在set_append_rel_size中通过prune_append_rel_partitions函数获取“可保留”的分区。本节的内容是介绍prune_append_rel_partitio
EthanHe
·
2023-04-06 03:25
(
源码解读
)
要理解computed的工作原理,只需要理解下面4个特性-特性1:computed默认不执行(因为lazy的原因,在新建watcher实例的时候,会将watcher.value赋值为undefined,而不会立马进行计算。)-特性2:取值的时候,computed里面的方法会被执行-特性3:computed是惰性的,computed依赖的其它属性发生变化时,computed不会立即重新计算,要等到获
请叫我小一
·
2023-04-06 02:29
vue
vue.js
LinkedList-
源码解读
简介LinkedList的特点:底层实现了双向链表和双队列特点可以添加任意元素(元素可重复),包括null线程不安全,没有实现同步LinkedList的底层操作机制LinkedList底层维护了一个双向链表LinkedList中维护了两个属性first和last分别指向首节点和尾节点每个节点(Node对象),里面又维护了prev、next、item三个属性,其中通过prev指向前一个,通过next
多加点辣也没关系
·
2023-04-06 00:40
源码解读
链表
数据结构
java
HashMap-
源码解读
简介HashMap的特点:存取顺序无序键和值位置都可以是null,但是键位置只能是一个null键位置是唯一的,底层数据结构是:数组+链表+红黑树引入红黑树的目的是提高查询的速度底层结构:数组是一个Node[]数组,这个数组也称为哈希表,表中的每个空间用于存放各链表或者红黑树的头节点,每一个子集合称为一个哈希桶。在往HashMap中添加元素的时候,会先通过hash算法得到该元素的索引位置,并以链表的
多加点辣也没关系
·
2023-04-06 00:53
源码解读
java
源码
散列表
hyperscan --/examples/simplegrep.c
转载于:http://www.cnblogs.com/zzqcn/p/4904290.html目录1.概述2.
源码解读
2.1编译正则表达式(compile)2.2进行匹配(scan)2.3清理资源3.编译运行正文示例位置
庞叶蒙
·
2023-04-05 23:14
DPDK学习
hyperscan
dpdk
ArrayList有参构造
源码解读
ArrayList有参构造
源码解读
debug用例:@TestpublicvoidtestArrayListConstructor(){ArrayListarrayList=newArrayListcls
xin麒
·
2023-04-05 11:53
java
List
源码
RabbitMQ并发消费
源码解读
目前项目采用spring-boot2.1.6版本,并集成了RabbitMQ的相关功能,至于MQ的相关选型,由于之前项目组已经有项目采用了RabbitMQ,所以基于技术栈的稳定性,并没有变更,但是也简单了解了目前主流的MQ的使用场景,包括RabbitMQ,RocketMQ,Kafka这三种主流MQ,这里不过多阐述,感兴趣的同学可以google下,也可以参读下极客时间李玥老师的消息队列高手课专栏课程对
花花大脸猫
·
2023-04-05 10:20
SpringBoot启动
源码解读
(10)
这次关注的是类加载实例化部分代码。spring中加载类在代码ConfigurationClassPostProcessor中实现的。1:ConfigurationClassPostProcessor是在AnnotationConfigEmbeddedWebApplicationContext创建时,调用接口AnnotationConfigUtils#registerAnnotationConfig
五指魅力
·
2023-04-05 09:29
Leveldb
源码解读
------Memtable(跳表)详解
在leveldb中的memtable实际上是对核心数据结构skipList做了一个包装,并对外提供了接口。使用让我们一起来研究一下跳表为什么使用跳表因为memtable为了更快的查询,是一个sortmap要求。一般会采用红黑树,不过LevelDB采用的是Skiplist。Skiplist是一种概率性的数据结构,支持SortedMap的所有功能,性能和红黑树相当实现源码分析//Writesrequi
boring_111
·
2023-04-05 06:07
leveldb源码解读
数据结构
数据库架构
数据库开发
《spring
源码解读
》 - IoC 之解析 import 标签
spring-framework.jpg在上一文中我们分析了注册BeanDefinition的过程,在其中我们了解到在解析跟节点和子节点时分两种情况,对于默认名称空间的标签我们通过DefaultBeanDefinitionDocumentReader#parseDefaultElement(Elementele,BeanDefinitionParserDelegatedelegate)进行处理,而
AnonyStar
·
2023-04-05 05:29
源码解读
:PolarDB-X 中的窗口函数
为什么需要窗口函数?Window是一个常用且重要的功能,PolarDB-X作为一款分布式数据库,自然也支持了窗口函数。对于业务开发来讲,其可以大大简化业务SQL的设计,比如分组排序功能,如果支持窗口函数,则只需使用排序函数即可,例子如下。例:我现在有一张表,包含学生姓名,学生班级,学生成绩,现在请你帮我写一条SQL,实现对每个班级内的同学进行排名的需求?有窗口函数时:SELECTstudent_n
阿里云技术
·
2023-04-05 04:10
数据库
java
sql
云计算
RocketMQTemplate 实现消息发送
代码托管于gitee:easy-rocketmq文章目录一、前置工作二、消费者三、生产者1.普通消息2.过滤消息3.同步消息4.延时消息5.批量消息6.异步消息7.单向消息8.顺序消息9.事务消息概要Demo
源码解读
一
HGW689
·
2023-04-05 02:47
RocketMQ
java
RocketMQ
SpringBoot
Android 架构之Glide
源码解读
(下)
前言在前两篇中,主要进行了Glide三部曲with、load、into对应的源码解析。在本篇中将会对Glide的三级缓存以及三层缓存实现的逻辑进行详解。在解读三级缓存之前,我们要先知道到底是哪三级缓存,然后再熟悉其原理,最后再将其原理带入源码中解读,将会事半功倍。为了更好的了解Glide,建议没看过前两篇的小伙伴可以去看看,当然我这每一篇都是独立的,就算没看过前两篇,本篇内容依然能够看懂。前两篇文
我爱田Hebe
·
2023-04-05 00:00
Ribbon过滤器ZoneAvoidanceRule
源码解读
一ZoneAvoidanceRule在类图中的位置二ZoneAvoidanceRule
源码解读
publicclassZoneAvoidanceRuleextendsPredicateBasedRule{
chengqiuming
·
2023-04-04 18:11
Ribbon
java源码阅读 - TreeMap
往期文章HashMap中putAll()方法批量保存的
源码解读
,并发现严重缺陷用最简单的话讲最明白的红黑树数据结构-堆与堆排序文章目录往期文章一、介绍二、类的声明三、底层实现四、成员变量五、内部类Entry
理想万岁万万岁
·
2023-04-04 16:08
JAVA
集合
源码
java
ArrayList扩容原理
今天带来的下饭菜是ArrayList的扩容
源码解读
。相信大家对这盘菜都不陌生,我们经常使用它来定义一个集合,无论日常开发还是自己学习使用的频率是相当的高。
理想万岁万万岁
·
2023-04-04 16:37
JAVA
java
arraylist
AFNetworking 3.0
源码解读
总结(干货)(下)
承接上一篇AFNetworking3.0
源码解读
总结(干货)(上)21.网络服务类型NSURLRequestNetworkServiceType示例代码:typedefNS_ENUM(NSUInteger
MinggeQingchun
·
2023-04-04 11:10
iOS-OC
grpc
源码解读
-java
https://www.cnblogs.com/parse-code/p/6160070.htmlhttp://jiangew.me/grpc-01/https://cloud.tencent.com/developer/article/1347864
haozhugogo
·
2023-04-04 07:50
其它
「Redis
源码解读
」—数据结构(六)对象
知识点redis数据库中的每一个键值对的键和值都是一个对象redis共有字符串、列表、哈希、集合、有序集合五种类型的对象,每种类型的对象至少都有两种或以上的编码方式,不同编码可以在不同的使用场景上优化对象的使用效率redis在执行命令之前,会先检查给定键的类型是否能执行指定命令,而检查一个键的类型就是检查键的值对象的类型redis的对象系统带有引用计数实现的内存回收机制,当一个对象不再被使用时,该
wh4763
·
2023-04-04 05:56
Spring
源码解读
之BeanDefinition读取器
Spring
源码解读
之BeanDefinition读取器BeanDefinitionReader1、这个接口的功能就是将资源文件(spring的配置文件)中的信息转换成BeanDefinition形式2
爱撒谎的男孩
·
2023-04-04 05:10
Flink
源码解读
(二):JobGraph
源码解读
目录JobGraph核心对象1、JobVertex2、JobEdge3、IntermediateDataSetJobGraph生成过程入口函数createJobGraph函数参考JobGraph
源码解读
上回说到
Stray_Lambs
·
2023-04-04 03:41
大数据
Flink
flink
EventBus
源码解读
本人通过源码的解读,只是为了加深对其执行流程的理解,文章中不会对更细致的地方做过多的讲解,只是把握住开源框架的整体脉络。EventBus的整体执行流程包括四部分:注册、事件发送、事件接收、取消注册。在源码讲解之前首先先放上一个简单的例子://EventBus注册EventBus.getDefault().register(this);//事件发送EventBus.getDefault().post
android_hcf
·
2023-04-03 23:31
RocketMQ
源码解读
之Consumer
立志欲坚不欲锐,成功在久不在速。——张孝祥大纲图示Rebalance(针对集群消费模式)(1)消费Group下的所有消费者(2)Topic的所有Queue队列(3)Queue分配策略1.触发时机(1)消费者启动(2)消费者加入或者退出消费组(3)定时触发Rebalance(10s)2.举例假设,一个topic中有4个队列,有一个Producer往4个队列中发数据,在集群消费中,在一个消费者分组中如
娆疆_蚩梦
·
2023-04-03 20:56
Spring Security
源码解读
:基本架构及初始化
SpringSecurity是基于web的安全组件,所以一些相关类会分散在spring-security包和web包中。SpringSecurity通过自定义Servlet的Filter的方式实现,具体架构可参考官网SpringSecurity:Architecture这里使用SpringBoot2.7.4版本,对应SpringSecurity5.7.3版本基本架构首先左侧是Servlet中的Fi
T.Y.Bao
·
2023-04-03 13:54
Spring
Security
spring
servlet
java
Class.getResource()、ClassLoader.getResource()
源码解读
Class.getResource()、ClassLoader.getResource()
源码解读
Java中取资源时,经常用到Class.getResource和ClassLoader.getResource
JermeryBesian
·
2023-04-03 11:44
Java
java
jvm
面试
webpack 4.0 完全讲解及
源码解读
(1)
webpack4.0完全讲解及
源码解读
就目前前端环境而言,使用cli自动构建工具可以快速的构建项目完成项目搭建,快速完成功能,业务开发,这样水到渠成的模式深得人心,也深得科技公司信赖,因为简单,易用且方便
公羊无衣
·
2023-04-03 11:25
【Android】startForeground启动流程分析
1、startForeground本文分析了startForeground启动流程,android在8.0以上平台上怎么保证了前台服务,以及前台服务的通知怎么显示出来的进行
源码解读
。
Tech Ranger
·
2023-04-03 10:14
笔记
并发编程系列(十)AQS同步器独占锁加锁与解锁-
源码解读
目录1.AbstractOwnableSynchronizer源码分析2.AQS同步器下的Node源码:3.AbstractQueuedSynchronizer独占锁4.1.1AQS独占锁加锁的过程4.1.2acquire()方法:4.1.3tryAcquire()方法4.1.4addWaiter()方法4.1.5enq()方法自旋方式使node进入队尾4.1.6acquireQueued()方法
程序员劝退师丶
·
2023-04-03 08:48
线程
AQS
co
源码解读
背景:闲来无事,翻了下co的源码来看,源码短小精悍,算上注释,一共240行左右;决定写一篇博客来记录下学习的心得。TJ大神的co:https://github.com/tj/co作用:co通过将Generator函数拆成一个Promise将码农从callbackhell中拯救了出来;下边放出一段代码,对比下co与普通回调版本的区别:1/**2*回调版本3*/45letfs=require('fs'
zzm_
·
2023-04-03 06:16
Flutter(八)--Flutter渲染逻辑+
源码解读
Flutter渲染逻辑+源码浅显解读前言flutter渲染引擎-flutter.framework,而真正的渲染工作是由skia来做的由于Flutter中几乎所有对象都是Widget,那么现在抛出两个问题:我们在屏幕上看到的就是以Widget为依据渲染的吗?我们开发中创建的每一个Widget都会被渲染到屏幕上吗?带着这三个问题,开始这篇文章,阅读大概需要8-10分钟。Flutter渲染逻辑三种树这
Henry________
·
2023-04-02 16:49
Vector-
源码解读
简介Vector类实现了一个动态数组。和ArrayList很相似,但是两者是不同的:Vector是同步访问的Vector包含了许多传统的方法,这些方法不属于集合框架Vector类的定义说明:它的底层也是一个数组对象protectedObject[]elementData,它的方法带有synchronized关键字,所以是线程安全的,在开发中,需要线程同步安全的时候,考虑使用。与ArrayList的
多加点辣也没关系
·
2023-04-02 14:33
java
源码
ArrayList-
源码解读
简介:ArrayList是List接口的一个实现类,它是程序中最常见的一种集合。在ArrayList内部封装了一个长度可变的数组对象,当存入的元素超过数组长度时,ArrayList会在内存中分配一个更大的数组来存储这些元素,因此可以将ArrayList集合看作一个长度可变的数组。正是由于ArrayList内部的数据存储结构是数组形式,在增加或删除指定位置的元素时,会创建新的数组,效率比较低,因此不
多加点辣也没关系
·
2023-04-02 14:33
源码解读
java
Linux /proc/iomem与/proc/ioports
SystemRAM3.1SystemRAM简介3.2page_is_ram3.3Kernelcode、data、bss四、/proc/ioports五、/proc/iomem/与/proc/ioports/对比5.1API简介5.3
源码解读
总结参考资料前言本文主要描述了
小立爱学习
·
2023-04-02 13:15
Linux
内存管理
linux
运维
服务器
Redisson: 不错, 正是在下 (
源码解读
)
了解RedissonRedisson简介可重入锁Redisson的锁重入
源码解读
废话
阿千弟
·
2023-04-02 10:09
redis
官方学习
java
redis
分布式
CAS 4.1.10 版本服务端
源码解读
这篇文章主要对CAS4.1.10版本进行
源码解读
(主要是登录流程)。不同版本可以在github下载。
AaronSimon
·
2023-04-02 07:20
上一页
14
15
16
17
18
19
20
21
下一页
按字母分类:
A
B
C
D
E
F
G
H
I
J
K
L
M
N
O
P
Q
R
S
T
U
V
W
X
Y
Z
其他