原创 Writing when making software

2011-7-8 12:40 1467 16 17 分类: 消费电子

A quote from Donald E. Knuth:


"Let us change our traditional attitude to the construction of programs: Instead of imagining that our main task is to instruct a computer what to do, let us concentrate rather on explaining to human beings what we want a computer to do."


Al Stavely's new book, "Writing in Software Development," is a sorely-needed manifesto for the art of writing when creating software.


I read a lot of code and associated documentation, and, alas, find the state of the art to be essentially at a grade school level. It's ironic that engineers produce, more than anything, documents that are supposed to communicate ideas, yet we're so poor at written communication. Al's book is the Dutch boy's finger in the dike, a well-written attempt to show us what we must do.


Some of the book is patently obvious. Much is thought-provoking. The gestalt, though, really defines the essential work of a software developer. It's an inexpensive (as an e-book) work that's a fast read.


The book takes some swipes at sacred cows like C since it "isn't even object-oriented!" C, though, is the lingua franca of the embedded world.


One suggestion is to use a digital camera to capture diagrams drawn on a whiteboard. I first saw this a couple of years ago when working with a attorney who captured all whiteboard presentations on his camera. Months later he'd still refer to those images. Gray cells are fragile containers of knowledge; digital representations preserve that information for as long as needed.


Another suggestion is to maintain documentation during development, making rough margin notes as you're working, and cleaning them up at the end of the project. I disagree. You won't have time, so those rough notes will be lost. Keep the docs clean all of the time, as we're supposed to do with the code. In other words, keep refactoring the docs.


What about Doxygen? Al likes it, but makes the important point that Doxygen adds no new information at all. It's a useful tool, but no substitute for careful documentation.


Al stresses using assertions as documentation. in "Software Aging," computer scientist David Parnas said "Just as in other kinds of engineering documentation, software documentation must be based on mathematics." Assertions can be a formal way of specifying the intended behavior of a function. Design by Contract, which takes assertions further by converting them into pre- and post-conditions, is one of the most powerful tools we can employ, both to generate correct code, and to document our intentions.


One interesting idea, drawn from Knuth's Literate Programming, is to write all of our code in a word processor, complete with all of the annotations needed. Using html tags and a relatively simple script, the build process strips the code from the file and feeds that to the compiler. A cool idea, but that generates problems when debugging as the "source" file is not the same as the file used by the IDE. When, oh when, will the compiler vendors wean us from brain-dead text files, and allow us the formatting options we have given the word processing world for decades?


All in all, it's a great read and very worthwhile book. Get it here: http://press.nmt.edu/ .

PARTNER CONTENT

文章评论1条评论)

登录后参与讨论

用户1406868 2013-9-13 15:36

always a major fan of linking to bleoggrs that I enjoy but don�t get quite a bit of link really like from[...] [...]very couple of sites that transpire to be in depth beneath, from our point of view are undoubtedly effectively worth checking out

用户1587382 2012-5-27 20:58

顶顶

用户1065050 2012-5-23 23:56

液体金属人,经典啊

用户1608085 2012-5-21 21:54

很期待的!

用户1580664 2012-5-21 16:01

这个得顶顶!

用户1655290 2012-5-21 09:07

这是神马东西。。。

用户1627313 2012-5-11 10:28

注意:违规内容已被屏蔽!

用户1277994 2012-5-11 09:49

苹果iPhone5据说采用这个,今后还能拆解吗?

用户1077287 2012-5-11 09:38

真的有,是好消息!!

用户1190942 2012-5-10 10:44

hao
相关推荐阅读
用户3671694 2016-04-18 17:49
What would you change about C?
If you’re an old-timer you’ve most likely written code in a large number of languages that have ma...
用户3671694 2016-04-18 17:33
A look at a new embedded heap manager
Many of us don’t give much thought about the math our compilers do. Toss off a call to a sine func...
用户3671694 2016-04-15 17:12
Why names are critical
The Linux printk function has various logging levels, which include KERN_EMERG, KERN_ERR and other...
用户3671694 2016-03-14 19:02
What do you think of ultra-low power watchdogs?
I have written extensively about designing ultra-low power systems that operate from coin cells. U...
用户3671694 2016-02-26 21:58
Comment headers: The best and the worst
I read a great deal of code. The vast majority is in C with some C++ and a bit of assembly sprinkl...
用户3671694 2016-02-12 17:58
What's your take on knobs?
In a recent Embedded Muse Richard Wall reviews the latest version of Digilent’s Analog Discovery U...
我要评论
1
16
关闭 站长推荐上一条 /3 下一条