杂谈篇之我是怎么读源码的,授之以渔

  • 时间:
  • 浏览:0
  • 来源:幸运快3_快3神彩_幸运快3神彩

前言

  开心一刻

    今天上课不小心睡着了,结果被老师叫起来回答大问题,这是背景。无奈之下看向同桌寻求帮助,同桌小声说到选C,结果附近的人都说选C,向同桌投去4个 感激的眼神后大声说道选C。刚说完教室就笑开了,老师一脸恨铁不成钢的表情说选你个头,我叫你翻译文言文你选C!你出去,你给我出去。看着同桌挤眉弄眼的表情,劳资真想说,这帮畜生

互相抱怨道:你是全是又长胖了?

  路漫漫其修远兮,吾将上下而求索!

  github:https://github.com/youzhibing

  码云(gitee):https://gitee.com/youzhibing

读源码的经历

  刚参加工作那会,没想过去读源码,更没想过去改框架的源码;总想着别人的框架应该是完美的、万能的,应该不都要改;另外即使我改了源码,怎样才能会样我想的改动生效了? 项目中引用的不还是没改的jar包吗。回想起来人太好 那前一天的想法人太好 挺......

  工作了一年多前一天准备跳槽了,前一天刚现在开始了了了一轮的面试,其蕴含十哪几个 面试官就问到了相关的源码大问题:ArrayList、HashMap的底层实现,spring、mybatis的相关源码。问源码的面试一般好多好多 回去等消息,但会 就没但会 了。那前一天前一天刚现在开始了了意识到,源码这东西在前一天的工作的中感受没人,但会 在面试中好像面的还挺频繁的,从此有意识的前一天刚现在开始了了了jdk每项源码的阅读(主好多好多 集合)。一前一天刚现在开始了了看源码,看的不得劲糙,知道个大概,知道ArrayList的底层实现是数组,HashMap的底层是散列表(数组+链表);更深入这一的扩容、hash碰撞等等就谁能谁能告诉我了。

  读spring源码起于工作中遇到了4个 大问题(spring jdbcTemplate事务,各种诡异,包你醍醐灌顶!),排查一段时间最终是补救了,但过程我想非常难受,各种上网查资料、各种尝试,感觉就像大海捞针一样,遥遥无期。我下定决心,我想看一看spring的源码,于是我买了一本《spring源码深度1解析》,结合着这本书、打开着eclipse,前一天刚现在开始了了了spring的源码阅读之旅。至此,读源码成了习惯,源码可能进入了我的心里。

  而是,springboot的火热,我想也想蹭上一蹭,于是有了springboot的启动源码系列,人太好 还在进行中,但会 我相信我想将其完成;工作中用到了shiro,我又结合着《跟我学shiro》将shiro的源码看到个大概,有了shiro源码系列博文,还差一篇认证与授权(应该越来太快就能面世),shiro源码系列就封笔了。最近在搭建此人 的后台管理系统,用到了quartz,集成的过程也遇到了这一大问题,但会 有了quartz的三篇文章

  慢慢的,从一味的网上找资料变成了好多好多 前一天会从源码中找答案。不求能读没人来越多的源码,但愿此人 接触的技术都能读上一读,路漫漫其修远兮,吾将上下而求索!

我为那先 读源码

  好多好多 人一定和我一样的感受:源码在工作蕴含用吗? 用处大吗?很长一段时间内我全是另4个 的大问题,认为那先 有事没事扯源码的人好多好多 在装,好多好多 为了提高亲戚亲戚朋友的逼格而已。

  那为那先 我想读源码呢? 一前一天前一天现在开始了了为了面试,而是为了补救工作中的大问题,再而是好多好多 此人 喜好了。说的好听点是有匠人精神;说的委婉点是好奇(底层是怎样才能会实现的);说的不自信点是对黑盒的东西我用的没底,怕用错;说的简单直白点是提升自我价值,为了更高的薪资待遇(这里对真正的技术迷说声抱歉)。

  源码中亲戚亲戚朋友都可不能能 学到好多好多 东西,学习别人高效的代码书写、学习别人对设计模式的熟练使用、学习别人对整个架构的布局,等等。可能你还能找出其中的过低,没人恭喜你,我想飞升了!会使用之好多好多 重要,但知道为那先 没人使用同样重要。从模仿中学习,从模仿中创新。

  读源码不像围城(外面的人想进来,上端的人想出去),它是外面的人你要进来,上端的人你要出去;当亲戚亲戚朋友跨进城内,我就发现(还是城外好,皮!)城内风光无限,源码的海洋任亲戚亲戚朋友遨游!

                 

  你想好入城何时能 能 ?

我是怎样才能会样读源码的

  内容了解

    首先亲戚亲戚朋友要对亲戚亲戚朋友的目标有所了解,知道她有那先 特点,这一那先 功能。对对方都还不了解,就想着进入别人的内心世界,那全是臭之好多好多 脸嘛,亲戚亲戚朋友要做4个 有着流氓心的绅士;对她有个大致的了解了,就都可不能能 发起攻势,一举拿出。

    没人怎样才能会样了解了,土土辦法 有好多好多 ,我这里提供几种,仅供参考

      最好的土土辦法 好多好多 官方参考指南,亲生父母往往对孩子是最了解的,对孩子的描述也是最完整性的;比如Spring Boot Reference Guide好多好多 对springboot最完整性的描述,怎样才能会样使用springboot、springboot底部形态等等,通过此指南,springboot在你转过身一览无遗;但会 ,springboot毕竟是外国人的孩子,可能英语不好,估计读起来不得劲头疼了,不过亲戚亲戚朋友有google翻译呀,咬咬牙也是能看的。源码世界的丈母娘、老岳丈是非常慷慨的!

      其次是书籍,国外优秀的有好多好多 ,国内好多好多 乏好书,比较推荐此土土辦法 ,自成体系,让亲戚亲戚朋友掌握的知识点不至于太散。这好多好多 好比是源码的闺蜜,对源码非常了解,重点是挺大方,会尽全力帮助亲戚亲戚朋友了解源码。

      再次好多好多 博客,人太好 可能人太好 知识点比较散,但会 针对某个知识点却不得劲的细,对彻底掌握非常有帮助,园子内全是好多好多 技术大牛,写的博客自然也是非常棒,非常具有学习价值。当然还有社区、论坛、github、码云等等。这好多好多 源码的亲戚亲戚朋友圈,亲戚亲戚朋友从中不能获取到非常多关于源码的信息。

  设计模式的了解

    优秀的框架、技术之好多好多 乏设计模式;jdk源码中就应用了好多好多 设计模式,比如IO流中的适配器模式与装饰模式、GUI的观察者模式、集合中的迭代器模式等等;spring源码中也是用到了几瓶的设计模式。设计模式有那先 优点、各适用于那先 场景,全是本文的内容,都要亲戚亲戚朋友亲戚亲戚朋友自行去了解。

    亲戚亲戚朋友只都要对这一常用的设计模式有个大致了解,再去读源码是比较好的;不都要将23种设计模式都通读,好多好多 都要将常用设计模式完整性理解透;对于完整性通读,亲戚亲戚朋友时间有限,另外这一模式人太好 不太好理解、用的少,性价比不高,没必要完整性都读。

    推荐书籍:《Head First Design Patterns》(中文版:《Head First 设计模式》)、《Java与模式》;

    常用设计模式:单例模式、工厂模式、适配器模式、装饰模式、外观模式、代理模式、迭代器模式、观察者模式、命令模式

    另外我比较推荐的四种 学习设计模式的土土辦法 是读别人博客:java_my_life刘伟技术博客chenssy的设计模式

    设计模式之于源码,就好比逛街购物之于男人的女人的女人,想顺利勾搭源码,亲戚亲戚朋友都要好好掌握设计模式这一套路。

  配合ide进行断点追踪

    亲戚亲戚朋友通过源码的圈子对源码的了解终究好多好多 停在皮下组织,终究还是没人走进她的内心,接下来我就和亲戚亲戚朋友分享下,我是怎样才能走进她的内心的!

    相信看到我的源码博客的小伙伴都知道,我非常喜欢通过idea断点来进行源码追踪,断点追踪源码是我非常推荐的四种 土土辦法 。断点不仅都可不能能 用来调试亲戚亲戚朋友的代码,也都可不能能 用来调试亲戚亲戚朋友用到的框架源码。面对未知的、茫茫多的源码,亲戚亲戚朋友往往没人足够的时间、经历和耐心去通读所有源码,亲戚亲戚朋友只都要去读亲戚亲戚朋友关注的每项即可(村里人 可能会说我全是关心,这...)。那为那先 要用断掉调试的土土辦法 来跟源码,而全是直接从源代码入手去跟亲戚亲戚朋友关注的每项呢?尝试过的小伙伴应该知道,可能亲戚亲戚朋友对源码粘壳悉,直接通过源码的土土辦法 去跟,一方面很容易迷路(多态,会有好多好多 子类实现),谁能谁能告诉我接下来跟哪4个 ,此人 面也很容易跟丢,当亲戚亲戚朋友跟入的深会的前一天,很有可能就忘记上一步跟到哪了。

    下面我会举例来说明我是怎样才能进行断点追踪的,以spring-boot-2.0.3之quartz集成,也没人你想的那样哦!spring-boot-2.0.3之quartz集成,数据源大问题,源码探究 为背景来讲,都要搞清楚4个 点:springboot是怎样才能向quartz注入数据源的,quartz是怎样才能操作数据库的

    springboot向quartz注入数据源

      QuartzAutoConfiguration是springboot自动配置quartz的入口

      将quartz的配置属性设置给SchedulerFactoryBean;将数据源设置给SchedulerFactoryBean:可能有@QuartzDataSource修饰的数据源,则将@QuartzDataSource修饰的数据源设置给SchedulerFactoryBean,但会 将应用的数据源(druid数据源)设置给SchedulerFactoryBean,显然亲戚亲戚朋友的应用中没人@QuartzDataSource修饰的数据源,没人SchedulerFactoryBean中的数据源好多好多 应用的数据源;将事务管理器设置给SchedulerFactoryBean。SchedulerFactoryBean,负责创建和配置quartz Scheduler,并将其注册到spring容器中。SchedulerFactoryBean实现InitializingBean的afterPropertiesSet土土辦法 ,上端有都可不能能 设置数据源的过程

      都可不能能 看到通过org.quartz.jobStore.dataSource设置的dsName(值为quartzDs)最一定会被替再加springTxDataSource.加scheduler实例名(亲戚亲戚朋友的应用中是:springTxDataSource.quartzScheduler)。springboot会注册4个 ConnectionProvider给quartz:4个 dsName叫springTxDataSource.quartzScheduler,有事务;4个 dsName叫springNonTxDataSource.quartzScheduler,没事务。

    quartz怎样才能操作数据库

      亲戚亲戚朋友通过停止定时任务来跟下quartz对数据库的操作

      发现quartz用如下土土辦法 获取connection

conn = DBConnectionManager.getInstance().getConnection(getDataSource());

      没人亲戚亲戚朋友的job中就都可不能能 按如下土土辦法 操作数据库了

      明确亲戚亲戚朋友的目的,找到大概的切入点,进入断点调试追踪也就容易了。

  任也许的天花乱坠,你仍无动于衷,那也好多好多 一厢情愿,没人局中人不能体会到其中的奥妙!

总结与感悟

  从上至下完整性通读的土土辦法 ,此人 不太推荐,这是建立在粘壳悉的基础上的,当亲戚亲戚朋友对某个框架可能比较熟悉了,再从上至下进行通读,彻底了解,这是我认为正确的土土辦法 ;但会 之好多好多 熟悉到熟悉这一过程,此人 不推荐完整性通读,好多好多 推荐上端我推荐的土土辦法 - 断点局部追踪。

  好多好多 前一天,亲戚亲戚朋友的博文都好多好多 授之以鱼,而亲戚亲戚朋友也好多好多 从中得到鱼;而这篇的目的则是授之以渔,但会 亲戚亲戚朋友从中学到捕鱼的土土辦法 ,而全是一味的听候别人的鱼;希望亲戚亲戚朋友不能自给自足,不能把鱼和渔都授予此人 。

  但会 亲戚亲戚朋友前一天刚现在开始了了去读源码,慢慢的就会形成此人 的一套读源码的土土辦法 ;每此人 的土土辦法 全是一样,大概此人 的才是最好的。行动起来,用大概的土土辦法 去俘获你的的她吧!

  纯属此人 之拙见,不喜请喷!