(杂谈二) 看看别人是怎么写程序的(程序员的自我修养)

2024-05-11 11:32

本文主要是介绍(杂谈二) 看看别人是怎么写程序的(程序员的自我修养),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1999年,周星驰拍了一部电影叫做《喜剧之王》,一部令人难忘的作品。片中有个情节,迄今记忆犹新。星爷所饰演的主人公,爱上了一位夜总会的小姐,并且与她发生了关系。醒来之后,他把自己的全部身家都留给了她。这中间包括一块手表、几枚硬币,还有一本书。书的名字,我记得很清楚,叫做《演员的自我修养》。

  多年来,我一直在寻找,一本名为《程序员的自我修养》的书。在我的内心深处,一直有一种隐约的信念:这样的一本书,将能够标志软件行业在精神上的成熟。不过,很可惜,一直到今天,我都没有找到这本书。

  当然,这并不是我写这篇文章的理由。以我的资质,来写这样的大题目,并不相称。所以,不妨将我写下来的这些年对此问题的感悟与思考,看成一个戏作。又或者,在其中还能找到一星半点的真知灼见。


  独立思考

  我一直告诫自己,在这个世界上,绝对意义上的独立思考是不存在的。人的思想,被基因、教育、环境所决定,又随着当下的心境、情绪而起伏。不过,这些都不妨碍我们通过不断的内省和诘问揭示事物的真相。OOP,AOP,MDA,Design Pattern,XP,RUP,TDD,...... 是谁在鼓吹他们?又是谁从中得到了利益?

  思考本身是不容易的,所以我碰到过很多程序员特别热衷于马不停蹄地写代码,很少停下来想一下,为什么这么写?要怎么设计程序才会更好?写出来的这个程序是谁在使用?他们想得到的是什么?一个本来是脑力劳动的行当,被他们做成了体力劳动。

  去思考已属难能,再要做到独立,不为时尚所影响,就更其可贵了。因为,独立不止是一种态度,更是一种能力。也正因为此,才要去修养。而且,作为最基本,最重要的一项。因为,没有独立思考,就很难达成自我教育;而没有自我教育,就谈不上自我修养。


  谦卑之心

  机器不是人的奴隶,程序也不是程序员的仆人。它们的成长顺应其自身内在的规律。程序员的工作,就象农民,只是给程序浇水施肥,给它们好的阳光和空气,帮助它们生长发育。在我们所创造的程序面前保持谦卑之心,当它们运行良好时不必欣喜若狂,当它们崩溃时也不会手足无措。

  对于我们的前辈,也要保持谦卑之心,不要认为他们已经落后于时代。他们曾经直接面对裸露的机器,一个字节一个字节地输入程序;他们曾经为了几个字节的运行空间构思过很多奇妙的设计;他们曾经为了使每天只有5分钟的上机调试时间而反复地检视自己的程序;他们曾经为了减少一个循环而绞尽脑汁。他们精益求精,因为硬件的束缚已经使程序创作变成一门艺术。

  而今天,我们的程序之道,正在退化成一种技术。因为,我们已经失去了我们的前辈们曾有过的谦卑之心。


  简洁之道

  没有一个可用的程序是简单的。但这并非所有程序员的共识。很多程序员认为很多程序是简单的,比如MIS系统。我今天所供职的这家公司生产的几乎全是这类系统,这家公司已经做了十年了,其产品依然令人难堪。因为其产品主题不简洁。

  一个程序要成为一个良好运作的系统,需要处理非常多的细节,应对来自硬件、操作系统、其它软件所带来的故障或异常,成千上万的状态,每一个执行都可能产生若干个逻辑分支。这一切,都使一个完备的程序变得异常复杂。但是,也正因为此,一个程序的主题必须遵循简洁之道。复杂的系统需要简洁清晰的主题来支撑才能站起来,不然就会溃散。

  我们通常所做的恰好相反。我们把一个程序的逻辑想得很简单,同时为了炫耀自己的技术而使细节变得毫无必要的繁复,对于主题,则经常是不加思索,不加约束。一个系统是什么,不是什么,讲了半天,写几百页的文档,还是讲不清楚,不知所云。因为我们没有遵循简洁之道。


  大局观

  在软件界,有一种汹涌的努力,正在企图剥夺一个程序员作为一个思想者的乐趣。他们弘扬大方法论,把系统进行精致的分解,由为数不多的几个设计师控制着系统的设计,程序员则变成纯粹的蓝领。其核心要义,是软件系统可以象建筑物一样来构造,程序员最后可以变成砌砖的人。

  这种努力来势汹汹,而且没有引起人们足够的警觉。尽管还没有见过以这种方式构造的真正革命性的软件产品,它已经在宣称,一个工作中的程序员不需要良好的大局观。如果你是一个普通的程序员,你不需要了解你所写的代码所服务的系统,你不需要了解你的程序服务于什么人,你甚至不需要关心你的程序是否真正进入了系统。

  然而,没有大局观,对系统构造而言是一个长远的伤害,系统最终将变得支离破碎。对系统的每一点更改,都会变得让人难以忍受。而对于程序员来说,没有大局观,又意味着什么呢?这个问题,可是值得好好思考。


  清晰阐述

  我一直相信,一个观念,如果不能够被阐述出来,它就是不清晰的;一个程序员,如果不能阐述其程序的主题,那一定是没有深刻地理解这个程序。也许有人会反驳说程序员一般是内向的,不善言辞,可能能写出好程序,但是却讲不清楚。但是,我所见过的程序员,不论看上去多么木讷,只要谈起他们投入热情所写的程序,马上就会变得滔滔不绝,喜形于色。

  在这个问题上,程序员并不能被作为一个特例来对待。清晰阐述,不仅是一个发表观念的动作,更是一种促进思考的工具。很多的思想,都是在阐述的过程中被得到检视,发现了漏洞,进行了完善,或者经过了更深的验证。因为阐述本身为思考提供了明确的标的物,所以它们极有可能再次激发了新的思考。

  作为团队工作中的一个元素,清晰阐述同时也是团队流畅运作的一个基本需求。在清晰阐述的过程中,程序员发现了自我,并开始突破程序员的职业边界。

  什么是好的程序?好的程序不是使人惊叹,而是触动他们的灵魂。就象桥下的流水,安详优雅地流淌,偶尔碰到礁石,或者激起浪花,但都能够自我包容,毫无阻滞的运行。如果我们能写出这样的程序,那么,我们的自我修养就已经走上了正道。
 

我相信思考是成功的秘诀,我特别热爱极限攀岩,而且是徒手攀岩,在不断挑战自我,面临死亡的情况下,仍然能够保持清醒的头脑去思考。写程序也是一样的,真的算起来,虽然我写过不少代码,但是写代码占用的时间其实连15%都不到,更多的时间我在思考,在设计,在推敲,在。。。

这篇关于(杂谈二) 看看别人是怎么写程序的(程序员的自我修养)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/979410

相关文章

golang程序打包成脚本部署到Linux系统方式

《golang程序打包成脚本部署到Linux系统方式》Golang程序通过本地编译(设置GOOS为linux生成无后缀二进制文件),上传至Linux服务器后赋权执行,使用nohup命令实现后台运行,完... 目录本地编译golang程序上传Golang二进制文件到linux服务器总结本地编译Golang程序

使用Docker构建Python Flask程序的详细教程

《使用Docker构建PythonFlask程序的详细教程》在当今的软件开发领域,容器化技术正变得越来越流行,而Docker无疑是其中的佼佼者,本文我们就来聊聊如何使用Docker构建一个简单的Py... 目录引言一、准备工作二、创建 Flask 应用程序三、创建 dockerfile四、构建 Docker

怎么用idea创建一个SpringBoot项目

《怎么用idea创建一个SpringBoot项目》本文介绍了在IDEA中创建SpringBoot项目的步骤,包括环境准备(JDK1.8+、Maven3.2.5+)、使用SpringInitializr... 目录如何在idea中创建一个SpringBoot项目环境准备1.1打开IDEA,点击New新建一个项

qt5cored.dll报错怎么解决? 电脑qt5cored.dll文件丢失修复技巧

《qt5cored.dll报错怎么解决?电脑qt5cored.dll文件丢失修复技巧》在进行软件安装或运行程序时,有时会遇到由于找不到qt5core.dll,无法继续执行代码,这个问题可能是由于该文... 遇到qt5cored.dll文件错误时,可能会导致基于 Qt 开发的应用程序无法正常运行或启动。这种错

电脑提示xlstat4.dll丢失怎么修复? xlstat4.dll文件丢失处理办法

《电脑提示xlstat4.dll丢失怎么修复?xlstat4.dll文件丢失处理办法》长时间使用电脑,大家多少都会遇到类似dll文件丢失的情况,不过,解决这一问题其实并不复杂,下面我们就来看看xls... 在Windows操作系统中,xlstat4.dll是一个重要的动态链接库文件,通常用于支持各种应用程序

python编写朋克风格的天气查询程序

《python编写朋克风格的天气查询程序》这篇文章主要为大家详细介绍了一个基于Python的桌面应用程序,使用了tkinter库来创建图形用户界面并通过requests库调用Open-MeteoAPI... 目录工具介绍工具使用说明python脚本内容如何运行脚本工具介绍这个天气查询工具是一个基于 Pyt

Ubuntu设置程序开机自启动的操作步骤

《Ubuntu设置程序开机自启动的操作步骤》在部署程序到边缘端时,我们总希望可以通电即启动我们写好的程序,本篇博客用以记录如何在ubuntu开机执行某条命令或者某个可执行程序,需要的朋友可以参考下... 目录1、概述2、图形界面设置3、设置为Systemd服务1、概述测试环境:Ubuntu22.04 带图

Python程序打包exe,单文件和多文件方式

《Python程序打包exe,单文件和多文件方式》:本文主要介绍Python程序打包exe,单文件和多文件方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录python 脚本打成exe文件安装Pyinstaller准备一个ico图标打包方式一(适用于文件较少的程

Python程序的文件头部声明小结

《Python程序的文件头部声明小结》在Python文件的顶部声明编码通常是必须的,尤其是在处理非ASCII字符时,下面就来介绍一下两种头部文件声明,具有一定的参考价值,感兴趣的可以了解一下... 目录一、# coding=utf-8二、#!/usr/bin/env python三、运行Python程序四、

Mac备忘录怎么导出/备份和云同步? Mac备忘录使用技巧

《Mac备忘录怎么导出/备份和云同步?Mac备忘录使用技巧》备忘录作为iOS里简单而又不可或缺的一个系统应用,上手容易,可以满足我们日常生活中各种记录的需求,今天我们就来看看Mac备忘录的导出、... 「备忘录」是 MAC 上的一款常用应用,它可以帮助我们捕捉灵感、记录待办事项或保存重要信息。为了便于在不同