左耳听风_100_99_高效学习如何学习和阅读代码

你好,我是陈浩网名,做我个house.这节课呢我想来谈一谈如何学习和阅读代码。

杰夫阿特伍德啊说过这么一句话,code tell you how comments tell you why.那我把它扩展一下呢,就是代码会告诉你what how和details.而文档和书呢会告诉你what how和why可见啊,代码并不会告诉你,y看代码呢只能靠猜测或者推导来,估计y是揣测不准确,所以呢也会有很多的误解。

而且呢我们每个人都知道外啊是能让人一通百通的东西,也是能让人醍醐灌顶的东西。

但是呢代码它会告诉你细节,那这个呢是书和文档不能给你了,细节是魔鬼,细节决定成败。

这样的话我们不但听过很多啊,我们做技术的也应该体会过很多。

当然呢我们也要承认这些代码细节给人带来的快感,毕竟不如知道y以后的快感。

大书和文档呢是人对人说的话,而代码呢是人对机器说的话。

所以说如果你想知道人为什么要这么搞,那么应该参考资料:https://51gx.top/detail/254去看书看文档。

而如果你要知道机器它到底干了什么,那你呀就应该看代码。

因此啊我认为都比较重要。

那关键呢是看你的目的是什么。

那如果你想了解一种思想、一种方法、一种原理、一种思路、一种经验,那恐怕读书和读文档会更有效率一些。

因为其中呢会有作者的思路描述,像effective c加加之类的书啊,里面就有很多的对不同用法和设计的推敲。

Tcpip详解里面呢也会有对TCP算法好坏的比较。

那这些思维方式啊能让你对技术的把握力更强,而光看代码很难达到这种级别。

但是如果你想了解的就是具体的细节,比如说某一个协程的实现,某一个模块的性能,还有某个算法的实现。

那么你还是要去读代码的。

因为代码中呢会有更具体的处理细节啊,尤其是对于一些educase或者代码技巧方面的内容。

另外呢通过接下来这几个现象,你可以自己比较一下。

第一呢就是很多时候我们去读代码,是因为没有文档或者文档写的太差。

第二,很多时候啊在google stackorle flow还有github之后啊,你会发现你掌握的知识啊就是一块一块的碎片,既不系统也不结构化,更别说融会贯通了。

你会觉得自己需要好好的读一本书,系统的掌握知识。

你的这种感觉啊一定很强烈吧。

第三呢就是很多时候在读别人代码的时候啊,你会因为基础知识或者原理不懂,或者说你在不知道为什么的情况下,要么就完全读不懂代码,要么会误解代码。

比如说如果你没有c语言和TCP原理方面的基础知识啊,就根本读不懂linux下面TCP的相关代码。

我们因为误解代码用意而去修改代码所造成的故障还省吗?第四啊,在很多时候你看到一个算法或者一个设计的时候啊,比如说penxils,你是不是会想去看一下这个算法的实现代码是什么样的,思考一下如何才能实现的好呢?第五很多时候呢,当你写代码的时候,你能感觉得到自己写的代码有点别扭啊,怎么写都别扭。

那这个时候呢,你也会有想去看别人代码是怎么实现的冲动。

那类似的情况呢还有很多,但是到底从代码中收获大,还是从书里面收获到在不同的场景,不同的目的之下,会有不同的答案。

那这里啊我还是谈一谈人的学习过程吧。

从学习的过程中啊,我们来分析一下看代码和看书这两个活动。

那人对新事物的学习过程啊,基本上都是从感性认识到理性认识的那如果你是个新手啊,那应该多读代码,多动手写代码。

因为你需要的是感性认识,那这个时候理性认识呢,你体会不到,一是因为啊你没有切身的感受。

那即便告诉你why你也体会不到。

而另一方面呢这个阶段你要做的不是做漂亮,而是做出来。

所以说在新手阶段呢,你会喜欢get up这样的东西。

而如果你是个老手,你有多年的感性认识了,那么你的成长呢需要更多的理性认识。

因为到这个阶段,一方面你会不满足于做出来,你会想去做更牛更漂亮的东西。

而另一方面呢,你知道的越多,你的问题呢也越多,你迫切的需要知道why.这时呢你就需要大量的找牛人交流。

所以说这个阶段呢你会喜欢读好书和文章。

但是呢对于计算机行业这个技术创新能力超强,技术种类繁多的行业来说啊,我们每个人啊都既是新手,也是老手。

那接下来呢我想来和你聊一聊如何阅读源代码。

很多人呢都问过我如何读代码,因为我在外企里工作的时间啊比较长,所以呢我经常接手一些国外团队写的代码。

我发现啊虽然老外写的代码比国人好一点,但是呢依然有文档缺失、代码注释不清、代码风格混乱等等一些问题。

那这些呢都是阅读代码的障碍。

在这里啊,我把我的一些阅读源代码的经验分享给你,希望能对你有用。

首先呢在阅读代码之前啊,我建议你需要有以下的这些前提再去阅读代码。

那这样呢你读起代码来啊会更顺畅。

那第一个呢就是相关的语言和基础技术的知识。

第二个呢是软件功能。

你先要知道这个软件完成的是什么样的功能,有哪些特性,哪些配置项,你需要先读一遍用户手册,然后呢让软件跑起来,自己先用一下,感受一下。

第三呢是相关的文档,读一下相关的内部文档啊。

Read me也好,release notes也好,design也好,ricky也好。

那这些文档呢可以让你明白整个软件的方方面面。

那如果你的软件没有文档,那么你只能指望这个软件的原作者还在,而且他还乐于交流。

那第四呢就是代码的组织结构,也就是代码目录中啊,每个目录是什么样的功能,每个文档是干什么的那如果你要读的程序啊,是在某种标准的框架之下组织的,比如说java spring框架,那么恭喜你,这些代码不难读了。

那接下来呢你要了解这个软件的代码是由哪些部分构成的。

我在这里呢给你一个列表供你参考。

第一呢是接口抽象定义,任何代码呢都会有很多的接口和抽象定义。

他描述的代码需要处理的数据结构或者业务实体,还有他们之间的关系。

那理清楚这些关系呢是非常重要的。

第二呢是模块粘合槽,我们的代码呢有很多都是用来联合代码的。

比如说中间件、promise模式回调,代理委托,还有依赖注入啊等等,这些代码模块间的粘合技术啊是非常重要的。

因为他们会把本来平铺之数的代码给分裂开来,让你不容易看明白它们之间的关系。

那第三呢就是业务流程,这是代码运行的过程。

一开始呢我们不需要进入细节,但是需要在高层搞清楚整个业务的流程是什么样的那在这个流程当中啊,数据是怎么被传递和处理的那一般来说呢我们需要画程序流程图或者时序处理图。

第四呢就是具体的实现。

当你了解了前面这三个方面的内容之后啊,相信你对整个代码的框架和逻辑啊已经有了总体的认识。

那这个时候呢,你就可以深入细节,开始阅读具体实现的代码。

那对于代码的具体实现呢,一般来说啊你需要知道下面一些事实。

那这样呢有助于你在阅读代码时啊找到重点。

第一就是代码逻辑,代码呢有两种逻辑,一种是业务逻辑。

那这种逻辑呢是真正的业务处理逻辑。

而另一种呢是控制逻辑。

这种逻辑呢只是用来控制程序流转的,而不是业务逻辑。

比如说flag之类的控制变量,多线程处理的代码,异步控制的代码,远程通讯的代码,还有对象序列化、反序列化的代码等等。

那这两种逻辑呢要分开很多代码之所以混乱,就是把这两种逻辑啊混在一起了。

第二呢是出错处理,根据二八原则,百分之二十的代码是正常的逻辑,而百分之八十的代码是在处理各种错误。

所以说你在读代码的时候呢,完全可以把处理错误的代码全部删除掉。

那这样呢就会留下比较干净和简单的正常逻辑的代码,排除的干扰因素呢就会更高效的读代码。

第三呢是数据处理。

只要你认真观察,你就会发现我们好多代码呢就是在那里倒腾数据。

比如说DAODTO,比如说jason、 XML这些代码呢冗长无聊啊,不是主要逻辑可以不理。

第四呢就是重要的算法。

一般来说呢我们的代码里啊会有很多重要的算法。

那我这里说的并不不一定是什么排序啊,或者搜索算法啊,可能是一些其他的核心算法。

比如说一些索引表的算法,全局为一ID的算法,信息推荐的算法、统计算法通度算法等等。

那这些比较核心的算法可能会非常难读,但它们往往是最有技术含量的部分。

第五呢是底层交互,有一些代码是和底层系统的交互。

那一般来说呢是和操作系统或者GVM的交互。

因此读这些代码通常需要一定的底层技术知识,不然呢很难读懂。

最后阅读代码的第五个前提呢是运行时的调试。

很多时候啊代码只有运行起来了,才能知道具体发生了什么事儿。

所以呢我们让代码运行起来,然后呢用日志也好,debug设置断点跟踪也好,实际看一下代码的运行过程,是了解代码的一种很好的方式。

那这里呢我总结一下阅读代码的方法。

首先呢一般采用自顶向下,从总体到细节的剥洋葱皮的读法。

其次呢画图是必要的程序流程图,调用时序图模块、组织图啊等等。

然后呢代码逻辑归一下类排出的杂音啊,主要逻辑才会更清楚。

另外呢一帮要跟踪一下代码,是了解代码在执行中发生了什么的最好的方式。

对了,阅读代码你需要一个很好的IDE.我记得以前读c和c加加代码的时候呢,有一个叫source inside的工具,就大大提高了我的代码阅读效率。

那说白了就是可以查看代码,相互间调用reference的工具。

那这方面呢,visual studio做的是非常好的。

好了,我总结一下今天的内容,我先跟你探讨的是读文档还是读代码分析对比了从文档和代码中啊各自能收获到哪些东西,然后呢给出建议。

如果你想了解思想方法和原理啊,读书和文档会更有效率。

而如果你想知道具体的细节啊,那还是应该读代码。

随后呢我分享了一些我阅读源代码的方法和技巧,希望能对你有启发。

下节课呢是高校学习系列的最后一篇,我将分享一下面对枯燥和量大的知识的时候啊,我们该怎么做?。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/37634.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

rk3568 rockit编译测试

前言 环境介绍: 1.编译环境 Ubuntu 20.04.6 LTS 2.SDK版本 rk3568_linux_5.10 3.单板 迅为itop-3568开发板 一、编译rockit组件包 rockit组件包在4.10版本需要手动编译,奈何我的版本怎么都编译不了,后来改用5.10版本才编译通过。 4.1…

存储请求地址但是使用时请求的是端口

baseURL默认全局加载一次,后续直接读取缓存 解决方案:

类和对象(封装、继承、多态、友元)

c面相对象的三大特性为:封装、继承、多态 c 认为万事万物都皆为对象,对象上有其属性和行为 一、类和对象(封装) (一)封装的意义 封装是c面相对象的三大特性之一 封装的意义: 将属性和行为…

实现List接口的ArrayList和LinkedList

package study;import java.util.*;public class day01_list {public static void main(String[] args) {// <Integer> 这个尖括号表示的是 Java 的泛型&#xff08;Generics&#xff09;// 泛型是 Java 5 引入的一项特性&#xff0c;它允许你在 类、接口和方法 中使用类…

网页如何快速被收录?

其实就是要要吸引搜索引擎爬虫更快地抓取你的网页&#xff0c;想让爬虫爬取网页&#xff0c;首要做的自然是创建并提交站点地图。站点地图是搜索引擎了解你网站结构的重要工具。它可以帮助爬虫更快地发现和抓取你网站上的所有重要页面。通过Google Search Console提交站点地图&…

网络编程常识

网络编程常识 网络编程常识一、 OSI七层模型对应 TCP/IP四层模型二、TCP协议 最后 网络编程常识 一、 OSI七层模型对应 TCP/IP四层模型 OSI七层模型TCP/IP四层模型应用层表示层会话层应用层传输层传输层网络层网络层数据链路层物理层网络接口层 物理层&#xff1a;主要定义物…

深度学习在目标检测中的革命性应用与进展

目标检测是计算机视觉领域的核心任务之一&#xff0c;它旨在从图像或视频中识别和定位感兴趣的目标。深度学习的出现极大地推动了目标检测技术的发展&#xff0c;提高了检测的准确性和效率。本文将详细探讨深度学习在目标检测中的应用&#xff0c;包括关键技术、算法进展、实际…

python编程题3

1. 将一个文件中的所有英文字母转换成大写&#xff0c;复制到另一文件中。 fiopen("ex01.py",r) foopen("f2.txt",w) for line in fi:lineline.upper()fo.write(line) fi.close() fo.close() 2. 将一个文件中的指定单词删除后&#xff0c;复制到另一个文…

mysql lpad函数和rpad函数的用法

1、lpad函数 -从左至右填充 lpad( string, padded_length, [ pad_string ] ) string 准备被填充的字符串&#xff1b; padded_length 填充之后的字符串长度&#xff0c;也就是该函数返回的字符串长度&#xff0c;如果这个数量比原字符串的长度要短&#xff0c;lpad函数将会把字…

Perl与CGI脚本:入门指南到Web页面生成

Perl是一种功能强大的编程语言&#xff0c;广泛用于文本处理和系统管理任务。它也是早期Web开发中用于编写CGI脚本的流行选择之一。CGI&#xff08;Common Gateway Interface&#xff09;是一个标准&#xff0c;定义了Web服务器与执行在服务器上的程序之间的交互方式。本文将详…

MobPush REST API的推送 API之批量推送

调用验证 详情参见 REST API 概述的 鉴权方式 说明。 频率控制 详情参见推送限制策略的 接口限制 说明。 调用地址 POST http://api.push.mob.com/v3/push/createMulti 推送对象 以 JSON 格式表达&#xff0c;表示一条推送相关的所有信息 字段类型必须说明pushWorkobje…

用JSZip,FileSaver 有现成cdn的http图片或者文件地址,弄成压缩包导出,解决如果文件名字都是一样的只导出一个图片或文件的方法

第一步先处理重名的数据 &#xff0c; 解决方法 &#xff1a;将相同名字的图片或文件后面加后缀数字作为区分 let arr [{name:图片一,url:http://cdn}, {name:图片一,url:http://cdn}, {name:图片二,url:http://cdn}]; // 创建一个对象来跟踪已经遇到的名称和它们的计数 le…

6. 较全的Open3D点云数据处理(python)

注意&#xff1a;以下内容来自博客爆肝5万字❤️Open3D 点云数据处理基础&#xff08;Python版&#xff09;_python 点云 焊缝-CSDN博客&#xff0c;这篇博客写的全且详细&#xff0c;在这里是为了记笔记方便查看&#xff0c;并非抄袭。 1.点云的读写 代码如下&#xff1a; …

ARM功耗管理软件之软件栈及示例

安全之安全(security)博客目录导读 思考:功耗管理软件栈及示例?WFI&WFE?时钟&电源树?DVFS&AVS?

php对接快手券码,扫码核销

快手本地生活-开放平台&#xff1a;https://open.kwailocallife.com/docs/dev 快手本地生活-商家中心&#xff1a;https://lbs.kuaishou.com/ll/merchant/login 实现功能&#xff1a;对接快手券码&#xff0c;实现在快手上购买券码&#xff0c;然后在自己开发的app上扫码核销&…

ubuntu22.04速装中文输入法

附送ubuntu安装chrome wget https://dl.google.com/linux/direct/google-chrome-stable_current_amd64.deb sudo dpkg -i google-chrome-stable_current_amd64.deb

磁盘扩容,新增磁盘

磁盘扩容 1.点击设置-硬盘-添加-按推荐添加磁盘 2.查看磁盘使用情况&#xff0c;未扩容之前&#xff0c;查看分区使用情况 [rootnode1 ~]# df -Th 文件系统 类型 容量 已用 可用 已用% 挂载点 devtmpfs devtmpfs 1.4G 0 1.4G …

干系人参与度矩阵

干系人参与度矩阵 干系人的定义干系人参与水平分类应用与策略总结 干系人参与度矩阵是用于评估项目干系人当前参与水平与期望参与水平之间差异的工具。以下是对干系人参与度矩阵的详细解释&#xff1a; 干系人的定义 在项目管理中&#xff0c;干系人指的是那些积极参与项目&am…

python中pip换源

目录 1. 背景2. Python 的 pip 换源2.1 临时换源&#xff08;命令行中使用参数&#xff09;2.2 永久换源&#xff08;修改配置文件&#xff09;2.2.1 Windows系统2.2.2 Linux/macOS系统 2.3 使用 pip-config 命令换源&#xff08;Linux/macOS 特定&#xff09; 3. 常用的 PyPI …

探索WebKit的革新之旅:HTML5新特性的卓越处理

标题&#xff1a;探索WebKit的革新之旅&#xff1a;HTML5新特性的卓越处理 摘要 WebKit作为许多流行浏览器的渲染引擎&#xff0c;包括Safari、Chrome和Epiphany&#xff0c;它在处理HTML5新特性方面扮演了重要角色。HTML5引入了一系列新特性&#xff0c;旨在改善网络应用的性…