首页
学习
活动
专区
圈层
工具
发布
    • 综合排序
    • 最热优先
    • 最新优先
    时间不限
  • 来自专栏纸上得来终觉浅

    libuv源码阅读(6)--helloworld

    先看用例源码: #include <stdio.h> #include <stdlib.h> #include <uv.h> int main() { uv_loop_t *loop = malloc

    1K20发布于 2021-03-12
  • 来自专栏golang算法架构leetcode技术php

    nginx源码阅读6)Master进程浅析

    4. nginx中channel指令 我们发现,ngx_channel_handler中共有6个指令类型,分别是NGX_CMD_QUIT、NGX_CMD_TERMINATE、NGX_CMD_REOPEN

    65021编辑于 2022-08-02
  • 来自专栏golang算法架构leetcode技术php

    nginx源码阅读6)http处理流程

    Nginx作为一款开源的、高性能的HTTP服务器和反向代理服务器而闻名,本文基于nginx-1.15.0,将为读者简要介绍其HTTP处理流程。

    1.9K20编辑于 2022-08-02
  • 来自专栏小黑娃Henry

    RunLoop源码阅读RunLoop源码阅读

    livePort == dispatchPort) { //通过线程的私有方法里添加gcdMain _CFSetTSD(__CFTSDKeyIsInGCDMainQ, (void *)6,

    1.5K20发布于 2021-08-09
  • 来自专栏做不甩锅的后端

    Druid源码阅读6-PreparedStatementPool源码及使用场景分析

    阅读DruidDataSource源码的过程中,发现DruidConnectionHolder有个特别的属性PreparedStatementPool statementPool。 final DruidAbstractDataSource dataSource; } LRUCache的结构: LRUCache本质上是一个LinkedHashMap,学习过LinkedHashMap源码就会知道 可以参考LinkedHashMap源码分析. public class LRUCache extends LinkedHashMap<PreparedStatementKey, PreparedStatementHolder 通过源码可以发现,作者特别喜欢通过Holder来对java sql包提供的对象进行扩展。当然这也与druid连接池的定位是分不开的,druid最大的有点就是其监控功能非常完善。 6.总结 关于PreparedStatementCache的使用,在Druid中实际上cache是Connection级的。每个连接一个Cache。 一般在mysql中不建议使用这个Cache。

    1.5K20发布于 2021-11-17
  • 来自专栏多线程

    MyBatis源码阅读(一) --- 源码阅读环境搭建

    一、简介 使用Mybatis有一段时间了,但是一直没有专门去阅读MyBatis框架的源码,Mybatis是一个非常值得我们去阅读的框架,源码里面运用了很多常见的设计模式,如构建者模式、代理模式、模板方法模式等等 下面我们就以搭建一个源码阅读环境开始,一起来看看Mybatis的源码。 MyBatis 是一款优秀的持久层框架,它支持自定义 SQL、存储过程以及高级映射。 下面我们搭建一个简单的Mybatis 源码Debug环境。 } catch (IOException e) { e.printStackTrace(); } finally { //6、 通过上面的示例,我们总结一下Mybatis使用的大体流程,如下图所示: 可以看到,主要分为了如上图的几个步骤,这几个步骤也是Mybatis的核心了,所以我们阅读源码也是从这几个部分切入,逐步逐步去了解里面的实现细节

    52310编辑于 2023-12-22
  • 来自专栏服务端技术杂谈

    InheritableThreadLocal源码阅读

    查看InheritableThreadLocal源码 重写了getMap和createMap方法。

    82540发布于 2018-04-17
  • 来自专栏樯橹代码

    阅读redux源码

    redux源码解析 什么是redux Redux 是 JavaScript 状态容器,提供可预测化的状态管理。 源码解析 注意: 如果没有使用过redux,建议先去看看redux文档 api方法 export { createStore, combineReducers, bindActionCreators

    1.1K10发布于 2019-09-02
  • 来自专栏个人分享

    SparkContext源码阅读

    SparkContext是spark的入口,通过它来连接集群、创建RDD、广播变量等等。

    1.1K20发布于 2018-09-06
  • ConcurrentHashMap 源码阅读

    ConcurrentHashMap源码阅读1.ConcurrentHashMap1.71.存储结构Java7中ConcurrentHashMap由很多个Segment组合,而每一个Segment是一个类似于 3.put接着上面的初始化参数继续查看put方法源码。展开代码语言:JavaAI代码解释/***Mapsthespecifiedkeytothespecifiedvalueinthistable. ss,u))==null){//使用CAS赋值,只会成功一次if(UNSAFE.compareAndSwapObject(ss,u,null,seg=s))break;}}}returnseg;}上面的源码分析了 3.put直接过一遍put源码。 4.getget流程比较简单,直接过一遍源码

    6910编辑于 2026-02-20
  • 来自专栏海涛技术日常

    ThreadLocal源码阅读

    每个线程独有一个 Map,Map里的存储结构为 Entry <ThreadLocal,Object> 数组

    64810发布于 2019-12-16
  • 来自专栏seth-shi的专栏

    PHP 源码阅读

    已挂载进容器 docker-compose exec centos bash php-fpm nginx # 查看 worker 进程号 ps aux | grep fpm gdb --pid=xxx 阅读工具 推荐使用Understand 尝试过CLion和Visual Studio 很多代码都不能进行跳转 需自行下载一个与Dockerfile中PHP版本相同的源码用于阅读 增加扩展(可选) 依赖 下载已经安装的 PHP按本的PHP源码 进入扩展源码目录比如curl cd ~/php71/ext/curl 执行phpize(编译PHP扩展的工具,主要是根据系统信息生成对应的configure文件) /var/ │ │ │ │ │ │ │ │ │ │ │ │ │ ───────┴──┴──┴──┴──┴──┴──┴──┴──┴──┴──┴──┴──┴─────────► -6 -5 -4 -3 -2 -1 0 1 2 3 4 5 6 │ │ │ │

    5.9K10编辑于 2023-12-18
  • 来自专栏全沾开发(huā)

    koa源码阅读

    koa源码阅读[0] Node.js也是写了两三年的时间了,刚开始学习Node的时候,hello world就是创建一个HttpServer,后来在工作中也是经历过Express、Koa1.x、Koa2 用的比较多的还是Koa版本,也是对它的洋葱模型比较感兴趣,所以最近抽出时间来阅读源码,正好近期可能会对一个Express项目进行重构,将其重构为koa2.x版本的,所以,阅读源码对于重构也是一种有效的帮助 image.png 小记 最近抽时间将Koa相关的源码翻看一波,看得挺激动的,想要将它们记录下来。 应该会拆分为几段来,不一篇全写了,上次写了个装饰器的,太长,看得自己都困了。 koa与koa-compose 热门中间件 koa-router与koa-views 杂七杂八的轮子 koa-bodyparser/multer/better-body/static 示例代码仓库地址 源码阅读仓库地址

    93110发布于 2019-12-09
  • 来自专栏服务端技术杂谈

    ThreadLocal源码阅读

    ThreadLocal源码比较简单,整体了解起来比较容易。

    92440发布于 2018-04-17
  • 来自专栏全沾开发(huā)

    ioredis源码阅读

    ioredis源码阅读[1] 上次针对 redis 的源码阅读涉及普通的 client,这次针对 cluster 模式下的 client 源码进行分析。 具体的源码路径就是在 lib/cluster 目录下了。 127.0.0.1", }, { port: 6381, host: "127.0.0.1", }, ]) cluster.get('someKey').then() 从源码上来看

    97510发布于 2021-04-08
  • 来自专栏flytam之深入前端技术栈

    reselect源码阅读

    reselect源码阅读 之前就听闻了reselect是一个用于react性能优化的库,并且源码只有100多行。 可谓短小精悍,今天来阅读一波膜拜大佬们的思想 import { createSelector } from 'reselect' const shopItemsSelector = state = 下面开始阅读探读部分 先说几个简单的工具函数吧 首先是默认的比较函数,代表比较方式,可以根据业务需求换的。默认是进行全等比较 /** * 默认的比较函数,只进行一层全等比较。

    65420发布于 2020-01-14
  • 来自专栏cc log

    Koa源码阅读

    toc Koa源码阅读 Koa使用 Koa整体调用流程 Koa 中间件“洋葱模型” Koa源码阅读 Koa使用 Koa整体调用流程 Koa 中间件“洋葱模型” Koa源码阅读 Koa 在众多NodeJs 框架中,以短小精悍而著称,核心代码只有大约570行,非常适合源码阅读。 本文就核心阅读中间件的源码。 Koa使用 中间件可以理解为插件,对于Koa来说,就是很简单的use()API。 Koa源码阅读 Koa 在众多NodeJs框架中,以短小精悍而著称,核心代码只有大约570行,非常适合源码阅读。 实际上核心来说,Koa主要是两块 中间件系统 对请求结构封装为更为易用的ctx对象。 本文就核心阅读中间件的源码。 Koa使用 中间件可以理解为插件,对于Koa来说,就是很简单的use()API。

    72810编辑于 2022-08-16
  • 来自专栏个人分享

    NIO源码阅读

      自己对着源码敲一遍练习,写上注释。发现NIO编程难度好高啊。。 public class TimeClient { 4 public static void main(String args[]){ 5 int port = 8080; 6 import java.io.IOException; 4 import java.net.InetSocketAddress; 5 import java.nio.ByteBuffer; 6 TimeServer: 1 package nio; 2 3 import java.io.IOException; 4 5 public class TimeServer { 6 import java.io.IOException; 4 import java.net.InetSocketAddress; 5 import java.nio.ByteBuffer; 6

    66640发布于 2018-09-06
  • 来自专栏歪歪梯Club

    Redis源码阅读

    把缩容一次后会聚拢到该bucket的bucket也遍历了,也就是idx与(idx + size/2) % size 比如size是8,缩容后就是4,所以对size为8的遍历就是 0->4 1->5 2->6 3->7 基于idx与idx + size/2这个公式得到的bucket 源码里把这用一个数学公式体现(反序+1后再反序) //每次从高位进1 000 0 -》 100 4 001 1 -》 101 5 010 2 -》 110 6 011 3- 》 111 7

    56920发布于 2021-10-11
  • 来自专栏阿杜的世界

    浅谈源码阅读

    经典的源码像诗,值得细细品味 1. 明确目的 阅读书籍和源码最好带着自己的问题和目的,这样可以避免“看了就忘”的尴尬状态。 读研期间,为了掌握嵌入式开发,读了很多Linux的内核源码,摸索清楚了一个Linux系统从系统加电到控制台出现的流程。 最近开始阅读RocketMQ的源码,目的有两个: 学习MQ的通用知识(可靠发送、可靠消费、顺序消息、消息优先级等等)、RocketMQ自己的实现,以及不同MQ之间的比较。 基本流程 源码阅读是有一定的套路的。 以RocketMQ为例,分享下我的方法: (1)我会先去学会基本的使用; (2)阅读官网的文档,了解该中间件的整体架构、核心概念; (3)梳理基本功能的实现,例如系统启动、发送消息、消费消息的过程; (

    53330发布于 2018-08-06
领券