好程序员不写代码
原标题:好程序员不写代码
乾明 发自 凹非寺
无剑胜有剑,是金庸武侠世界的最高境界。
现实的西方程序员世界里,也有与之如出一辙的精神:The Best Code is No Code At All。最好的代码就是根本没代码。
简单说来,无码胜有码。
△François Chollet
山景城坷垃斯剑派祖师François Chollet最近就连连发Twitter,传扬这种精神,赞同者云集。
他说:
程序员写多少代码不重要,重要的是解决问题的效率。
不用你写、不用你维护的才是好代码——直接用的现成解决方案嘛。
简单几句话,仿佛说到了众多同行的心坎里。他们高喊“太对了”,还用“@”呼朋唤友前来观摩。
Chollet有充分的资格发推布道:他是入门框架Keras的作者、Google研究员、《Python深度学习》一书作者,顶会论文没少发,打Kaggle竞赛也很厉害,最高排到过全球第17名。
圣诞之后新年之前的垃圾时间里,他这条不总结不展望不拜年的Twitter,已经被转发了700多次,收获了2100多赞。
多写代码就是好?
引来这么赞同的核心观点说来也简单:
代码是几十行还是几千行不重要,解决问题才是正经事。
就拿Chollet举的例子来说吧:如果老板让你搞个系统,监控有没有人在厨房做饭,该怎么办?
解决方案一摆,高下立判。
如果买个摄像头,花10000美元收集数据,然后亲自把控训练流程,奋战几周用低级库定制一个CNN-LSTM架构……那是糟糕的程序员,程序员里的战5渣。
好程序员会怎么办呢?
买几个5美元的温度传感器,几个小时收集完数据,然后用sklearn训练一个简单的逻辑回归模型。
一下午就能搞定,而且系统更可靠、更好维护,甚至,还没什么隐私之忧。
有人做饭,厨房自然会热起来嘛!如果只知道拿摄像头检测人形物体,简直是不知变通,费时费力还费钱。
不过这还不算惨,如果程序员搭了CNN-LSTM之后对效果不太满意,再花几周时间,用GAN来扩增数据细心打磨……
“认真”到这个程度,已经超出了战五渣的境界,可以叫那个啥队友了。
方向走错了,花再多力气都是白费。
而这些“认真”程序员花掉的力气,大概也会让Chollet一脸无奈:
就算你非搭CNN不可,为什么要用低端库定制呢?我的Keras里都打包好了,拿来试试不行就换别的啊……
评论区就有网友一针见血地总结:没必要重复发明轮子。
不要重复造轮子
这句话在各行各业都深入人心,程序员界也不例外。
作为Keras这个高级框架的作者和布道者,Chollet对重复造轮子这种行为,更是持之以恒地批判。
前不久,他还在吐槽某些“痛恨框架”的程序员,说他们自己从头构建的东西只不过是重新实现了框架的部分功能,而且设计拙劣、无法复用。
为什么这么推崇用框架呢?是为了站在巨人的肩膀上。那些大型框架是众多人想法和努力的结晶,想自己实现其中一部分功能?那相当于想靠0.01%的努力&脑力出人头地。
好程序员,要善用前人打下的基础。
不过,关于“重复造轮子”这个问题,争论很是激烈。Twitter上、Reddit论坛里,关于“什么时候用框架、什么时候手写”的讨论总是热火朝天。
想自己手动搭模型的程序员各有各的理由。比如说,为了优化程序的性能:
这种说法太短视了,如果追求性能、低延迟,就要重写很多代码,这也没什么问题。
更多重造轮子的人,是为了学习。
不少人都认为,在刚开始学习编程的时候,重造轮子不失为一个好办法,能够让初学者能更好的理解技术或方法背后的逻辑。
比如,如果你想了解PyTorch的原理,以及怎么让它运行得更快,最好的方法,就是自己实现一个简单版本的autograd。
虽然不能够得到一个比PyTorch更好的框架,但通过这个过程,你对PyTorch的理解会变得更加深刻,在之后用到PyTorch的时候,也会更加顺手。
同为Google研究员的David Ha就曾经和Chollet激烈争论过,David说:
从零开始(用纯Python、numpy、甚至JS)实现全连接网络、卷积神经网络、RNN、反向传播、SGD,然后用小训练集来训练这些模型是一种学习神经网络如何工作的好方法。在跳到框架上之前,应该花时间从这里收获宝贵的直觉力。
除此之外,还有一个充满无奈的原因:现成的轮子还真不一定能用。
没开源、不适合这个特定任务,都让开发者们面对轮子的时候很无奈。最近的“圣诞彩蛋”事件,更是让程序员们对轮子充满警惕:
谁知道作者会在轮子里藏些什么东西!
但切记,不论你为什么要自己动手从头实现一个算法,千万不要造出来一个方轮子。
One More Thing
知乎上曾经流传着这样一个问题:程序员真的很少写代码吗?
有网友嘲讽&自黑,说写代码多、天天敲键盘的程序员是“苦力”、“段位不够”。
也有不少人吐槽:还不是因为大部分时间都是在找bug!
话说回来,无论调框架还是从头搭、写文档还是找bug,都是为了实现功能。
你支持有码还是无码呢?
— 完—
相关文章
-
产品观察|淘宝终于有了自己的QQ秀
-
直播带货主播抖音话术脚本运营方案计划书新手小白技巧攻略玩法
-
巴菲特减持苹果,会引发连锁反应吗?
-
图片社交平台Pinterest公开IPO申请书:拟登陆纽交所
-
【得得周报】12.24-12.30|2018年最后一周数字货币总市值下跌5.16%,火币矿池或将上线EOS交易所
-
5G网上线首亮相,价格公布后心凉一半,网友:对不起5G,再见
-
合肥回应ApplePay交通卡落地困难:得给苹果交钱超过承受能力
-
“门外汉”恒大:掀起“地产”造车新运动?
-
氪星晚报|腾讯总市值超阿里巴巴;特斯拉中国用户数据和认证服务将迁至中国;中兴通讯大股东15个月内套现59亿
-
王川任小米中国区总裁 雷军这是在打造第二个"自己"?
-
欲替代谷歌搜索,华为搜索引擎“花瓣搜索”面向国内开放
-
清除黑历史的机会来了!QQ注销功能下周推出:App将更新
-
一人跌落是困境,众人跌落才是“沙雕”梦境!
-
同一天!抖音、微信小程序日活破2亿,头腾大战愈演愈烈
-
霸榜知乎,谴责豆瓣,数据分析告诉你《流浪地球》到底好看么?
-
苹果再陷尴尬英特尔5G芯片或无法按时交货
-
总在论坛做手机的黄章最后还是跑到微博上玩起了调研
-
二十多年前马云在美国找到创业灵感,今天阿里要给全球启示
-
刘强东:你们曾是我兄弟
-
HTC发布眼动追踪Vive Pro Eye、内向外追踪Vive Cosm
-
天猫双11又破纪录!进口产品中,国人最爱日货
-
网友都在给10086发送2019!是个坑?中国移动回复了
-
仅3成中国企业完成了数字化升级,何为转型关键点?
-
被判有效!这局洗碗机专利对决,美的处上风,云米科技会被禁售吗?
-
电子汇入与转账区别是什么
-
跨境电商系列|电商行业的爬虫识别与管理
-
理财课只卖9块钱,长投学堂凭什么年入5000万?
-
BW-20N100W+固定衰减器
-
好未来5篇论文入选人工智能教育国际顶级会议AIED2021