`
sg552
  • 浏览: 622224 次
  • 性别: Icon_minigender_1
  • 来自: 北京
博客专栏
47437293-94b9-3b04-9152-8971c7580049
白手起家学习使用Flex
浏览量:18752
社区版块
存档分类
最新评论

应用开源项目时,你会大肆封装,修改它吗?

阅读更多
趁着前面那位”LUCENE应用体会“,发表此帖,也是我心中压抑已久。

我觉得,对于开源项目,就是工具,大可不必用的那么复杂。

封装再封装,HACK再HACK,有什么明显的性能提升吗?某些我们作出的改进,人家作者能想不到相关方面吗?

见过有把Struts的DispatchAction 封装的面目全非的,见过有把Spring Mvc中的 controller 重写源代码的, 见过有为了实现美其名曰“权限的动态管理”把Acegi改的一塌糊涂的。最后效果怎么样?

改Struts的那个只是为了增加个log,写出的class却无法被 doclet辨认。改Spring mvc controller的那个也就是增加个log,却没有使用官方推荐的 paraMethodResolver,弄的那方法名是千奇百怪啊。至于改Acegi的那个,是我做的蠢事。人在公司,身不由己。上级要求的,于是我按照上级的思想来实现。到最后BUG 多多,诡异事件到处都是。领悟用3天,改Acegi用4天,教人使用还要2天。我自己都不知道把现在这东西是怎么用的。哎!

记得在某坛见到某前辈谈经验。他说,见过的好系统,都是设计简单的。越是经历多几个项目,我就越身有体会。

菜鸟刚飞,说的漏洞很多,请各位朋友多多指教!
分享到:
评论
45 楼 wangfuyu 2007-07-05  
我觉得,对于开源项目,就是工具,大可不必用的那么复杂。

封装再封装,HACK再HACK,有什么明显的性能提升吗?某些我们作出的改进,人家作者能想不到相关方面吗?

见过有把Struts的DispatchAction 封装的面目全非的,见过有把Spring Mvc中的 controller 重写源代码的, 见过有为了实现美其名曰“权限的动态管理”把Acegi改的一塌糊涂的。最后效果怎么样?

改Struts的那个只是为了增加个log,写出的class却无法被 doclet辨认。改Spring mvc controller的那个也就是增加个log,却没有使用官方推荐的 paraMethodResolver,弄的那方法名是千奇百怪啊。至于改Acegi的那个,是我做的蠢事。人在公司,身不由己。上级要求的,于是我按照上级的思想来实现。到最后BUG 多多,诡异事件到处都是。领悟用3天,改Acegi用4天,教人使用还要2天。我自己都不知道把现在这东西是怎么用的。哎!

记得在某坛见到某前辈谈经验。他说,见过的好系统,都是设计简单的。越是经历多几个项目,我就越身有体会。

菜鸟刚飞,说的漏洞很多,请各位朋友多多指教!
44 楼 haohappy 2007-07-04  
封装、扩展但尽量不修改源码,否则最好直接参与开源项目的建设。

当然这也是好事,目前贡献代码的人比拿来就用的人要少得多,特别中国的程序员只有很小部分参与国际开源项目,这种状况也需要改变了。
43 楼 geszJava 2007-07-03  
ltian 写道
侵入式地修改开源的东西要慎重。最好是不侵入式修改。

严重同意.
可惜有时候需要加功能,又要兼顾效率和处理历史问题.俺也不想这么做的.想想以后的维护...头很大.不过没办法,现在也看不见以后会怎么样,或许公司倒闭或许公司成功,反正无论哪种可能,俺都不用去维护这个破东西了.所以,想改就改吧!
42 楼 taelons 2007-06-28  
好的开源项目都是面向接口设计的,便于扩展。写程序时一定要明白,你的代码要便于扩展,使用你的代码的人也应该明白,去扩展而不要去修改,除非有bug。
其实许多大的开源项目我们都不用,比如spring、hibernate,一直用老版本的struts,加上一些自己的扩展,因为当时spring、hibernate等没出现或者不完善。
41 楼 kedao 2007-06-27  
如果封装能更好的实现应用,为什么不呢?
40 楼 bbiao 2007-06-21  
对DispatchAction封装过...
我觉得有些东西如果有改得好的话,还是很有意义的...
39 楼 limx 2007-06-21  
TommyCool 写道
记得,我们在做地税项目时,根据实际需求对hibernate进行了一定的封装,将事务处理封装的很好,使得程序员都不用理会后台,而专注于实际业务本身.对开源框架的封装要根据实际需要而定,不要走极端.建议多关注AOP方面的应用,对进行封装或业务需求的处理有很好的借鉴!


同意,很多时候封装都是为了将前后台或不同模块的业务分隔开
曾经封装过lucene,目的也是为了方便其他模块的程序员调用
至于说修改......  个人还是扩展用得多一些  实在不敢自己未完全掌握的开源框架前造次
38 楼 geszJava 2007-06-19  
lucene的hack是必需的,在我们的项目中.
37 楼 TommyCool 2007-06-19  
记得,我们在做地税项目时,根据实际需求对hibernate进行了一定的封装,将事务处理封装的很好,使得程序员都不用理会后台,而专注于实际业务本身.对开源框架的封装要根据实际需要而定,不要走极端.建议多关注AOP方面的应用,对进行封装或业务需求的处理有很好的借鉴!
36 楼 zlsunnan 2007-06-19  
这个完全是根据实际情况而定  如果是你的项目中 有这样的需求的 那是肯定要改的  如果没有需要的话  为什么要改呢 都封装的那好 拿来就用 行了
35 楼 galaxystar 2007-06-18  
在真正做开发时,少写一行代码也是好的!
34 楼 zwchen 2007-06-18  
其实,敢改开源项目,必须先问自己:
1、你对原开源产品理解透了吗?
2、除了封装,又其它扩展办法吗?
3、你的项目必须这么做吗?
4、开源产品的后续升级对你冲击大吗?
33 楼 zwchen 2007-06-18  
我看具体情况了,一般来说,我觉得如果你用开源框架做产品,比起做项目,修改框架的可能性要大多了。象log4j,我见过几个产品,因为ClassLoader的问题,将log4j给封装了(log4j提供的那个自定义ClassLoader就像有时候不满足要求)。

打个比方,象最常用的Struts,本身就提供了很多的扩展点,譬如那个ActionServlet和RequestProcessor,包括RequestProcessor里面的每个protected的processXXX的模板方法都是留给扩展的,否则要用protected干嘛,而且自定义RequestProcessor都可以在struts-config.xml 里面配置的。也就是说它很好支持扩展。那个Plugin机制也是专门为我们做扩展的,因为已有的Validation和国际化、临时数据库都是典型的例子。
而且,我以前用一个类似Spring的的Seasar框架,它通过IoC和AOP,把Struts变成了webwork那样易用。

一般来说,框架提供的filter、interceptor等类似AOP的东西,是一个通用的扩展方式。

如果把开源项目给封装了,大肆修改,后期你发现那个开源项目出现了bug,并且在新版本里面更正了,该更正也是你需要的,你咋办?再对新版改造?

我觉得,一定要考虑优先用开源产品自己的plugin机制!

我现在在对Jive公司著名的即时通讯服务器和客户端Openfire和Spark二次开发,但首先考虑的是写plugin,但是我们的在Spark客户端(类似于MSN)的上的二次开发就没法再用Spark的后续版本了,因为有很多定制的功能,譬如最简单的:Spark的国际化只做了90%,剩下的10%是hard code的,我们一给它完善,呵呵.... 它本身的后续bug都交给我了。







32 楼 JerryZheng 2007-06-18  
agile_boy 写道
gigix 写道
奇怪……竟然没有人指出如此明显的一件事:
如果你需要修改开源项目,别人很可能也有同样的需要
所以你应该把你的修改贡献给开源社区

赞成,这才是正确的开源之道


呵呵 有时候老板的话乃们要听...
31 楼 sun113 2007-06-18  
通用框架并不一定适合所有的系统,
对于具体的系统通常对框架封装就可以了,
至于修改代码认为没必要。
30 楼 无明 2007-06-15  
大规模修改?那还不如自己写个土制框架好了,至少是100%贴合实际
29 楼 magice 2007-06-15  
修改,封装都是正常之事,毕竟国外人的有些框架绕的弯子和我们思路就不一样,如果能修改简单一些那自然是好,但是如果修改复杂了,那就。。。
28 楼 agile_boy 2007-06-15  
gigix 写道
奇怪……竟然没有人指出如此明显的一件事:
如果你需要修改开源项目,别人很可能也有同样的需要
所以你应该把你的修改贡献给开源社区

赞成,这才是正确的开源之道
27 楼 agile_boy 2007-06-15  
除非,你决定参与到开源项目中,否则最好不要去修改源代码(特殊情况除外),当然看人家代码实现,是应该也是必须的
大肆封装也没有必有吧,但有时候也会用facade,adapter模式去做些简单封装的.
26 楼 devilbaby 2007-06-14  
工具性的开源项目不会,好像liferay,expresso这种整合框架性的开源项目,会

相关推荐

    自己移植的MP4V2开源库可以直接使用代码封装H264和AAC linux.zip

    标题中的“自己移植的MP4V2开源库可以直接使用代码封装H264和AAC”表明,这是一个关于在Linux环境下,使用自移植的MP4V2库进行H264和AAC编码视频与音频封装的项目。MP4V2是一个开源的库,专门用于处理ISO基础媒体...

    c++ 开源项目

    **c++ 开源项目——深度探索Jason数据封装** 在编程世界中,C++以其高效、灵活性和面向对象的特性深受开发者喜爱。对于学习者来说,理解并掌握C++的高级特性,尤其是如何处理数据结构和接口设计,是提升技能的关键...

    开源项目-Xeoncross-macappshell.zip

    【开源项目-Xeoncross-macappshell.zip】是一个面向Mac OS X操作系统的开源项目,它的主要功能是通过一个简单的bash脚本创建一个`.app`包装器,使得Go语言编译的程序可以在Mac上以标准的Mac应用形式运行。...

    sun公司免费开源项目下载

    Sun公司,作为IT历史上的一家重要企业...通过研究C3CRM3GA.exe,我们可以深入理解Java和MySQL在实际项目中的应用,以及开源软件如何促进技术进步和创新。对于初学者和经验丰富的专业人士来说,这是一个不容错过的资源。

    Android 谷歌开源项目

    "Android 谷歌开源项目"涵盖了Android系统的各个层面,包括系统内核、框架层、应用程序接口(API)、开发工具链以及大量的开源应用程序。 1. **Android系统架构**:Android系统由五层架构组成,从低到高分别是Linux...

    开源项目-steeve-homebrew-delve.zip

    【开源项目-steeve-homebrew-delve.zip】是一个开源项目,其主要目的是为用户提供一个自定义的途径来安装和管理Delve。Delve是Go语言的一款强大的调试工具,它使得Go程序的调试过程变得更加简单和高效。在这个压缩包...

    第三方开源库的简单再封装

    "第三方开源库的简单再封装"这个主题主要探讨如何根据项目需求,对这些开源库进行适当的修改和封装,使其更好地适应我们的应用。 首先,我们来看看`net`这个目录,它可能包含了网络请求相关的代码。在Android中,...

    开源项目-IPStreet-HelloWorld.zip

    同时,开源的特性使得任何人都可以查看、学习、修改和分享这个项目,促进了技术知识的共享和进步。 总的来说,IPStreet-HelloWorld项目结合了Go语言的强大功能和开源社区的开放精神,为开发者提供了一个实战平台,...

    开源项目Auto Maker缺少的Common项目代码

    在IT行业中,开源项目扮演着至关重要的角色,它们促进了技术的共享和创新。"Auto Maker"是一个这样的项目,它提供了一套工具或者框架,可能是用于自动化制造流程、汽车设计或者其他与自动化相关的领域。然而,根据...

    VB6.0封装Excel功能区代码-开源

    "VB6.0封装Excel功能区代码-开源"项目正为此目的提供了宝贵的资源,它允许开发者通过编程方式控制Excel的功能区,增强应用程序与Excel的交互性。 首先,我们来理解“功能区”这一概念。在Excel 2007及后续版本中,...

    Java最著名的开源项目总结.pdf

    **Spring Framework** 是一个轻量级的开源框架,它的核心特性使它成为了一个强大的企业级应用程序开发工具。Spring 框架解决了 J2EE 开发中常见的问题,比如依赖管理和控制反转(Inversion of Control, IoC),以及...

    仿25ge封装的APP封装源码-可以封装安卓和IOS.zip

    在IT行业中,应用程序的封装是开发过程中的一个重要环节,它涉及到软件的打包、签名和发布。本主题聚焦于一个名为“仿25ge封装的APP封装源码-可以封装安卓和IOS”的压缩包,其中包含了用于封装Android APK和iOS描述...

    开源项目-lukechampine-httprpc.zip

    它支持任意基于文本的RPC协议,这意味着你可以将现有的RPC协议(如JSON-RPC、gRPC的protobuf等)轻松地转换为HTTP服务,而无需修改原始协议的实现。 项目结构主要包含以下几个部分: 1. **服务器端实现**:服务器...

    如何正确使用开源项目?

    在应用开源项目之前,开发者应深入学习其工作原理和核心机制,尤其是对于框架和库的使用。掌握主要API的使用方法和设计模式能够帮助开发者更好地集成项目,并在出现问题时能够快速定位和解决。 避免直接修改源码是...

    仿25ge封装的APP封装源码-可以封装安卓和IOS

    标题中的“仿25ge封装的APP封装源码-可以封装安卓和IOS”指的是一个开源项目,它提供了用于创建和封装Android及iOS应用的工具。这个项目可能模仿了某些特定的功能或界面设计,如25ge这样的平台,同时提供了一种...

    开源代码.rar

    首先,Apache是全球最知名的开源软件基金会之一,它维护了许多关键的开源项目,如HTTP服务器、Tomcat应用服务器、Apache Maven构建工具等。在这里提到的Apache,可能指的是其某些组件或者与Web服务相关的项目。了解...

    开源项目-tywkeene-go-fsevents.zip

    【标题】"开源项目-tywkeene-go-fsevents.zip"是一个开源项目,它主要关注的是使用Go语言实现对文件系统事件的监控。这个项目由开发者tywkeene创建,目的是提供一个简单且高效的方式来观察文件系统的变化,尤其是...

    开源项目-d4l3k-talib.zip

    【开源项目-d4l3k-talib.zip】是一个基于Go语言的开源项目,它的主要目的是为金融技术分析提供一个TA-Lib(Technical Analysis Library)的封装器。TA-Lib是一个广泛使用的库,包含了多种技术指标和分析工具,主要...

Global site tag (gtag.js) - Google Analytics