重磅推荐:阿里大神的编码方法论赋能你我他.docx

上传人:A*** 文档编号:141583489 上传时间:2020-08-10 格式:DOCX 页数:19 大小:120.24KB
返回 下载 相关 举报
重磅推荐:阿里大神的编码方法论赋能你我他.docx_第1页
第1页 / 共19页
重磅推荐:阿里大神的编码方法论赋能你我他.docx_第2页
第2页 / 共19页
重磅推荐:阿里大神的编码方法论赋能你我他.docx_第3页
第3页 / 共19页
重磅推荐:阿里大神的编码方法论赋能你我他.docx_第4页
第4页 / 共19页
重磅推荐:阿里大神的编码方法论赋能你我他.docx_第5页
第5页 / 共19页
点击查看更多>>
资源描述

《重磅推荐:阿里大神的编码方法论赋能你我他.docx》由会员分享,可在线阅读,更多相关《重磅推荐:阿里大神的编码方法论赋能你我他.docx(19页珍藏版)》请在金锄头文库上搜索。

1、重磅推荐:阿里大神的编码方法论,赋能你我他Photo 文|陈昌毅导读Don Roberts 提出的一条重构准则:第一次做某件事时只管去做;第二次做类似的事时会产生反感,但无论如何还是可以去做;第三次再做类似的事时,你就应该重构。编码也是如此,当多次编写类似的代码时,我们需要考虑是否有一种方法能够提高编码速度。作者多年来致力于敏捷开发,总结了一套编码的方法论,有助于程序员快速、优质、高效地进行编码。方法1:手工编写代码大多数刚学习 Java 的程序员,都会怀着一种崇敬的仪式感,一字一句地在开发工具上敲出以下代码:public class Test public static void main(

2、String args) System.out.println(Hello world!); 没错,这就是经典的Hello world,这也是大多数人手工编写的第一个程序。手工编写代码,更能体现一个程序员的基本素质。有很多公司,都把上机编程考试作为面试的重要手段之一。面试者需要根据题目的要求,挑选一款熟悉的编程工具(比如Eclipse),手工编写代码并调试运行通过。在整个过程中,不能通过网络搜索答案,不能查看联机帮助文档,要求面试者必须手工编写代码,主要是考察面试者手工编写代码的能力语法、函数、逻辑、思维、算法以及动手能力。手工编写代码,是一个优秀程序员必须具备的基础能力。手工编写代码正如提笔

3、写文章,语法就是遣词造句的方法、函数就是组成文章的词句、类库就是据经引典的掌故、架构就是行文表述的体裁、功能就是写作文章的主旨、算法就是组织语言的逻辑所以,只要掌握一门程序语言的语法、学习一堆基础类库的函数、引用一些所需的第三方类库、选择一款成熟稳定的架构、明确一下产品需求的功能、挑选一种实现逻辑的算法手工编写代码就会像写文章一样手到擒来。方法2:复制粘贴代码常言道:熟读唐诗三百首,不会作诗也会吟。编码也是同样的道理,编码的第一步就是模仿,简单地说就是抄代码复制粘贴代码。复制粘贴代码是一门艺术,用好了编码会事半功倍。但是,没有检验过的东西,终究是不可全信的。当看到需要的代码时,在复制粘贴前,我

4、们都需要仔细研读、认真思考、详细甄别很多东西,都是仁者见仁、智者见智的东西,适合别的场景但不一定适合你的场景。作为一名合格的程序员,切不可一味地拿来主义。1.为什么要复制粘贴代码 复制粘贴现有代码,可以节省开发时间; 复制粘贴稳定代码,可以降低系统故障风险; 复制粘贴网络代码,可以把别人的成果化为己用。2.复制粘贴代码带来问题 你对复制的代码理解程度是多少?实现逻辑是否合理?能不能稳定运行?存在多少潜在的 Bug? 这个代码在项目中已经复制粘贴了多少次?根据“三则重构”原则,你是否需要对这些相同代码进行重构? 代码被复制粘贴次数越多,带来的代码维护问题越多。多个代码版本的更改和修正,要保持这些

5、代码的同步,就必须需要在每一处进行同样的修改,增加了维护的成本和风险。总之,复制粘贴代码,跟其它编码方法一样,没有优劣对错之分。它只是一种方法,你可以善用,也可以滥用。如果我们用到了复制粘贴,我们就必须为结果负责。方法3:用文本替换生成代码1.生成代码样例已经编写好的用户查询相关代码:/* 查询用户服务函数 */public PageData<UserVO> queryUser(QueryUserParameterVO parameter) Long totalCount = userDAO.countByParameter(parameter); List<UserVO&g

6、t; userList = null; if (Objects.nonNull(totalCount) && totalCpareTo(0L) > 0) userList = userDAO.queryByParameter(parameter); return new PageData<>(totalCount, userList);/* 查询用户控制器函数 */RequestMapping(path = /queryUser, method = RequestMethod.POST)public Result<PageData<UserVO&g

7、t;> queryUser(Valid RequestBody QueryUserParameterVO parameter) PageData<UserVO> pageData = userService.queryUser(parameter); return Result.success(pageData);如果我们要编写公司查询相关代码,其代码形式与用户查询类似,整理出替换关系如下: 把用户替换为公司; 把User替换为Company; 把user替换为company。利用 Notepad、EditPlus 等文本编辑器,选择区分大小写,进行普通文本替换,最终得到结果

8、如下:/* 查询公司服务函数 */public PageData<CompanyVO> queryCompany(QueryCompanyParameterVO parameter) Long totalCount = companyDAO.countByParameter(parameter); List<CompanyVO> companyList = null; if (Objects.nonNull(totalCount) && totalCpareTo(0L) > 0) companyList = companyDAO.queryByPa

9、rameter(parameter); return new PageData<>(totalCount, companyList);/* 查询公司控制器函数 */RequestMapping(path = /queryCompany, method = RequestMethod.POST)public Result<PageData<CompanyVO>> queryCompany(Valid RequestBody QueryCompanyParameterVO parameter) PageData<CompanyVO> pageData

10、 = companyService.queryCompany(parameter); return Result.success(pageData);利用文本替换生成代码,整段代码生成时间不会超过1分钟。2.主要优缺点主要优点: 生成代码速度较快。主要缺点: 必须编写样例代码; 只适用于文本替换的情景。方法4:用Excel公式生成代码Excel 的公式非常强悍,可以用于编写一些公式化的代码。1.利用 Excel 公式生成模型类从 WIKI 上拷贝接口模型定义到 Excel 里,样例数据内容如下:编写Excel公式如下:= /* &D6&IF(ISBLANK(F6), , (&a

11、mp;F6&)& */ &IF(E6 = 否, IF(C6 = String, NotBlank, NotNull), )& private &C6& &B6&利用公式生成代码如下:/* 用户标识 */ NotNull private Long id;/* 用户名称 */ NotBlank private String name;/* 用户性别(0:未知;1:男;2:女) */ NotNull private Integer sex;/* 用户描述 */ private String description;创建模型类,整理代码如

12、下:/* 用户DO类 */public class UserDO /* 用户标识 */ NotNull private Long id; /* 用户名称 */ NotBlank private String name; /* 用户性别(0:未知;1:男;2:女) */ NotNull private Integer sex; /* 用户描述 */ private String description; .2.利用 Excel 公式生成枚举类从 WIKI 上拷贝枚举定义到 Excel 里,样例数据内容如下:编写 Excel 公式如下:=/* &D2&(&B2&)

13、*/&C2&(&B2&, &D2&),利用公式生成代码如下:/* 空(0) */NONE(0, 空),/* 男(1) */MAN(1, 男),/* 女(2) */WOMAN(2, 女),创建枚举类,整理代码如下:/* 用户性别枚举 */public enum UserSex /* 枚举定义 */ /* 空(0) */ NONE(0, 空), /* 男(1) */ MAN(1, 男), /* 女(2) */ WOMAN(2, 女); .3.利用 Excel 公式生成数据库语句用 Excel 整理的公司列表如下,需要整理成 SQL 语句直接插入数据库:编写 Excel 公式如下:= (&B2&, &C2&, &D2&, &E2&),利用公式生成 SQL 如下:(高德, 首开大厦, (010)11111111, ),(阿里云, 绿地中心, (010)22222222, ),(菜鸟, 阿里中心, (010)33333333, ),添加 into 语句头,整理 SQL 如下:insert into t_company(name, address, phone, email) values(高德, 首开大厦, (010)11111111,

展开阅读全文
相关资源
相关搜索

当前位置:首页 > IT计算机/网络 > 其它相关文档

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号