说起代码整洁之道,想必大家想到更多的是那本经典重构书籍。没错,记得当时自己读那本书的时候,一边结合项目实战,一边结合书中的讲解,确实学到了很多东西,对我自己的编码风格影响极深。随着时间的流逝,书中很多具体的内容自己都记得不太清楚,但是会不自觉的应用到实际工作中,相当于成为自己的一种编码习惯了。所以在这篇博客里面,我将结合自己最近在android项目里面重构的经历,分享一些自己的代码重构体会吧,希望能够总结自己,同时帮到大家。

我记得以前遇到一个team leader他给我很深刻的影响就是人很自负,但是不得不承认技术很牛。他给我印象最深的一句话就是:你在写代码的时候,对自己的要求就是一个方法里面,最多不能够超过20-30行代码,不然我就认为你这个代码写的很烂,需要考虑重构了。从此我就深深得被他那句话给震撼到了,这句话以后一直就作为我编码时候的座右铭。好了,让我们回到正题上来吧,请看如下代码:

private void setDownGoodsListView() {
downGoodsListAdapter = new RsvAdapter(recyclerViewBelow.getContext(), downGoodsList, R.layout.goodsitem2);
recyclerViewBelow.setAdapter(downGoodsListAdapter); downGoodsListAdapter.setItemClickListener(new RsvAdapter.ItemClickListener() {
@Override
public void onItemClick(View view, int position) {
TrackPart currentTrack = SvmFactory.getSvm().getTrackPart();
if (currentTrack.canSell(goodsId, isHotDrank)) {
Bundle data = new Bundle();
data.putString("GoodsId", goodsId);
data.putBoolean("GoodsIsHot", isHotDrank); Context context = view.getContext();
Intent intent = new Intent(context, SaleActivity.class);
intent.putExtras(data);
if (!(context instanceof Activity)) {
intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
}
context.startActivity(intent);
}
} @Override
public void onItemLongClick(View view, int position) { }
});
}
private void setUpGoodsListView() {
upGoodsListAdapter = new RsvAdapter(recyclerViewTop.getContext(), upGoodsList,R.layout.goodsitem);
recyclerViewTop.setAdapter(upGoodsListAdapter); upGoodsListAdapter.setItemClickListener(new RsvAdapter.ItemClickListener() {
@Override
public void onItemClick(View view, int position) {
TrackPart currentTrack = SvmFactory.getSvm().getTrackPart();
if (currentTrack.canSell(goodsId, isHotDrank)) {
Bundle data = new Bundle();
data.putString("GoodsId", goodsId);
data.putBoolean("GoodsIsHot", isHotDrank); Context context = view.getContext();
Intent intent = new Intent(context, SaleActivity.class);
intent.putExtras(data);
if (!(context instanceof Activity)) {
intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
}
context.startActivity(intent);
}
} @Override
public void onItemLongClick(View view, int position) { }
});
}

上面这段代码是我从最近的android项目里面截取出来两个方法,具体含义你可以理解为:有两个列表,同时绑定数据和绑定每一个item的点击事件。如果你拿到这段代码,你会怎样去重构呢?

也许聪明的你,很快就能够发现这段代码最大的问题就是冗余代码太多,有没有发现itemClick里面的代码,除了goodsId/isHot两个参数差别之外,基本全部都是一样的代码。基于上面的分析,我们可以将代码进行如下重构:

private void setUpGoodsListView() {
upGoodsListAdapter = new RsvAdapter(recyclerViewTop.getContext(), upGoodsList,R.layout.goodsitem);
recyclerViewTop.setAdapter(upGoodsListAdapter); upGoodsListAdapter.setItemClickListener(new RsvAdapter.ItemClickListener() {
@Override
public void onItemClick(View view, int position) {
clickGoodsItemAction(view,upGoodsList.get(position).getId(),upGoodsList.get(position).isHot());
} @Override
public void onItemLongClick(View view, int position) { }
});
}
private void setDownGoodsListView() {
downGoodsListAdapter = new RsvAdapter(recyclerViewBelow.getContext(), downGoodsList, R.layout.goodsitem2);
recyclerViewBelow.setAdapter(downGoodsListAdapter); downGoodsListAdapter.setItemClickListener(new RsvAdapter.ItemClickListener() {
@Override
public void onItemClick(View view, int position) {
clickGoodsItemAction(view,downGoodsList.get(position).getId(),downGoodsList.get(position).isHot());
} @Override
public void onItemLongClick(View view, int position) { }
});
}
private void clickGoodsItemAction(View view,String goodsId,boolean isHotDrank){
TrackPart currentTrack = SvmFactory.getSvm().getTrackPart();
if (currentTrack.canSell(goodsId, isHotDrank)) {
Bundle data = new Bundle();
data.putString("GoodsId", goodsId);
data.putBoolean("GoodsIsHot", isHotDrank); Context context = view.getContext();
Intent intent = new Intent(context, SaleActivity.class);
intent.putExtras(data);
if (!(context instanceof Activity)) {
intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
}
context.startActivity(intent);
}
}

可以看到,我们进行了冗余重构之后,整个代码就简洁、直观了很多。但是如果只重构到这一步的话,那么还不是很完美的代码。你也许会问,还有什么地方可重构的吗?这个时候我们可能还需要用到另外一个重构原则就是:一个方法里面尽量只做一件事情。这下你就应该能够明白接下来应该做的事情了吧?首先让我们来看看,两个set开头的方法里面到底都干了几件事情?第一件事情就是:绑定列表数据;第二件事情就是设置每一个item的点击事件;好吧,分析到这里接下来的重构就是顺理成章的事情了,set方法重构之后的代码如下:

 private void setUpGoodsListView() {
setOneAdapter();
setOneItemClick();
}
private void setDownGoodsListView() {
setTwoAdapter();
setTwoItemClick();
}
private void setOneAdapter(){
upGoodsListAdapter = new RsvAdapter(recyclerViewTop.getContext(), upGoodsList,R.layout.goodsitem);
recyclerViewTop.setAdapter(upGoodsListAdapter);
}
private void setOneItemClick(){
upGoodsListAdapter.setItemClickListener(new RsvAdapter.ItemClickListener() {
@Override
public void onItemClick(View view, int position) {
clickGoodsItemAction(view,upGoodsList.get(position).getId(),upGoodsList.get(position).isHot());
} @Override
public void onItemLongClick(View view, int position) { }
});
}

同理连个two方法也是这样去拆分,这里就不一一贴出来了。重构到这里,你会发现整个代码结构就一目了然,但是我故意犯了个很二的错误,那就是命名规范的问题。这个也许大家都很清楚:每个变量的命名,每个方法的命名都尽量要让人家一看到这个名字就知道该方法是干什么的?所以这里可能又牵涉到一个很有意思的矛盾问题(鸡生蛋,还是蛋生鸡呢?)。也就是在我们代码里面到底是应该加注释呢?还是尽量少加注释呢?你会看到只要我们遵循命名释意的规则,我们就不需要去添加注视了,因为项目结构随时在变,很可能今天添加的注释,明天就不准了,这样的注释有比没有更害人。所以我的原则是能不加就不加。

好了,今天就到这里吧!其实还有更好的重构原则,大家可以参考一些书籍,下班了see you!

android开发系列之代码整洁之道的更多相关文章

  1. Programming好文解读系列(—)——代码整洁之道

    注:初入职场,作为一个程序员,要融入项目组的编程风格,渐渐地觉得系统地研究下如何写出整洁而高效的代码还是很有必要的.与在学校时写代码的情况不同,实现某个功能是不难的,需要下功夫的地方在于如何做一些防御 ...

  2. <代码整洁之道>、<java与模式>、<head first设计模式>读书笔记集合

    一.前言                                                                                       几个月前的看书笔记 ...

  3. 《代码整洁之道》(Clean Code)- 读书笔记

    一.关于Bob大叔的Clean Code <代码整洁之道>主要讲述了一系列行之有效的整洁代码操作实践.软件质量,不但依赖于架构及项目管理,而且与代码质量紧密相关.这一点,无论是敏捷开发流派 ...

  4. <读书笔记> 代码整洁之道

    概述      1.本文档的内容主要来源于书籍<代码整洁之道>作者Robert C.Martin,属于读书笔记. 2.软件质量,不仅依赖于架构和项目管理,而且与代码质量紧密相关,本书提出一 ...

  5. 2015年第11本:代码整洁之道Clean Code

    前一段时间一直在看英文小说,在读到<Before I fall>这本书时,读了40%多实在看不下去了,受不了美国人啰啰嗦嗦的写作风格,还是读IT专业书吧. 从5月9日开始看<代码整洁 ...

  6. Python代码整洁之道(一)

    很多新手在开始学一门新的语言的时候,往往会忽视一些不应该忽视的细节,比如变量命名和函数命名以及注释等一些内容的规范性,久而久之养成了一种习惯.对此呢,我特意收集了一些适合所有学习 Python 的人, ...

  7. 《代码整洁之道》ch5~ch9读书笔记 PB16110698(~3.15) 第二周

    <代码整洁之道>ch5~ch9读书笔记 本周我阅读了本书的第5~9章节,进一步了解整洁代码需要注意的几个方面:格式.对象与数据结构.错误处理.边界测试.单元测试和类的规范.以下我将分别记录 ...

  8. 《代码整洁之道》ch1~ch4读书笔记 PB16110698 (~3.8 第一周)

    <代码整洁之道>ch1~ch4读书笔记  <clean code>正如其书名所言,是一本关于整洁代码规范的“教科书”.作者在书中通过实例阐述了整洁代码带来的种种利处以及混乱代码 ...

  9. 《代码整洁之道 中文版》高清 PDF 电子书下载

    代码整洁之道.PDF 下载 代码整洁之道.PDF 中文版 高清 PDF  电子书下载 代码整洁之道下载  点我下载 作者简介  · · · · · · Robert C. Martin,Object ...

随机推荐

  1. opencv 连通域需要的函数解析

    OpenCV支持大量的轮廓.边缘.边界的相关函数,相应的函数有moments.HuMoments.findContours.drawContours.approxPolyDP.arcLength.bo ...

  2. 第4章 awk编程

    1 awk编程模型       2 awk用法 调用awk有三种方法(与sed类似): 在Shell命令行输入命令调用awk,格式为: awk [-F 域分隔符] 'awk程序段' 输入文件 将awk ...

  3. web调试技巧

    接触web不久,遇到了一些"奇怪"的问题,现将一些调试技巧总结如下:    1.欲添加某一样式,点击右键,查看源码    2.样式有问题,点击右键,审查元素 当然,还有一些经验总结 ...

  4. 过河-状压DP

    http://www.luogu.org/problem/show?pid=1052 题目描述 在河上有一座独木桥,一只青蛙想沿着独木桥从河的一侧跳到另一侧.在桥上有一些石子,青蛙很讨厌踩在这些石子上 ...

  5. 查询数据库后台Block 的Sql存储过程

    查询数据库后台Block 的Sql存储过程 SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER OFF GO /*记录SQL Server的阻塞情况 wang 200 ...

  6. Use EnCase to acquire data from a smartphone

    Yesterday someone asked me a question can EnCase acquire data from a smartphone, and my reply was &q ...

  7. Server2003安装SP2补丁提示密钥无效的解决方法

    机器一直没有打SP2的补丁.几天要安装一个程序,还非要SP2不可.没办法.居然打补丁的时候出现了这样的错误信息: --------------------------- Service Pack 2 ...

  8. 比特币钱包应用breadwallet源码

    breadwallet是一款安全.可靠和便捷的比特币钱包,可使用户免于恶意软件和其他应用中常见的安全问题的骚扰,充分利用了iOS提供的安全功能,包括AES硬件加密.app沙盒和数据保护.代码签名以及k ...

  9. MVC5使用SignalR进行双向通信(1)

    MVC5使用SignalR进行双向通信 (1) 配置Signal 在NuGet中通过 install-package Microsoft.AspNet.SignalR 命令进行安装 在Scripts文 ...

  10. ASP.NET MVC5 高级编程 第5章 表单和HTML辅助方法

    参考资料<ASP.NET MVC5 高级编程>第5版 第5章 表单和HTML辅助方法 5.1 表单的使用 5.1.1 action 和 method 特性 默认情况下,表单发送的是 HTT ...