`
shangjava
  • 浏览: 1236652 次
  • 性别: Icon_minigender_1
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

代码审查的对话

Web 
阅读更多


最近一个朋友和我在雅虎上讨论关于代码审查( Code Review),摘要贴出来:

朋友 : 你们对于代码也review么?

朋友 : 呵呵。

summerfang : 很密集

summerfang : 我每个星期自己做3-4

朋友 : 现在我碰到的问题是,有些新手的注释不规范。

朋友 : 这是要强制要求的是么?

summerfang : 代码review是个好办法

朋友 : 如果少写了,重写是么?

summerfang : 没有在所有的地方完全强制。

朋友 :

summerfang : SPEP是强制的

朋友 : 类 和 方法, 函数是强制的么?

朋友 :

朋友 : 但是里面呢?

summerfang : Review有几种

summerfang : 一般性的Review

朋友 : 嗯,侧重不同是吧

summerfang : 比如,代码风格Review,适合周期性的Review

朋友 :

朋友 : 你们一般是抽查,还是大覆盖面的查啊?

summerfang : Review之前通常有些通用规则,如不能Hardcode等等

朋友 :

朋友 : 这个是有的。

summerfang : 随机

朋友 :

summerfang : 主要是针对问题

朋友 :

朋友 : 知道你的意思了。

summerfang : 比如每个SP我会抽5Bug review

summerfang : 总的来说,根据需要,做出可行的Review计划

朋友 : 哦。明白了。

summerfang : 另外,如果做了,就一定要坚持

summerfang : Code Review非常有效

朋友 : 哈哈。这个难。

summerfang : :)

朋友 : 不过,没收效前还是要坚持的。

summerfang : 我现在Review上瘾

朋友 : 哈哈

朋友 : 也能看到不少精华啊。

summerfang : 问题居多

summerfang : 对我自己也是挑战

summerfang : 很多人的代码呀

朋友 : 呵呵

朋友 : 那是

朋友 : 不够水平的看也看不出啥来。

summerfang : 还好现在问题还比较明显:)

代码审查是提高代码质量的良药。但良药苦口,也有很多问题。

首先,没有习惯代码审查的开发员的心理抵触。当指出代码中的问题时,很多程序员会感到难堪。特别是不直接影响程序功能的代码,比如,不良代码风格。另外,现在的软件开发常常是多人维护的,如果不良代码是别人写的,总感觉象代人受过一样。这时,不得不反复说明,代码审查目的是帮助找到问题,而不是将某人的军。也正是因为这些原因,很多项目负责人不愿意推动代码审查,要不,就搞得太正式。

其次,如果代码审查没有目标,则很容易使得代码审查变得很无趣,变成了程序逻辑报告会。通常,我在代码审查之前,心理尽量有一个方向,比如今天主要看代码风格,或安全问题等。这样容易找出问题。如果能在一个公共可访问的Web site写上一个检查列表,审查之前表态:今天主要审查这些条目,那会更有效。

还有,代码审查的目的是有分类的,不同的审查有不同的焦点。如:

以审查代码风格为主的审查。这种审查,适合周期性举行。

以审查程序逻辑的审查。审查程序逻辑,建议在设计之初,实现中,结尾时各做一次。

以审查特定目标的审查,如安全等。最好辅助工具,如不安全函数列表扫描等。

应该还有很多要点,暂时写到这儿。

分享到:
评论

相关推荐

    forum:中央存储库,用于协调牛津大学研究人员之间的代码审查

    该存储库是组织牛津大学代码审查的中心。 如果您希望其他人查看您的代码,只需打开一个带有简短代码说明的问题。 如果您想自愿查看一些研究代码,只需在相应的问题上发表评论,以使作者知道您可以查看他们的代码。 ...

    基于百度文心一言语言大模型的智能文本对话AI机器人API,支持聊天对话、行业咨询、语言学习、代码编写等功能

    它可能可以辅助用户解决编程问题,提供代码示例,甚至进行代码审查,以提升开发效率。 “软件/插件”标签暗示了这个API不仅可以作为一个独立的服务被调用,也可能有配套的软件或插件形式供用户下载安装,以便更方便...

    AgileReview-EclipsePlugin:Eclipse IDE 的 AgileReview 代码审查插件。 不稳定!

    AgileReview-EclipsePlugin 是一个专门为 Eclipse IDE 设计的代码审查插件,旨在提升软件开发团队的敏捷开发实践。这个插件的主要目的是帮助开发者进行更高效、更灵活的代码审查过程,以确保代码质量并促进团队间的...

    代码大全(第2版)中文版

    1. 代码审查:强调代码审查在提升团队代码质量中的作用,提供了有效的代码审查流程和技巧。 2. 对话与文档:提倡有效的技术沟通,讨论了编写技术文档和进行有效会议的方法。 五、持续学习与成长 1. 软技能:除了...

    Empathetic-COAI-Papers:这是一个用于审查和讨论共情对话式AI领域最新技术论文的资料库。 提供每篇论文的相关源代码(如果有)

    如果有的话,将提供每篇论文的相关源代码。免责声明此存储库中的评论完全基于个人意见和理解; 由于我在自然语言处理和移情对话的生成领域进行了几个月的研究,因此不能保证所提供的想法或批评是完全准确的。 如果...

    如何用ChatGPT写代码.zip

    2. **代码审查**:ChatGPT提供的代码可能需要进一步检查和调整,因为它可能无法考虑到所有细节。例如,它可能不会处理边界条件或优化性能。因此,收到代码后要仔细审查,确保其符合项目需求和最佳实践。 3. **上...

    Cursor:AI 驱动的编程工具

    2.降低错误率:Cursor 的代码审查和自动修复功能,有助于避免常见的编程错误,确保代码更加健壮。 3.增强代码可读性:AI 的优化建议不仅提升了代码的性能,还能帮助开发者编写更加简洁易读的代码。 4实时反馈与协作...

    VC++统计有效代码行数的计算器

    此外,它还可以作为代码审查的一部分,以便评估代码的可读性和维护性。 总的来说,“VC++统计有效代码行数的计算器”是一个实用的辅助工具,它结合了C++的文件操作、字符串处理和GUI编程技术,为开发者提供了一种...

    powertalkbox原代码改进4月一日下午

    2. **代码审查**:在团队中,修改后的代码通常需要经过代码审查,以确保代码质量,遵循编码规范,并且没有引入新的bug。 3. **性能优化**:代码改进的一个常见目标是提升软件性能,可能包括减少内存占用、加快运行...

    code review 怎么做

    Code Review,也称为代码审查,是软件开发过程中的一个关键环节。它旨在通过同行或者其他有经验的开发者对源代码进行检查,以发现潜在的错误、提高代码质量、增强团队合作和知识分享。以下是对"code review 怎么做...

    GitHub中文语言排行榜图表展示

    开发者可以提交代码、创建分支、对话讨论、提出问题、执行代码审查等。 项目管理:GitHub提供了一系列项目管理工具,包括任务追踪、项目看板、里程碑、文档管理等。这些工具可以帮助团队组织和管理项目,提高工作...

    pull-request-review-guide::person_in_lotus_position::laptop_computer::person_in_lotus_position:更好,更快的请求请求审查指南

    在软件开发过程中,代码审查(Code Review)是确保代码质量、分享知识以及团队协作的重要环节。"pull-request-review-guide" 提供了一套实践指南,帮助开发者更好地进行代码审查,提高团队的工作效率。在这个指南中...

    Reviewable:支持可审核

    【标题】"Reviewable: 可审核代码审查工具" 【描述】"Reviewable是一个强大的代码审查平台,专为提升软件开发团队的协作效率而设计。它不仅提供了全面的代码查看和评论功能,还集成了Git和其他版本控制系统,使得...

    有效无痛苦的代码评审.pdf

    通过不断的代码审查,开发人员可以学习到不同的编程方法,并将其应用于未来的工作中。 #### 三、常见的误区 1. **多余且强制性的过程:** 开发人员有时会觉得代码评审是一个不必要的环节,是被迫参与的。 2. **...

    C ++:对话(以前:谁害怕C ++?)C++: A Dialog (formerly: Who's Afraid of C++?)

    - **代码审查**:与他人分享你的代码,并接受他人的审查,这是一个非常有效的学习过程。 ### 总结 对于没有任何计算机背景的新手来说,学习 C++ 可能会遇到一些挑战,但只要掌握了正确的方法和途径,就能够逐步...

    [大模型部署]在C# Winform中使用文心一言ERNIE-3.5 4K 聊天模型

    安全方面,一定要保护好API密钥,避免在客户端代码中硬编码,而是应该通过服务器端代理或者环境变量等方式安全地存储和使用。此外,由于模型可能会生成敏感或不适当的内容,需要添加内容过滤机制,对返回的结果进行...

    dlg.rar_Apk c_反编译 源代码_反编译得到cpp

    4. **代码相似度分析**:这个工具可能包含一种算法或库,用于计算代码片段之间的相似性,这对于代码审查、抄袭检测或优化代码重复性有重要意义。 5. **逆向工程**:反编译是逆向工程的一部分,可以帮助开发者了解...

    codestream:为远程团队构建的代码协作工具

    码流CodeStream可帮助开发团队讨论,查看和理解代码。...CodeStream 10的新增功能CodeStream现在支持在编辑器内对“拉取请求”创建,管理和执行代码审查。开发CodeStream 对CodeStream开发感兴趣吗? 查看 , , 或的开

    代码行数统计

    8. **持续集成/持续交付(CI/CD)**: 在CI/CD流程中,代码行数统计可以作为自动化测试和代码审查的一部分,以确保代码增量在合理范围内。 总结来说,"代码行数统计"是软件开发中的一个重要工具,它能提供关于项目规模...

Global site tag (gtag.js) - Google Analytics