外链代发包收录,纯手工外链代发就找老客外链吧

站长新闻

您的位置:老客外链吧 > 站长新闻 > IT >

10分钟学会6个阿里内部的编程方法,赋能你我他

文章来源:老客SEO 作者:老客SEO 人气:14 时间2019-11-07 11:00:24

编码也是如此,当多次编写类似的代码时,我们需要考虑是否有一种方法能够提高编码速度。作者多年来致力于敏捷开发,总结了一套编码的方法论,有助于程序员"快速、优质、高效"地进行编码。

10分钟学会6个阿里内部的编程方法,赋能你我他

 

方法1:手工编写代码

大多数刚学习 Java 的程序员,都会怀着一种崇敬的仪式感,一字一句地在开发工具上敲出以下代码:

10分钟学会6个阿里内部的编程方法,赋能你我他

 

没错,这就是经典的"Hello world",这也是大多数人手工编写的第一个程序。

手工编写代码,更能体现一个程序员的基本素质,是一个优秀程序员必须具备的基础能力。

有很多公司,都把上机编程考试作为面试的重要手段之一。面试者需要根据题目的要求,挑选一款熟悉的编程工具(比如Eclipse),手工编写代码并调试运行通过。在整个过程中,不能通过网络搜索答案,不能查看联机帮助文档,要求面试者必须手工编写代码,主要是考察面试者手工编写代码的能力——语法、函数、逻辑、思维、算法以及动手能力。

方法2:复制粘贴代码

常言道:"熟读唐诗三百首,不会作诗也会吟。"编码也是同样的道理,编码的第一步就是模仿,简单地说就是"抄代码"——复制粘贴代码。复制粘贴代码是一门艺术,用好了编码会事半功倍。但是,没有检验过的东西,终究是不可全信的。当看到需要的代码时,在复制粘贴前,我们都需要仔细研读、认真思考、详细甄别……很多东西,都是仁者见仁、智者见智的东西,适合别的场景但不一定适合你的场景。作为一名合格的程序员,切不可一味地"拿来主义"。

1.为什么要复制粘贴代码

  • 复制粘贴现有代码,可以节省开发时间;
  • 复制粘贴稳定代码,可以降低系统故障风险;
  • 复制粘贴网络代码,可以把别人的成果化为己用。

2.复制粘贴代码带来问题

  • 你对复制的代码理解程度是多少?实现逻辑是否合理?能不能稳定运行?存在多少潜在的 Bug?
  • 这个代码在项目中已经复制粘贴了多少次?根据“三则重构”原则,你是否需要对这些相同代码进行重构?
  • 代码被复制粘贴次数越多,带来的代码维护问题越多。多个代码版本的更改和修正,要保持这些代码的同步,就必须需要在每一处进行同样的修改,增加了维护的成本和风险。

总之,复制粘贴代码,跟其它编码方法一样,没有优劣对错之分。它只是一种方法,你可以善用,也可以滥用。如果我们用到了复制粘贴,我们就必须为结果负责。

方法3:用文本替换生成代码

1.生成代码样例

已经编写好的用户查询相关代码:

10分钟学会6个阿里内部的编程方法,赋能你我他

 

如果我们要编写公司查询相关代码,其代码形式与用户查询类似,整理出替换关系如下:

  • 把"用户"替换为"公司";
  • 把"User"替换为"Company";
  • 把"user"替换为"company"。

利用 Notepad、EditPlus 等文本编辑器,选择区分大小写,进行普通文本替换,最终得到结果如下:

10分钟学会6个阿里内部的编程方法,赋能你我他

 

利用文本替换生成代码,整段代码生成时间不会超过1分钟。

优点成代码速度较快。

缺点必须编写样例代码,只适用于文本替换的情景

方法4:用Excel公式生成代码

Excel 的公式非常强悍,可以用于编写一些公式化的代码。

1.利用 Excel 公式生成模型类

从 WIKI 上拷贝接口模型定义到 Excel 里,样例数据内容如下:

10分钟学会6个阿里内部的编程方法,赋能你我他

 

编写Excel公式如下:

10分钟学会6个阿里内部的编程方法,赋能你我他

 

利用公式生成代码如下:

10分钟学会6个阿里内部的编程方法,赋能你我他

 

创建模型类,整理代码如下:

10分钟学会6个阿里内部的编程方法,赋能你我他

 

2.利用 Excel 公式生成枚举类

从 WIKI 上拷贝枚举定义到 Excel 里,样例数据内容如下:

10分钟学会6个阿里内部的编程方法,赋能你我他

 

编写 Excel 公式如下:

10分钟学会6个阿里内部的编程方法,赋能你我他

 

利用公式生成代码如下:

10分钟学会6个阿里内部的编程方法,赋能你我他

 

创建枚举类,整理代码如下:

10分钟学会6个阿里内部的编程方法,赋能你我他

 

3.利用 Excel 公式生成数据库语句

用 Excel 整理的公司列表如下,需要整理成 SQL 语句直接插入数据库:

10分钟学会6个阿里内部的编程方法,赋能你我他

 

编写 Excel 公式如下:

10分钟学会6个阿里内部的编程方法,赋能你我他

 

利用公式生成 SQL 如下:

10分钟学会6个阿里内部的编程方法,赋能你我他

 

添加 into 语句头,整理 SQL 如下:

10分钟学会6个阿里内部的编程方法,赋能你我他

 

优点适用于表格化数据的代码生成;写好公式后,拖拽生成代码,生成速度较快。

缺点不适用于复杂功能的代码生成。

方法5:用工具生成代码

用工具生成代码,顾名思义就是借用已有的工具生成代码。很多开发工具都提供一些工具生成代码,比如:生成构造函数,重载基类/接口函数,生成 Getter/Setter 函数,生成 toString 函数……能够避免很多手敲代码。还有一些生成代码插件,也可以生成满足某些应用场景的代码。

这里以 mybatis-generator 插件生成代码为例,介绍如何利用工具生成代码。

1.安装运行插件

具体方法这里不再累述,自行上网搜索文档了解。

2.生成代码样例

2.1.生成模型类代码

文件 User.java 内容:

10分钟学会6个阿里内部的编程方法,赋能你我他

 

2.2.生成映射接口代码

文件 UserMapper.java 内容:

10分钟学会6个阿里内部的编程方法,赋能你我他

 

2.3.生成映射XML代码

文件 UserMapper.xml 内容:

10分钟学会6个阿里内部的编程方法,赋能你我他

 

优点:

  • 利用生成代码插件,生成代码速度较快;
  • 利用插件配置文件,控制生成想要的功能代码。

缺点:

  • 需要时间研究和熟悉生成代码插件的使用;
  • 生成的代码不一定满足代码规范,每次生成后需进行代码合规;
  • 重新生成代码后,容易覆盖自定义代码(建议维护单独的生成代码库,通过DIFF 工具比较代码差异,然后再赋值粘贴差异代码)。

方法6:用代码生成代码

用代码生成代码,就是自己编写代码,按照自己的格式生成代码。下面,以生成基于 MyBatis 的数据库访问代码为例说明。

1.查询表格信息

首先,我们要从数据库中拿到我们生成代码所需要的表和列相关信息。

1.1.查询表信息

查询表信息语句:

10分钟学会6个阿里内部的编程方法,赋能你我他

 

其中,第1个问号赋值数据库名称,第2个问号赋值表名称。

查询表信息结果:

10分钟学会6个阿里内部的编程方法,赋能你我他

 

1.2.查询列信息

查询列信息语句:

10分钟学会6个阿里内部的编程方法,赋能你我他

 

其中,第1个问号赋值数据库名称,第2个问号赋值表名称。

查询列信息结果:

10分钟学会6个阿里内部的编程方法,赋能你我他

 

2.编写生成代码

2.1.编写生成模型类代码

10分钟学会6个阿里内部的编程方法,赋能你我他

 

2.2.编写生成 DAO 接口代码

10分钟学会6个阿里内部的编程方法,赋能你我他

 

2.3.编写生成 DAO 映射代码

10分钟学会6个阿里内部的编程方法,赋能你我他

 

3.生成相关代码

3.1.生成的模型类代码

10分钟学会6个阿里内部的编程方法,赋能你我他

 

3.2.生成的 DAO 接口代码

10分钟学会6个阿里内部的编程方法,赋能你我他

 

3.3.生成的 DAO 映射代码

10分钟学会6个阿里内部的编程方法,赋能你我他

 

优点

  • 代码格式可以定制,保证生成代码合规;
  • 代码功能可以定制,只生成需要的代码;
  • 经过前期代码沉淀后,后期能够直接使用。

缺点

  • 需要研究数据来源,保证能获取到生成代码所需的数据;
  • 需要建立数据模型、编写生成代码,耗费时间比较长。
10分钟学会6个阿里内部的编程方法,赋能你我他

 

编程的终极方法,是不是直接对着电脑说需求,然后电脑就自动生成代码了?未来科技发展到一定水平后,这种情况或许会变成现实。但是,目前这种情况是不现实的。现实中,想要做到"大口一张、代码就来",除非你是老板、产品经理或者技术管理者。

终极方法是“无招胜有招”,"无招"并不是不讲究"招式",而是不拘泥于某一"招式",信手拈来合适的"招式"为宜。本文中列举的各种编程方法,没有高低优劣之分,只有合不合适之说。所以,灵活地运用各种编码方法,就是编程的终极方法。

联系我们

在线服务 外链咨询 二维码

扫码添加微信:juxia_com