abstract:

代码克隆的综述


S1    INTRODUCTION AND MOTIVATION

代码克隆的利弊:

利:可以有效地去耦合,避免其他一些可能的错误;

弊:当被复制的那段code中带有bug的话,他的复制版本中都会含有bug。

但是代码克隆操作又是不可避免的,因此,代码克隆应该得到有效的检测和管理。


S2    A SYSTEMATIC REVIEW OF CLONE LITERATURE

Robert Tiras搜集了一个从1994~2013的论文库,主要分为以下几类:

1、克隆检测;(主要是一些检测技术和工具)

2、克隆分析;(主要是分析克隆的性质,如原因,存在性和影响,克隆重组的影响)

3、克隆管理;

4、克隆检测技术和工具的评价;

研究情况:

四个分类的研究情况:可以发现,克隆的分析和克隆的检测论文比较多

4个类别的发表的数量:未来在克隆的管理上,研究更有潜力,同时,对于克隆工具的评估的论文也相对较少。


S3    CLONE MANAGEMENT

克隆管理包含克隆检测,克隆避免和消除克隆,追踪克隆代码,克隆代码的重构。

A.   代码克隆的定义

Ira Baxter给出一种比较模糊的定义:“Clones are segments of code that are similar according to some definition of similarity"。每个研究者可能因为他们的检测工具对于代码的表现形式和检测机制的不同,他们对于相似的定义也不同。主要分为一下以下几类克隆:

1——相同的代码片段,除了代码的空格数和注释不同;

2——相同结构的代码片段,除了变量名,常量名,类型名,顺序和注释不同;( near-miss  clones)

3——同第二种相似,但还进一步允许有不同的操作符,如加减等;( near-miss clones)

4——实现相同的功能,但是实现的方法不同;

检测目的的不同,导致对克隆的定义也不同。我们并不希望能够有一个对“克隆”的统一定义,而是希望基于特定任务的相似性分类可以在未来出现,以及可以进一步区分上下文和克隆的目的。

对于代码克隆的研究不应该仅仅只局限于源代码,还应该扩展到基于模型,甚至是在电子表格中的克隆。

B    克隆管理


S4   克隆检测

不同的克隆检测技术:

1、追踪剪切板的操作;

2、相似性度量比较;

3、文本比较;

4、基于token的比较;

5、句法比较;

6、基于PDG(程序依赖图)的比较;

7、基于hash的比较;

8、基于低级代码的比较(如汇编、java字节码)

9、其他。


S5   集成克隆检测

把克隆检测与IDE或版本控制工具结合起来。

文中列举了大量的工具,但是极少数可以处理第三类clone。


S6  克隆检测报告

为了最小化克隆的信息, Harder and Göde提出了一种可扩展的模式——Rich Clone Format (RCF),包括克隆数据的存储,交换和一致性。但是,它也没有解决所有问题。因为没有一个统一的概念模型,所以需要多个研究团队在一起讨论后才能得出结论。


S7   克隆追踪

源码的改变可能使得之前的克隆信息失效,因此,要更新克隆信息,有两种方法:

1、重新检测:每一次代码改变,都可能触发克隆检测机制,重新检测一遍,这种方法开销太大;

2、增量式检测:检测仅在源码被修改的位置进行,在原有的基础之上加以改动,


S8   克隆演化分析

克隆的稳定性,克隆演化与软件的缺陷。克隆的可视化。

克隆演化的“家族系谱图”


S9   克隆注释

便于其他编程人员的阅读


S10   克隆再造/重构技术

克隆的泛型,设计模式,软件重构模式,同步修改。

1、泛型和模版:可以减少冗余的代码;

2、一致性重命名;

3、重构模式;


S11   分析和识别潜在的克隆重构

1、代码克隆分布和属性的可视化

散点图,hasse图,html等等。

2、成本效益分析和重构步骤

成本效益分析困难


S12   代码重复的根本原因

1、开发策略:当有相似的需求时,重用现有的代码通过拷贝的方式比较简便;

2、维护成本:现有的代码已经被测试过,复制的话可以节约成本;

3、克服潜在的局限性:开发者为了追求效率,并未遵循正确的开发策略,相似问题找相似代码解决;

4、无意中进行克隆:相同的API,写的代码高度的一致性。


S13   克隆管理策略

分三类:

1、克隆纠正:删掉代码中所有的克隆;

2、克隆预防:组织新的克隆活动;

3、克隆补救:删掉一些不好的克隆;


S14   克隆管理系统的设计

A   集成架构方案:

1、架构中心;

2、集成架构;

3、分散架构;

B   克隆管理触发事件:

1、主动触发;

2、系统触发;

3、克隆范围;

C   克隆管理的范围和时间点;


S15   克隆管理的工业应用

目前应用的程度还不高


S16   总结

【软件分析与挖掘】Vision of Software Clone Management: Past, Present, and Future (Keynote Paper)的更多相关文章

  1. 【软件分析与挖掘】Multiple kernel ensemble learning for software defect prediction

    摘要: 利用软件中的历史缺陷数据来建立分类器,进行软件缺陷的检测. 多核学习(Multiple kernel learning):把历史缺陷数据映射到高维特征空间,使得数据能够更好地表达: 集成学习( ...

  2. 【软件分析与挖掘】BOAT: An Experimental Platform for Researchers to Comparatively and Reproducibly Evaluate Bug Localization Techniques

    摘要: 目前有许多的bug定位技术,但是,由于他们基于不同的数据集,而且有些数据集还不是公开的,甚至有些技术只应用于小数据集,不具有通用性,因此,不好比较这些技术之间的优劣. 因此,BOAT应运而生. ...

  3. 【软件分析与挖掘】An Empirical Study of Bugs in Build Process

    摘要 对软件构建过程中所产生的错误(build process bugs)进行实证研究. 5个开源项目:CXF, Camel, Felix,Struts, and Tuscany. 把build pr ...

  4. 【软件分析与挖掘】ELBlocker: Predicting blocking bugs with ensemble imbalance learning

    摘要: 提出一种方法——ELBlocker,用于自动检测出Blocking Bugs(prevent other bugs from being fixed). 难度在于这些Blocking Bugs仅 ...

  5. 【软件分析与挖掘】A Comparative Study of Supervised Learning Algorithms for Re-opened Bug Prediction

    摘要: 本文主要是评估多种监督机器学习算法的有效性,这些算法用于判断一个错误报告是否是reopened的,算法如下: 7种监督学习算法:kNN,SVM, SimpleLogistic,Bayesian ...

  6. 第二次作业-Steam软件分析

    1 .介绍产品相关信息 随着电子音频游戏产业的发展以及正版意识的崛起,Steam已经成为大部分游戏爱好者必备的一款游戏下载平台.这款软件也使得Valve公司从一个游戏制作公司成功扩展业务到一个承揽众多 ...

  7. 使用AES加密的勒索类软件分析报告

    报告名称:  某勒索类软件分析报告    作者:        李东 报告更新日期: 样本发现日期: 样本类型: 样本文件大小/被感染文件变化长度: 样本文件MD5 校验值: da4ab5e31793 ...

  8. [软件逆向]实战Mac系统下的软件分析+Mac QQ和微信的防撤回

      0x00  一点废话 最近因为Mac软件收费的比较多,所以买了几款正版软件,但是有的软件卖的有点贵,买了感觉不值,不买吧,又觉得不方便,用别人的吧,又怕不安全.于是我就买了正版的Hopper Di ...

  9. 必应词典手机版(IOS版)与有道词典(IOS版)之软件分析【功能篇】【用户体验篇】

    1.序言: 随着手机功能的不断更新和推广,手机应用市场的竞争变得愈发激烈.这次我们选择必应词典和有道词典的苹果客户端作对比,进一步分析这两款词典的客户端在功能和用户体验方面的利弊.这次测评的主要评测人 ...

随机推荐

  1. java集合——题4,6

    4.(List)写一个函数reverseList,该函数能够接受一个List,然后把该List 倒序排列. 例如: List list = new ArrayList(); list.add(“Hel ...

  2. iOS开发——高级技术&系统应用于系统服务

    系统应用于系统服务 系统应用 在开发某些应用时可能希望能够调用iOS系统内置的电话.短信.邮件.浏览器应用,此时你可以直接使用UIApplication的OpenURL:方法指定特定的协议来打开不同的 ...

  3. Xcode 重新下载项目配置文件

    配置文件保存在: ~/Library/MobileDevice/Provisioning Profiles 可以按修改日期排序移走没用的配置文件或者干脆将目录重命名,备份好旧的配置文件后,到Xcode ...

  4. php header函数详解

    客户机的请求方式格式:是统一资源标识符.协议版本号,后边是MIME信息包括请求修饰符.客户机信息和可能的内容!服务器响应格式:一个状态行包括信息的协议版本号.一个成功或错误的代码,后边是MIME信息包 ...

  5. 苹果App部署HTTPS进行在线下载安装

    苹果App的ipa下载需要有几个前提,可参考:Android和IOS的本地App如何安装(apk&ipa) 本文主要介绍如何部署https提供ipa的下载,步骤如下: 1. 搭建一个HTTPS ...

  6. iPhone屏幕尺寸、分辨率及适配

    转:http://blog.csdn.net/phunxm/article/details/42174937 目录(?)[+]   1.iPhone尺寸规格 设备 iPhone 宽 Width 高 H ...

  7. MVC视图中处理Json

    /// <summary> /// 登录 /// </summary> /// <param name="value"></param&g ...

  8. 我用了13行代碼開發出来的PHP框架

    我只用13行代碼開發的PHP框架,如果您對框架不理解,不知道框架究竟幫您做了什麽事,可以下載此框架看一下, 另外如果您想開發自己的框架也可以由這個框架的思路進行擴展. 源碼下載地址:http://do ...

  9. RTTI的实现(vc)--转载

    RTTI (Run Time Type info) 这个神奇的东西用于存储类的相关信息,用于在运行时识别类对象的信息.C++ 里面只记录的类的名字和类的继承关系链.使得编译成二进制的代码,对象可以知道 ...

  10. 原创内容搬家到csdn博客啦~

    以后原创的文章就发布在csdn博客啦: http://blog.csdn.net/aceyan0718 这里就用来当作一个网络笔记本吧,转载些优质的内容