换公司如何快速切入软件项目工程
一、前言
作为程序员,根据自身职业发展,会通过跳槽谋求更进一步的发展,这时进入新公司,接触全新的项目工程和业务,如何快速的切入,形成认识呢?就算不跳槽,公司业务调整,也难以避免接触新项目,此时快速阅读项目工程源码的技能就很必要,这里小生不才,整理一下我的一些经验,抛砖引玉。
二、思路先行
还是遵循“思路先行”的原则,接触新项目工程,有如下思路:
1)软件框架和核心业务两手抓。
2)由整体到局部:先熟悉整体框架,再走读具体业务代码。
3)由主到次:核心业务代码先熟悉,再理解普通业务
4)简单到复杂:可以以简单的模块进行代码阅读,对框架建立认识,然后再啃复杂代码。
5)LLM辅助代码走读、注释。
三、软件框架
先熟悉软件框架,对于后续业务代码走读和理解有非常大的帮助,如平台的一些机制和API的理解。软件框架一般包含哪些东西,那就是我们要梳理对应的:
-
系统架构图、模块框图
-
分层结构:理清上下层关系
-
进程模型or线程模型
-
系统平台机制:定时器、事件通知、调试手段
-
上下文整理:核心线程,整理上下文入口,梳理调用链
-
进程间通信手段
-
配置管理:用户配置、数据库技术
-
事件通知机制:RPC、notify机制
-
业务模块:先关注有哪些模块,后续逐个学习
-
编译框架熟悉,机型配置管理和生效过程,衍生机型配置如何区分
梳理完成上述内容,基本对于软件框架就有基本认识,基本可以输出一张软件框架图,然后再展开核心业务代码学习。
关于如何快速进行代码走读,已在此文章整理过,可查阅:
https://blog.csdn.net/qq_40036519/article/details/149154971?spm=1001.2014.3001.5502
代码走读找准几个上下文的函数入口整理调用链条,根据数据结构了解核心业务逻辑,以核心模块走对对框架有个了解,然后逐步学习各模块。代码走读可以使用LLM给出代码阅读和注释。
四、业务学习
这里的目的是快速获取业务知识,通过以下途径:
- 多问
业务学习的一大技巧就是**“多问”**,并且要不耻下问,因为业务知识网络上可能搜索不到,自己又无法琢磨,此时就需要向公司内部专家多问。以快速获取知识为目的。
- 项目文档等已有资源获取
先获取项目文档,提升效率,不要怕,勇敢去问上级是否有相关资料文档,虽然可能很多公司文档都不健全。
- 代码走读
走读核心代码,熟悉业务,此时注意带着问题去走读,理解背后的设计原理和问题背景。管中窥豹,可见一斑。
- 历史修复问题列表
根据历史问题修复的跟进记录,和一些开发任务的过程记录,辅助学习。
五、一些技巧
- 注重已有资源获取:设计文档、系统框图、过程记录等资料获取。
- 思路先行、巧用LLM辅助代码阅读和注释。
- 学习笔记输出: 输出核心代码调用逻辑图、软件框架图、核心业务学习笔记。