`
getjack
  • 浏览: 13816 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
文章分类
社区版块
存档分类
最新评论

一个2600行代码的类,干掉1100行,程序照常运行

 
阅读更多
如题,这是什么概念,至于其他的类也是一个鸟样,我不想去多改了。
很无奈,如果要去优化,还不如重新开发。你们有碰到这样“优秀”的程序。唉
分享到:
评论
129 楼 getclass 2011-06-11  
痛恨写这些"异味"代码的人.这样的人在我手下,就直接开除.没商量
128 楼 NeroBest 2011-06-10  
一大堆人写一个类。。。代码行数爆炸
127 楼 william_ai 2011-06-02  
没有svn,cvs,vss之类的版本控制么
126 楼 zhongrenmeng 2011-06-02  
supertaxi 写道
我们公司一个类文件3W多行代码, 并且规定修改代码时,不能删除旧的代码,只能注释掉. 于是,一个注释直接注释一千多行...

我们公司也有很多人有这个习惯, 不过没还出现杯具到3w多行的情况
125 楼 mdsp25xhm 2011-06-02  
supertaxi 写道
我们公司一个类文件3W多行代码, 并且规定修改代码时,不能删除旧的代码,只能注释掉. 于是,一个注释直接注释一千多行...


同感
124 楼 wubaodong 2011-06-02  
sirxenofex 写道
wubaodong 写道
我写过的一个方法,将近1000行。功能很简单,逻辑单一,输出一个PDF文件。类似你直接写一个servlet输出一个HTML文件一样。1000行是因为PDF文件内容多,如果内容需要增加,我还会继续增加方法的行数。你们说这样的方法,有必要拆分吗?

非常有必要。就算你的1000行所有代码都不能重用,也要按步骤拆成很多个小函数。运行上没有任何区别,原因只有一个:给人看


如果只是从给人看的角度考虑,那我觉得不拆分跟拆分没有优劣之分

    System.out.println("我爱北京敏感词");
    System.out.println("敏感词上太阳升");
    System.out.println("伟大领袖敏感词");
    System.out.println("指引我们向前进");
    System.out.println("啦啦啦啦啦啦啦");


类似这样罗列的输出一篇文章,拆不拆分有什么区别,每一个自然段都拆分成一个小方法吗?
123 楼 from_null 2011-05-31  
zuzong 写道
赶工、加班、工资低、保险差、混乱的项目管理、蛋疼的经理、你说你还想要优雅的代码。。。。

 
122 楼 wangchong0114 2011-05-31  
其实这个感觉挺正常的
你无法保证项目组内的人的技术水平跟你一样
也无法保证项目组内的人跟你一个思路实现功能
关于重构这一块
确实是一个很大的学问
代码是由少变多再变少的一个过程

如果有人拿到你的代码再给你的代码删去一半  功能还是会实现
能说你写的代码不好么?
121 楼 sunofsummer 2011-05-31  
谨慎重构。
120 楼 crazygoal 2011-05-30  
对于维护系统来说一半都会选择重构,而不是重写。重写风险太大了,因为旧系统可以已经修正过很多BUG,直接重写的话有可能不能继承这些修复。我碰到过一个项目(C语言开发的),里面有大量的重复代码,超过7层的if语句,超过2000行的函数等,就是看了就崩溃的那种。那时我也很想很想重写,但是考虑到现有版本经过测试人员的反复测试,客户使用情况也较好,但就是新增功能非常困难,定位和修改BUG也非常困难。最终我们对系统进行了很多轮的分析,并进行重构(功能不变 内部结构变化)。代码从38K降至18K,验收测试和后续版本基本没有BUG产生。

结论
1.重构而非重写
2.重构前作充分准备,现有系统的多轮分析,人力/时间的准备。
3.重构最好进行拆分,不要想一次搞定,迭代进行。
119 楼 jnn 2011-05-30  
szcs10138456 写道
项目就是在不断地改需求和不断地fix和Refactoring下成长的

严重同意,
我接触过的几个项目最起码都大规模的重写过两遍,同时Refactoring无数次。
采用TDD开发的最大好处就是不怕Refactoring,改完了之后跑完测试都绿了就可以收工睡觉了。

118 楼 moremoney999 2011-05-30  
有时间就拆分了,还是没时间啊,拆分了还要测试,这时候可能已经上线了或者开始下一版开发了
117 楼 nowaytj 2011-05-30  
首先不能单纯看行数论好坏
然后呢这么多行的类肯定是不应该
什么事都得有个规范,有个度
程序写成这样原因只有一个
一定是有不负责任的人混饭吃
116 楼 sirxenofex 2011-05-30  
wubaodong 写道
我写过的一个方法,将近1000行。功能很简单,逻辑单一,输出一个PDF文件。类似你直接写一个servlet输出一个HTML文件一样。1000行是因为PDF文件内容多,如果内容需要增加,我还会继续增加方法的行数。你们说这样的方法,有必要拆分吗?

非常有必要。就算你的1000行所有代码都不能重用,也要按步骤拆成很多个小函数。运行上没有任何区别,原因只有一个:给人看
115 楼 vb2005xu 2011-05-30  
你不错了 我之前遇到过 1个 方法 1700行啊 更无语 啊
114 楼 zui4yi1 2011-05-30  
流程里不要添加太多的实现代码,基本上就OK
113 楼 ansjsun 2011-05-29  
BruceXX 写道
那你们看到过一个jsp页面组成一个项目的吗??哈哈。。。

文件管理器算不算..也可以 说成jsp木马..就一个jsp文件哦
112 楼 guaziaim9x 2011-05-29  
千万别把自己看得太牛逼,有可能捞的程序员考虑的更细致的东西
111 楼 okbaozhen 2011-05-28  
refactoring
110 楼 orcl_zhang 2011-05-28  
nakupanda 写道
到有一天发现别人臃肿的代码原来是考虑到一些自己没有考虑到的情况的时候, 不知道楼上的一些朋友会不会泪流满脸.

这是经常遇到的,有次精简代码,把8000行改成6000行,之后发现错了,又把6000行改成10000行。。
发表评论

文章已被作者锁定,不允许评论。

相关推荐

    微信小程序-通过webpack编译构建微信小程序

    所以,通过这样一个简单的构建脚本,我们可以在一个屏幕上用喜爱的编辑器或IDE照常愉快的写js,在另一个屏幕上刷开发者工具看结果,提升开发体验 注意 1、小程序的生命周期函数不要使用箭头函数,使用function才能用...

    太阳照常升起(组诗)

    很抱歉,但根据您给出的信息,这首名为"太阳照常升起(组诗)"的内容实际上是一首诗歌,而非IT行业的专业知识。描述中的内容也延续了诗歌的风格,讲述了作者对于父亲的怀念以及对生活的感悟。标签虽为"课件",但没有...

    通用软件安装程序1.0

    但是如果用"通用软件安装程序",则可以克服这样的缺点,如果光盘中某一个文件的损坏,并不影响其他文件,软件可以照常安装使用,这也是我制作通用安装工具的根本出发点。 4、制作示例: 以制作"恒特画王"安装程序...

    最新软件狗时间复制工具

    在判定加密锁错误时,并不立即提示或退出,而是在以后提示或退出或程序照常运行但出现偏差或溢出等等错误。 → 可以将加密锁返回值作为数组的索引、常量、计算单元和校验码;可以将加密锁返回值作为指针来控制程序...

    练习7_21

    第九题的答案是B,实际上,一个`try`块后面可以没有`except`,但如果没有`except`,`try`块中的异常将不会被捕获,程序会照常抛出异常。第十题的答案是`finally`,无论是否发生异常,`finally`块中的代码总是会被...

    cuthon:一个用于选择第一个免费GPU并运行Python的简单工具

    该脚本将找到第一个未使用的GPU,然后照常运行该程序。 最简单的说: cuthon my_program.py 该工具旨在用于相当利基的用例:在具有多个GPU的交互式节点上运行python程序。 对于那些经常这样做的人,您可能不必再...

    win7下的netmeeting

    因为NetMeeting的安装程序要检测Windows版本,所以有可能会报告不兼容,不过没关系,照常运行安装就是了。安装过程中会报告MSASN1.dll的某个函数点无法定位。 现在安装过的NetMeeting还不能运行,需要进行破解(即将...

    一个用foxpro编写人事管理系统

    整个系统是我独自一个人编写的,由于一个人的思维定势问题及我的编程水平所限,系统难免存在许多的不足和错误,如果你能提出很好的意见及建议,我愿意提供相关部分的源代码。 系统是使用VFP8.0开发编译的,在Win2K...

    freescale遇到的各种DT问题--无法加入控制程序

    5. 注意最下面的选择:在工程设置的某个步骤中,会遇到一个选择浮点型运算的选项。开发者指出,此处的选择不能为None,而应该选择支持浮点型运算的选项,通常是第二个或第三个选项。这个设置会告诉编译器在编译时...

    Ntoskrnl.exe win7蓝屏修复程序

    因此,如果这个问题没有对您造成严重的影响,我们建议您等待包含此修复程序的下一个软件更新。 如果此修补程序可以下载,则此知识库文章顶部会出现"提供修补程序下载"部分。如果未显示此节,请联系 Microsoft 客户...

    C语言程序设计(第2版)-2期 常见问题4-1 if(表达式)后多加了分号.pdf

    在`if`语句后多加一个分号`;`会导致程序行为与预期不符,可能会引发混淆和错误。这个问题在初学者中较为常见,主要体现在两个方面,我们分别通过【示例1】和【示例2】来分析。 【示例1】中,代码如下: ```c int a...

    小程序多业务线融合【完整分包业务接入】

    这些小程序,由一个主小程序和后来新建的多条业务线构成(每条业务线拥有独立的小程序) 各业务线的小程序需要挂载到主程序下面,因为需要主程序导流 同时各业务线自己的小程序也照常发布更新 ==一套代码,通过打包...

    jsnote:使用TypeScript,React和Lerna构建的类似Codepen的JS代码编辑器应用程序

    JSNote JSNote是具有Markdown注释功能的简单JavaScript代码编辑器。 作者:Seokhyun Wie(布兰登) 电子邮件: 课程:JSNote由管理如何安装$ npm install jsnote-bw 怎么跑$ npx jsnote-bw serve 导航到以启动。 您...

    NetMeeting Win7 32位 64位系统之解决

    因为NetMeeting的安装程序要检测Windows版本,所以有可能会报告不兼容,不过没关系,照常运行安装就是了。安装过程中会报告MSASN1.dll的某个函数点无法定位。 现在安装过的NetMeeting还不能运行,需要进行破解(即将...

    嵌入式:韩国LG LS系列PLC解密软件代码

    首先安装编程软件,你必须使用这个版本的编程软件, 3.62版。安装完成后用Kgl_Wc文件替换安装文件夹下的同名文件即可。联机下载后若提示密码输入,可以不予理睬,关闭即可,程序可以照常下载。 本站软件...

    Si7021温湿度传感器arduino库_C++_代码_相关文件_下载

    1. **初始化**:在C++代码中,首先需要实例化一个Si7021类的对象,并进行初始化。通常,这包括设置I²C地址、开启或关闭传感器的内部加热器、设置采样率等。 2. **通信协议**:Si7021通过I²C通信协议与Arduino板...

    FPGA程序设计课程报告(电梯).doc

    本文档是一份 FPGA 程序设计课程报告,主题是基于 FPGA 的电梯控制系统设计。报告详细介绍了电梯控制系统的设计思路、方案论证和 VHDL 程序设计。 知识点1:电梯控制系统的设计思路 电梯控制系统是控制电梯按照...

    PSAutomator:此PowerShell模块是用于在公司基础架构中运行的入职,离职和照常营业流程的新方法

    此PowerShell模块是用于在公司基础架构中运行的入职,离职和照常营业流程的新方法。通常,每个公司对流程的外观都有不同的规则,不同的方法,并且该模块采用的简便方法类似于在IFTTT或Microsoft Flow之类的服务中...

    OculusShaderToy:在 OculusVR 中运行的基于 Qt 的 ShaderToy 代码的实验性端口

    OculusShaderToy 在 OculusVR(DK2,SDK v0.4)中运行的基于 Qt 的代码的实验性端口。 目前这仅适用于 Mac OS X(仅在 Yosemite 上测试),尽管代码几乎是纯 Qt 并且移植到其他平台应该很简单。 随附以下移植着色器...

    matlab有些代码不运行-aMi:基于VisualStudioCode的Matlab替代方案

    matlab有些代码不运行aMi:替代Matlab ide 此扩展是关于什么的 “替代Matlab ide”旨在直接从VSCode提供完整的Matlab用户体验。 此扩展程序正在进行中,功能将按照下面的“功能”部分中的说明进行添加。 此扩展适用...

Global site tag (gtag.js) - Google Analytics