当前位置: 首页 > 编程日记 > 正文

[转]优秀编程的“艺术”

优秀的代码是一件艺术品?或者软件工艺宣言言过其实了?成为一名“优秀”的程序员,有什么要求?

设想你雇佣了一名水管工,让他更换地下室的旧管道。这个家伙在工作之前、之中、之后,他就没有停止过谈论他的管道工艺的艺术美。

“看看那根管道的角度。看看它与墙壁对齐是多么地美?如果你问我,那么它就是一件艺术品。”

这和程序员没什么区别。没有什么比 不可一世的程序员把他或她自己的代码看做是艺术品 更糟糕的了。这个类推借用了”敏捷麻烦制造者”和BDD【注1】创立者Dan North的一篇广受赞誉的文章,Dan North激烈地批判了软件工艺宣言,论证了“编程不是艺术”。

软件工艺宣言

宣言的作者Kevlin Henney、Bob Martin、Corey Haine和Glenn Vanderburg揭示了下面几项将通往软件工艺的大门:

  • 不仅是可运行的软件,而且是精心设计的软件。
  • 不仅响应变化,而且稳步增加价值。
  • 不仅个体与交互(Individuals and Interactions),而且是专家社区。
  • 不仅仅是客户协作,而且是有生产力的合作伙伴。

North的问题在于,软件开发者的自尊经常妨碍其成为优秀的软件项目。North谈到,用“精心设计的软件”这种荣耀的概念进一步加压到自尊上,是达不到预期的。Webservice和J2EE就是最近的项目例子,软件艺术性的崇高诠释部分地导致了项目的失败。

优秀的编程

你或许已经知道了来自于小型IT项目的这种问题。某个开发者主张使用特定技术是因为审美(而非务实)的原因。从此就每况愈下了。

根据North的观点,代码优美是因为它能有效地运行,而不是因为审美上有吸引力。不应该太计较代码看起来怎么样,而是看代码在从A点到B点带来的一段信息是多么可靠、高效。

“一个技术娴熟的编程团队可以在非常短的时间里交付让人惊奇的业务结果。一名真正的专家——真正的工匠——将理解埋葬在、比如我们把企业软件称作的杂乱里的、优雅的简单,并整理清楚。” ——Dan North

但是悲哀的是,甚至那些优秀的程序员经常忘记优秀软件的核心职能——软件工艺宣言的过分强调往往是祸因。

“软件从业者—特别具有讽刺意味的是优秀的软件从业者—经常忘记这一点。他们爱上了软件本身,开始把他们自己看做软件工匠。”——Dan North

开发者需要多大的才能?

这里有个引起整个争论的问题:软件工程是一种艺术形式吗?焦点集中在 对他们的工作充满激情的有热情的专家 和 只为薪水工作的程序员 之间的挣扎上。

据说性能和效率在软件行业的差异正在缩小,但是就成为优秀开发者的条件定义而言,没有达成一致或被认可的方法。Dan North说,“一名真正伟大的程序员胜过数百个为钱做事的程序员,在数小时或数天就可以交付,而普通程序员要用数周或数月。”

“做为软件解决方案的买家,难道你不想知道你的系统是被大师级工匠而非拿薪水的人开发的?你支付了钱,你有权保持某种信心。让我们搞清楚怎样提供这种软件。”——Dan North

North声称,“架构之美”无助于我们区别好坏。任何程序员都能把他或她自己称作软件工匠,滔滔不绝、高谈阔论软件架构的“美”。North对我们说,他将“乐于看到有人根据结果导向和取悦客户来重写软件工艺宣言。”

地下室与代码

房主不关心他们的水管看起来如何,只要它们不漏水就行。软件同样如此。客户和用户都不关心它是如何运转的,尤其不关心它内部看起来是否“美”。

“同样,我想让专家级电工而非新手给我的屋子布线,我想让专家级程序员涉足我的业务,”North对我们说。“然而,我不想要一个坚持谈论管道系统优雅与审美的、恃才傲物的管道工。”

  • 原文地址:http://jaxenter.com/programming-art-and-software-craftsmanship-112123.html
  • 注1:行为驱动开发(缩写BDD)是一种敏捷软件开发的技术,它鼓励软件项目中的开发者、QA和非技术人员或商业参与者之间的协作。BDD最初是由Dan North在2003年命名,它包括验收测试和客户测试驱动等的极限编程的实践,作为对测试驱动开发的回应。在过去数年里,它得到了很大的发展。http://zh.wikipedia.org/wiki/行为驱动开发

转载于:https://www.cnblogs.com/thanksmoons/p/4077848.html

相关文章:

洛谷 P5019 铺设道路(差分)

嗯... 题目链接:https://www.luogu.org/problem/P5019 首先简化一下题意: 给定一个长为N的数组,每次操作可以选择一个区间减去1,问最少多少次操作可以将数组中的数全变成0 N≤100000 思路: 首先对于第一个数字d_1我们至…

1小时教你做360度全景“小星球”效果图 Skillshare – Create a Panoramic ‘Little Planet’ from Anywhere

1小时教你做360度全景“小星球”效果图 Skillshare – Create a Panoramic ‘Little Planet’ from Anywhere 1小时教你做360度全景“小星球”效果图 Skillshare – Create a Panoramic ‘Little Planet’ from Anywhere 时长1h 2m 1280X720 MP4 语言:英语中文字幕…

BIO、NIO、AIO详解

BIO(Blocking I/O)就是传统的Java IO编程,其相关的类和接口在java.io包下。BIO是同步阻塞的,服务器实现模式为一个连接一个线程,即客户端有连接请求时服务器端就需要启动一个线程进行处理,如果这个连接不做任何事情会造成不必要的线程开销,可以通过线程池机制改善(实现多个客户连接服务器)服务器端启动一个,注册端口,调用accpet方法监听客户端的Socket连接客户端启动Socket对服务器进行通信,默认情况下服务器端需要对每个客户建立一个线程与之通讯。

Java学习总结:12

多态性 1.方法的多态性:重载和覆写 重载:同一个方法名称,根据不同的参数类型及个数可以完成不同的功能; 覆写:同一个方法,根据不同的实例化的子类对象不同,所完成的功能也不同。 2.对象的多态性…

10万字总结Java8到21新特性详解

Java 8 是Java历史上一个重大的版本更新,发布于2014年3月18日。Lambda 表达式是在 Java 8 中引入,并且被吹捧为 Java 8 最大的特性。它是函数式编程的的一个重要特性,标志着 Java 向函数式编程迈出了重要的第一步。或者其中parameters:是 Lambda表达式的参数列表,可以为空或包含一个或多个参数。->:是 Lambda 操作符,用于将参数和 Lambda 主体分开。expression:是 Lambda 表达式的返回值,或者在主体中执行的单一表达式。

10万字总结Java8到21新特性详解

Java 17,发布于 2021 年 9 月,是一个长期支持(LTS)版本。Java 18,于2022年3月发布。Java 19, 于2022-09-20 发布众所周知,JVM 是一个多线程环境,它通过为我们提供了对操作系统线程的抽象,但是 Java 中的线程都只是对操作系统线程的一种简单封装,我们可以称之为“平台线程”。代价昂贵:创建平台线程的成本很高。每当创建一个平台线程时,操作系统都必须在堆栈中分配大量内存来存储线程的上下文、原生调用堆栈和 Java 调用堆栈。

iOS 对UIImage进行的一些操作

1、生成指定宽高的UIImage对象(oldImage为原始图片对象,newImage为操作后的图片对象) // 参数1:图片的尺寸 参数2:是否透明(没看出YES和NO有什么区别) 参数3:缩放(1表示不缩放) (1) UIGraphicsBeginImageContextWithOptions(CGSize size, BOOL opaque, CGFloat scale) (2) U…

mysql基础之视图

原文:mysql基础之视图 在查询中,我们经常把查询结果 当成临时表来看. View是什么? View可以看一张虚拟表. 是表通过某种运算得到的一个投影. 既然视图只是表的某种查询的投影,所以主要步骤在于查询表上.查询的结果命名为视图就可以了. 视图与表的关系 视图是表的查询结果,自然…

Maya教程-XGEN制作毛发技能学习 Patreon – Cartoon Grooming Series by Jesus FC

Maya教程-XGEN制作毛发技能学习 Patreon – Cartoon Grooming Series by Jesus FC Maya教程-XGEN制作毛发技能学习 Patreon – Cartoon Grooming Series by Jesus FC Maya教程-XGEN制作毛发技能学习 Patreon – Cartoon Grooming Series by Jesus FC Patreon – Cartoon Groom…

2.抽取代码(BaseActivity)

知识点俩种退出程序的方法复制集合同步的用法字符数组工厂模式,生产fatgment,解决了碎片重复创建的问题全局上下文actionbar用法fargmentadapter,当viewpager里是fargment的话更方便1.抽取BaseActivity 管理所有activity 方便退出 public c…

C语言画圆(编译器:VS2013)

一.graphics.h库的添加 方法一 先下载所需文件: graphic头文件解决方法(密码:6z3y) 1.先打开include文件夹 2.将里面的文件复制粘贴到VS2013安装目录的include文件夹中,如下: 3.打开下载好的文件夹中的…

JVM内存调优原则及几种JVM内存调优方法

JVM内存调优原则及几种JVM内存调优方法 1、堆大小设置。 2、回收器选择。 1、在对JVM内存调优的时候不能只看操作系统级别Java进程所占用的内存,这个数值不能准确的反应堆内存的真实占用情况,因为GC过后这个值是不会变化的,因此内存调优的时…

Meta标签中的format-detection属性及含义

format-detection翻译成中文的意思是“格式检测”,顾名思义,它是用来检测html里的一些格式的,那关于meta的format-detection属性主要是有以下几个设置:meta name"format-detection" content"telephoneno"meta…

Unity 3D游戏代码编程学习教程 Full Guide To Unity 3D C#: Learn To Code Making 3D Games

Unity 3D游戏代码编程学习教程 Full Guide To Unity 3D & C#: Learn To Code Making 3D Games Full Guide To Unity 3D & C#: Learn To Code Making 3D Games Unity 3D&C语言完整指南学习教程:学习编写3D游戏代码 由迈克尔穆尔创作|最后更新日期:2021年…

Java学习总结:13

抽象类 定义: 所谓抽象类就是指在普通类的结构里面增加抽象方法的组成部分,抽象方法指的是没有方法体的方法,同时抽象方法还必须使用abstract关键字进行定义。拥有抽象方法的类一定属于抽象类,抽象类要使用abstract声明。 关于抽…

九度OJ 1339:ACM (排序)

时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:712 解决:379 题目描述:今年的ACM世界总决赛快要开始了,需要有一个排名算法来对每支队伍进行现场排名。ACM组委会把这个任务交给了你&#xff0…

2022-2028年中国汽车印制电路板(汽车PCB)产业深度调研及投资前景预测报告

【报告类型】产业研究 【报告价格】4500起 【出版时间】即时更新(交付时间约3个工作日) 【发布机构】智研瞻产业研究院 【报告格式】PDF版 本报告介绍了中国汽车印制电路板(汽车PCB)行业市场行业相关概述、中国汽车印制电路板(汽车PCB)行业市场行业…

【VMCloud云平台】SCO(四)流程准备

在经过这么多介绍文章后,我们终于可以开始拨开云雾见真章了,今天来做一些制作流程前的预热。(下图红色为部署中,紫色为实施完成,蓝色为计划中): 1、 流程,我们要了解它,可…

基本类型的数值转换

为了方便运算及调用一些方法,我们需要将基本类型的数值转换为对象;不过转换的时候需要特别注意好它们的类型到底是什么,需要调用方法的类名是哪个!特别注意是Byte常量池的相关问题();gc()垃圾回收机制的话&…

Java学习总结:14

接口 接口的基本定义 接口严格来讲属于一个特殊的类,而且这个类里面只有抽象方法与全局变量。 在java里面可以使用interface关键字来实现接口的定义。 例:定义接口 interface A{ //定义接口public static final String MSG"Hello World"; /…

Unity中创建本地多人游戏完整案例视频教程 Learn To Create A Local Multiplayer Game In Unity

Unity中创建本地多人游戏完整案例视频教程 Learn To Create A Local Multiplayer Game In Unity MP4 |视频:h264,1280x720 |音频:AAC,44.1 KHz,2 Ch 流派:电子学习|语言:英语原英文字幕 (机译中文字幕)|时长:15章 70…

第十二周 11.15-11.21

11.15 补个BC。 HDU 5565 Clarke and baton 没太懂题解怎么搞。反正挺暴力过了。 1 #include <iostream>2 #include <cstdio>3 #include <map>4 #include <vector>5 #include <algorithm>6 using namespace std;7 typedef long long LL;8 const …

Java 多线程的基本方式

Java 多线程的基本方式 基础实现两种方式&#xff1a; 通过实现Callable 接口方式&#xff08;可得到返回值)&#xff1a;

一次HP 阵列卡排障

公司使用的是HP gen8机器&#xff0c;用的是p420i阵列卡&#xff0c;同时在系统的另一端&#xff0c;nagios监控系统配合nrpe脚本check_hpasm定期检测硬件健康。最近为了让机器更带劲&#xff0c;加上了SSD硬盘&#xff0c;机械硬盘仅用作大容量存储&#xff0c;在感受速度与激…

集合、泛型、增强for

对于集合&#xff0c;首先要明确的是最顶层的接口是Collection接口类&#xff0c;其包含一些基本的方法以便子类调用&#xff0c;不过在定义的时候最好定义好数据类型&#xff0c;以免遍历时还得必须进行向上转型&#xff1b;特别注意的是其没有关于下标的方法。同时为了方便遍…

【强推】Blender制作逼真人物角色完整案例视频教程

【强推】Blender制作逼真人物角色完整案例视频教程 【强推】Blender制作逼真人物角色完整案例视频教程 时长53h 30m 1280X720 MP4 含教程工程文件 共九大模块 130小节课程 教程大小&#xff1a;12.9G 语言:英语机译中文字幕&#xff08;含原英文字幕文件&#xff09; Victory…

Java学习总结:15

Object类 Object类的基本定义 Object类是所有类的父类&#xff0c;也就是说任何一个类在定义时如果没有明确地继承一个父类&#xff0c;那它就是Object类的子类。 取得对象信息&#xff1a;toString() 在Object类中的toString()方法设计时&#xff0c;由于要考虑其可以满足…

ECMAScript——引用数据类型之array

array 转载于:https://www.cnblogs.com/cataway/p/4967058.html

2022-2028年中国炼钢行业市场研究及前瞻分析报告

【报告类型】产业研究 【报告价格】4500起 【出版时间】即时更新&#xff08;交付时间约3个工作日&#xff09; 【发布机构】智研瞻产业研究院 【报告格式】PDF版 本报告介绍了中国炼钢行业市场行业相关概述、中国炼钢行业市场行业运行环境、分析了中国炼钢行业市场行业的…

mvc存储Cookie和读取Cookie方法

mvc存储Cookie和读取Cookie方法&#xff1a;//存储HttpCookie cookie new HttpCookie("User");System.Text.Encoding enc System.Text.Encoding.GetEncoding("gb2312");cookie["id"] HttpUtility.UrlEncode(logid.ToString(), enc);cookie[&q…