在程序界有一句话很流行,不要重复造轮子。然而,这句话被滥用了。已经渐渐沦为程序员懒惰的借口。甚至因此而盲目指责那些勤奋的人。
大多数情况下初学者很难分清楚自己是不是在重复造轮子。当我头一次听到这句忠告的时候,我变得异常敏感,在做什么之前都要判断一下是否在造轮子。我跟大多数普通人一样,容易受到他人只言片语的不良影响。事实上很多时候,避免造轮子并不是我的首要目标。我的目标是完成一项任务,任务完成的速度要尽量快,质量要尽量好。而不是去判断自己在不在造轮子。
使用他人的现成轮子是实现快速任务的一项捷径。然而,并不总是这样子的。重复造轮子的正面是另外一句行话:吃自己的狗食。在涉及到关键技术点的地方,依赖他人的轮子容易造成高风险。高风险的原因在于:第一、它不是你写的。凭借注释和教程获得支持很有限,当需要功能拓展或者定制时,用起这个初期看起来很好的轮子反而变得碍手碍脚了。第二、当依赖轮子程度比较高的时候,那么它容易限制自己的思维。有些功能用轮子很难拓展,我们会推脱说轮子产生限制。反而不去思考这些功能的提出是否合理。第三、轮子可能是个一次性产品,轮子的开发者不愿再花时间维护。轮子不能与时俱进,那么就会被淘汰。因此你的产品也会遭到淘汰。“吃自己的狗食”的优势便是上述情况的反义。善于吃狗食的人,并不满足应用轮子做事,他们也会乐于阅读不同轮子的源码。去粗取精,博采众长。最终写出属于自己的锋利轮子,达到期望的目标。
除了在关键技术点尽量不要使用他人的轮子。还有重要一点,那就是不要被“重复造轮子”这句话吓怕了。windows有现成的记事本和扫雷,但是每年还是有成千上万的大学生乐此不疲的编写记事本和扫雷程序。更有喜欢折腾的人尝试自己实现红白机上的经典游戏。实践是最好的老师,学生们并不是在重复造轮子,而是以提高为自己的目的。许多开源项目的初始目的并不只是为了做出一件产品,而是为了学习。高手们都明白实践出真知的道理,只是他们实践的技术含量更高而已。所以,千万不要被轮子吓怕,更不要以“轮子”为借口拒绝学习成长。
上面我说了滥用重复造轮子的几个情况以及他们的危害。现在我想将自己的一点小小心得介绍出来——到底什么时候不要重复造轮子?
若我有天想去九寨沟旅游,我想要选择租车自驾游,我肯定不需要关心汽车是怎么工作的。汽车对我来说只是个工具,因为我的目标是旅游。情景发生转变时,一切就变得不一样了。假如我是个汽车设计师,我想测试汽车在九寨沟的山路上能否平稳驾驶。那么我不该关心九寨沟的旅游景点有哪些,而应该关心汽车的内部构成怎样,有没有问题,能否改进。
当使用轮子是为了达成一个日常任务,或是以一个工具形态出现的时候。那么请不要重复造轮子,除非为了学习目的。我常常督促自己多多学习一些shell命令,这样可以避免自己写出一堆轮子脚本。同样的,当我有个新奇想法的时候。我常常会上网搜索有没有朋友已经实现,若有的话直接使用现成的轮子即可。如果没有,那么我只有亲力而为,自己去实现。
有时候我会突然兴冲冲的充满野心。用数据库用的很不爽,不是说“吃自己的狗食”吗?那么把它写出来吧!当然最后一筹莫展,因为这对我来说太难了。也许我花上三五年时间都没法彻底搞懂。同样的还有写个操作系统、写个语言。这些东西也许最佳应亲力而为,但如果它对于自己来说过于复杂,那么就用它吧。因为这别无选择。优秀的程序员不会乐于被这些困难的东西牵着鼻子走,他们会尝试消化并改善它们。
除了遇见这些困难的东西,有时候还会碰到一些并不困难但是很占时间的东西。没有必要盲目开工写这些占时间的东西。在仔细分析已有的几种轮子后可以直接选择其中最优秀的,在它不能合适工作的时候就大刀阔斧的修改它。这其中的关键之处在于你明白轮子工作的原理,如果愿意,只要花上几个月的时间,你能重新写出一个来。
市面上有很多同类产品。明明有肯德基,为什么还出来麦当劳、李先生之类的。有时我会为开发产品的“山寨”而耿耿于怀,这无疑是重复造轮子的行为。别人已经有了,为什么我还要做?几乎同样的逻辑,为什么要重复实现一遍?这的确是重复造轮子,但是这是必要的。原因有:1.虽然产品形态和使用技术类似,但是后台的资源是不同的。用户需要不同的轮子,这样可以使市场有活力。肯德基和麦当劳虽然都是快餐店,经营方式和食品类型也差不多。但总有些微差异,而正是这份差异带来了活力。2.平台化、纵向发展。TX老是被网民骂抄袭,但是似乎越骂用户量反而越高了。因为TX造轮子有深厚的商业目的,它希望做出一个整合一切的平台。统一的平台给资源聚合带来了巨大的好处,用户也会变得更加喜欢用这个简单好用的整合平台。这种造轮子行为从这个角度上说是非常有利的。
分享到:
相关推荐
很多时候,都听人家在说不要重复制造轮子,要站在巨人的肩膀上等....不过让我感到有点困惑的是,怎么样才叫做不要重复制造轮子?如何才能站在巨人的肩旁上?现在网络如此发达,资源如此丰富,开源社区也发展的很好。...
不要再重复造轮子了,Hutool这款开源工具类库贼好使(csdn)————程序
NULL 博文链接:https://basil1292.iteye.com/blog/459911
数据描述符(descriptor)和存取描述符均具有以下可选键值:当且仅当该属性的 conBgurable 为 true 时,该属性描述符才能够被改变,同时该属
1、App/Common/Conf/db.php 数据库连接参数修改; 2、App/Api/Conf/config.php 微信小程序的appid、secret、mchid、key、notify_url,SELF_ROOT的参数修改; 3、ThinkPHP\Library\Vendor\wxpay\lib\WxPay.... ...
在根据SGI-STL仿造轮在的过程中,学习c++和数据结构
重复造轮子。 笔记 谷歌测试文档:见 致谢 所有版权声明移至此处: // Copyright 2006, Google Inc. // All rights reserved. // // Redistribution and use in source and binary forms, with or without // ...
CountDownTimerForTableView学习自,重复造轮子来练习
winform通用开发框架 这个主要就是为了一般管理系统重复避免造轮子,不需要在关注权限 页面等,新增功能只需要新增form界面并完成自己的业务,在系统配置即可。 个人主页有基于该框架开发的简易进销存软件和喷码软件
天天造轮子,手写面试常见源码.zip
【unity造轮子】2d敌人AI的实现,并自动躲避障碍物
# 【Unity造轮子】实现一个类csgo的武器轮盘功能 # 作者信息 姓名:向宇 博客:[https://xiangyu.blog.csdn.net/](https://xiangyu.blog.csdn.net/) # 文章说明: ...
java实现excel转pdf文件,并且支持excel单元格中带有图片的转换 基于 aspose,Excel转为 pdf工具类 Java Excel转为PDF(aspose)工具类 复造轮子 复制即用
Unity套件是Unity3D开发的工具包集合,集成常见的开发组件以免于重复造轮子。 套件设计初衷则是根据业务需求自由组合搭配其中的组件,项目在任何阶段都可以轻松接收。 由多个部分组成的套件,例如:基础组件,...
自己造轮子:一款实用的Android广告栏实现过程2016-01-23 安卓应用频道 安卓应用频道(点击上方公众号,可快速关注)来源:dongjunkun链接:
尝试实现下几种常用Blog API,重复造轮子,是为了锻炼Java编程技巧。 目前支持: getUsersBlogs getUserInfo newPost getPost editPost getRecentPosts deletePost getUsersBlogs getCategories NewMediaObject new...
最近开始一个小 asp.net 项目,整个项目需要登录才能操作。以前大家都采用 asp 的方式 session + cookie 来实现身份验证,我一直对 asp.net 自带的 forms 验证早就耳闻,苦于没实践,今天刚好逮到机会实际应用一下。
WAF 绕过-权限控制之代码混淆及行为造轮子#Safedog 代码层手写及脚本绕过变量覆盖,加密混淆,异或生成#BT Aliyun 代码层手写及脚本绕过编码解码
适合无法使用serlvet3.0的用户,适用于老旧系统使用。
快速入门原型 此存储库包含常用的 Maven 原型模板。 安装: 查看模板 从命令行转到项目根文件夹。 例如:D:/workspace/muzongyan-quickstart-archetypes/quickstart-springmvc-mybatis 执行以下 maven 命令来安装 ...