首页
学习
活动
专区
圈层
工具
发布
    • 综合排序
    • 最热优先
    • 最新优先
    时间不限
  • 来自专栏波波烤鸭

    10】Spring源码-分析篇-AOP源码分析

    Spring源码-AOP分析 一、手写AOP回顾   本文我们开始讲解Spring中的AOP原理和源码,我们前面手写了AOP的实现,了解和自己实现AOP应该要具备的内容,我们先回顾下,这对我们理解Spring 我们来看看他做了什么事情 在registerOrEscalateApcAsRequired方法中会把上面的Java类注入到容器中。 代理类的结构   在上面的分析中出现了很多代理相关的代码,为了更好的理解,我们来梳理下Spring中的代理相关的结构 2.1 AopProxy   在Spring中创建代理对象都是通过AopProxy这个接口的两个具体实现类来实现的 @Aspect解析   然后我们分析下@Aspect注解的解析过程 @Override protected boolean shouldSkip(Class<? getAdvisor(...) to represent the "current position" in the declared methods list. // However, since Java

    1.1K50编辑于 2022-10-28
  • 来自专栏Java架构师必看

    spring源码分析10

    spring源码分析10 强烈推介IDEA2020.2破解激活,IntelliJ

    34930发布于 2021-04-13
  • 来自专栏golang算法架构leetcode技术php

    golang源码分析10)slice

    // maxSliceCap returns the maximum capacity for a slice.

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

    golang源码分析:etcd(10)

    分析完raft算法,回来看etcd server的代码就比较清晰了,我们从入口文件server/main.go开始 func main() { etcdmain.Main(os.Args tp.Run() for { in, err := tp.Listener.Accept() go tp.serve(in) proxy的实现是一个标准的tcp代理,源码位于

    43120编辑于 2023-09-09
  • golang源码分析:langchaingo(10

    除了RAG,我们也可以定义agentTool交给大模型调用,下面我们看一个调用的例子

    11210编辑于 2026-03-18
  • golang源码分析 :gopls(10

    分析完一个featureCommands后,其他的22个都是类似的。 它们的作用是将编辑器对源码的操作接口进行标准化,它的核心接口如下:‌ ‌文本同步‌ textDocument/didOpen、textDocument/didChange、textDocument/didClose (非 LSP 标准)‌ ‌缓存管理‌ View(文件快照)、Snapshot(模块状态缓存) ‌类型检查‌ Package(集成 go/types 和 x/tools/go/packages) ‌代码分析

    9910编辑于 2026-03-18
  • 来自专栏Postgresql源码分析

    Postgresql源码10)LWLockAcquire流程分析

    功能特点: 信号量驱动唤醒,不做spin 等锁形成队列,依次唤醒 与PGPROC结构耦合,多进程协作

    30120编辑于 2022-05-12
  • 来自专栏二进制文集

    Java LinkedHashMap 源码分析

    分析 内部结构 LinkedHashMap继承自HashMap,内部额外维护了一个Entry的双向链表,用于记录访问和插入顺序。

    61930发布于 2019-02-25
  • 来自专栏程序员奇点

    Java String 源码分析

    Java String 源码分析 定义 Java 8 中 String 源码 public final class String implements java.io.Serializable String 是final 类型不能被继承,同时实现了 java.io.serializable Comparable charSequence 三个接口。 static final long serialVersionUID = -6849794470754667710L; String 实现了 Serializable 接口,支持序列化和反序列化支持,Java 使用字节数组来构建 String Java 中,String 实例中报错一个字符数组,char[] 字符数组时以 unicode 码来存储的。 假设一个方法从某个地方取得了一个很长的字符串,然后对其提取其中的一个小段内容,代码如下: String longStr = "....averylongstring"; String partStr= longStr.substring(10,30

    55810发布于 2020-10-23
  • 来自专栏二进制文集

    Java Stream 源码分析

    前言 Java 8 的 Stream 使得代码更加简洁易懂,本篇文章深入分析 Java Stream 的工作原理,并探讨 Steam 的性能问题。 image 源码结构 Stream 相关类和接口的继承关系如下图所示: ? image 操作叠加 Stream 的基础用法就不再叙述了,这里从一段代码开始,分析 Stream 的工作原理。 GC的行为是Java中很不好控制的一块,为增加确定性,我们手动指定使用CMS收集器,并使用10GB固定大小的堆内存。 具体到JVM参数就是-XX:+UseConcMarkSweepGC -Xms10G -Xmx10G JIT(Just-In-Time)即时编译技术。

    59241发布于 2020-12-08
  • 来自专栏大数据学习笔记

    Java HashSet源码分析

    1、源码分析 废话不多说,直接上代码,相关解释请参见注释 package java.util; /** * * @param <E> the type of elements maintained HashMap * @since 1.2 */ public class HashSet<E> extends AbstractSet<E> implements Set<E>, Cloneable, java.io.Serializable s) throws java.io.IOException { // Write out any hidden serialization magic s) throws java.io.IOException, ClassNotFoundException { // Read in any hidden serialization 通过源码可知,HashSet实际上由HashMap支持实现。它不保证set 的迭代顺序;特别是它不保证该顺序恒久不变。

    35510编辑于 2022-05-06
  • 来自专栏二进制文集

    Java Stream 源码分析

    前言 Java 8 的 Stream 使得代码更加简洁易懂,本篇文章深入分析 Java Stream 的工作原理,并探讨 Steam 的性能问题。 操作分类详情如下图所示: [2020-12-03-030958.jpg] 源码结构 Stream 相关类和接口的继承关系如下图所示: [2020-12-03-031525.jpg] BaseStream [2020-12-03-033401.png] 操作叠加 Stream 的基础用法就不再叙述了,这里从一段代码开始,分析 Stream 的工作原理。 GC的行为是Java中很不好控制的一块,为增加确定性,我们手动指定使用CMS收集器,并使用10GB固定大小的堆内存。 具体到JVM参数就是-XX:+UseConcMarkSweepGC -Xms10G -Xmx10G JIT(Just-In-Time)即时编译技术。

    3.4K53发布于 2020-12-03
  • 来自专栏全栈程序员必看

    Java volatile源码分析

    而针对volatile修饰的变量给java虚拟机特殊的约定,线程对volatile 变量的修改会立刻被其他线程所感知,即不会出现数据脏读,从而保证数据的一个可见性。 volatile 特性分析 特性一:可见性 前面介绍Java内存模型的时候,我们说过可见性是指当一个线程修改了共享变量的值,其他线程立即感知到这种变化。 特性二、禁止重排序 前面介绍Java 内存模型的时候,我们说过java中的有序性可以概况为一句话:如果在本线程中观察,所有的操作都是有序的;如果在另外一个线程中观察,所有的操作都是无序的。

    35150编辑于 2022-09-09
  • 来自专栏wannshan(javaer,RPC)

    java ThreadLocal 分析by 源码

    可以,通过inheritableThreadLocals属性子线程可以继承父线程的local变量,具体通过InheritableThreadLocal

    49730发布于 2021-03-18
  • 来自专栏后端Coder

    java进阶|java队列源码分析

    今天我要分享的是java里面比较常见的数据结构队列的源码分析,队列,先进先出模式,即FIFO的特点,日常生活中队列的特点也随处可见,超市购物排队,餐厅排队买饭等一系列都满足了队列的先进先出的特点,java 也不是,主要是之前我自己分析了ArrayList,LinkedList以及Stack的源码文章了,到这里就理所应当的应该分析队列的这种数据结构了,满足一下学生时代心心念的数据结构吧。 说了这么多,接下来就逐渐去分析队列的源码吧,写到这时下起了小雨,对,这个时间段是晚上十点左右,这篇文章是自己继五一放假来的第一篇文章,自己玩着玩着手机就突然想起了要写这篇文章了,索性就过来写了,要是学生时代这么努力多好 关于读源码,如何进行梳理整个过程,每个人都有着自己的一套,在这里我就以自己的一套来进行分析好了。 十,到这里就结束了自己对队列的源码分析,其实你会发现我这里没有对队列的每一个方法进行分析,其实都差不多,这里起到一个开头作用就可以了,下面的每个分析方法都差不多。

    97820发布于 2020-05-26
  • 来自专栏技术杂货店

    java集合【10】——— LinkedList源码解析

    浅拷贝 实现Serializable,可以被序列化和反序列化 下面是LinkedList的结构,注意:指针结束指向的是node,开始的是prev或者next [20201129152058.png] 源码定义如下 checkElementIndex(index); return node(index).item; } 在上面的代码中调用了通过索引位置查找节点位置的函数,下面我们来分析一下这个函数 Object o) { return remove(o); } 5.15 removeLastOccurrence(Object o) 移除元素,最后一次出现的地方移除掉,和前面分析的一样 LLSpliterator<E> implements Spliterator<E> { // 分割长度增加单位 static final int BATCH_UNIT = 1 << 10 private void writeObject(java.io.ObjectOutputStream s) throws java.io.IOException { /

    56300发布于 2020-12-05
  • 来自专栏EffectiveCoding

    Java Concurrent AQS原理&源码概要(Java 10

    一点闲扯 开始说AQS之前,继续说上一篇没说完的建议,相对于看一些不知道时效性的blog,说实话,理解一个知识点最简便的方式就是看论文及源码实现了,解决一个问题最好的方式就是看官方文档及源码,没有什么答案是在源码里找不到的 切身体会,关于Concurrent的论文,The java.util.concurrent Synchronizer Framewor,大家如果有需要可以私信。 AQS 源码实现 AQS 全称AbstractQueuedSynchronizer,是CountDownLatch/FutureTask/ReentrantLock/RenntrantReadWriteLock 还有另一个类叫做AbstractQueuedLongSynchronizer,这是不知道为什么之前看过的所有blog都没有提到,看了下官方文档这个是Java 8之后的实现,一个64位版本。 ,使用VarHandle实现,具体VarHandle介绍可以参考上一篇《Java Concurrent Atomic(JDK 10)》。

    82930发布于 2019-07-31
  • 来自专栏python编程军火库

    10 | Tornado源码分析:Gen 对象(上)

    话不多说我们先看一下源码(我已经进行过整理的源码,主要方便大家去理解里面的实现逻辑,若想看完整的源码建议大家可以自行查看本机安装的 tornado 版本中的源代码) # -*- encoding: utf /usr/bin/python """ @File : gen_ll.py @Time : 2020/08/29 15:10 @Author : haishiniu @Software:

    80820发布于 2020-09-01
  • 来自专栏后端Coder

    java进阶|PriorityQueue源码分析

    源码,倒是觉得它就是一个线程安全的队列,所以后面打算分享一下吧,谁让当时理解不了那个知识点呢,后面再说了,后面自己就写了java的等待通知机制的文章和限流的文章,所以这是今天写的第三篇文章了,好了,好了 ,不闲扯了,这里我就来分析了优先级队列的源码,因为我理解了里面的内容,不写出来总觉得没有掌握这个内容,其实也不是,可能是写文章写多了,不写总觉得不习惯,是的,不习惯。 0x02,步入主题 一般,我在分析源码的时候总是从构造函数入手,想起构造函数还是想起了要写一篇如何创建java对象的文章吗,不知道,还是在自己的内心沉淀一段时间再说吧,毕竟写文章是需要很花费一个人很长的时间的 )/offer()方法 0x05,上浮方法 0x06,peek()/contains()方法 0x07,size()/clear()方法 0x08,poll()方法 0x09,下沉方法 0x10 ,我的程序 0x11,总结 分析了优先级队列也算是源码系列的文章正式暂时告一段落了,这是第15篇源码分析的文章,最近也在思考一下这两年的点点滴滴,如果自己有时间以及自己如果思考的有意义的话语,自己会单独写一篇这两年的点点滴滴分享一下

    42520发布于 2020-07-02
  • 来自专栏后端Coder

    java之CopyOnWriteArraySet源码分析

    上篇我们分享了CopyOnWriteArrayList的源码分析,这次我们打算来分享 CopyOnWriteArraySet的源码分析,当自己整理了一下源码流程时发现这篇文章没什么写头,底层是在基于利用 package com.wpw.asyncthreadpool; import java.util.concurrent.CopyOnWriteArraySet; public class CopyOnWriteArraySetTest 我们看下在CopyOnWriteArrayList源码里面我们没有介绍到的containsAll()方法,由于这篇讲的是set,但是底层还是使用的是CopyOnWriteArrayList,所以我们这里继续分析 destPos, int length); 我们看上面的方法修饰符是由native关键字修饰的,所以它是在本地方法栈执行的,不是在java 到这里我们的分享内容就结束了,今天写了CopyOnWriteArrayList的姊妹篇 CopyOnWriteArraySet的源码分析,其实底层实现是基于CopyOnWriteArrayList的,喜欢文章的可以关注公众号

    60320发布于 2019-11-05
领券