你從未聽說過的一種編程方式

jopen 13年前發布 | 6K 次閱讀 編程

本文是從 A Programming Idiom You've Never Heard Of 這篇文章翻譯而來。


下面是一系列的動作:

從小屋里拿出耙子,用它把院子里的樹葉堆起來,然后把耙子放回小屋。

飛到西雅圖,看風景,然后飛回。

把鑰匙插進鑰匙孔,打開,然后取出鑰匙。

點亮你的手機,查看時間,然后把它置回睡眠狀態。

看到這些模式沒?你做一種事情,然后做另外一種事情,然后又撤銷你做的第一件事情。或者用更精確的說法,這最后的一步是第一步的反向操作。一旦你認識到這種模式,你會發現它無處不在。拿起茶杯,喝一口茶,放回茶杯。同樣,在程序代碼里有到處都是:

打開一個文件,讀取內容,關閉文件。

分配一段內存,用它做一些事情,釋放它。

把內存地址內容加載到寄存器,修改它,然后存回內存。

雖然這很容易解釋,也很容易舉出例子,但想實現它卻不那么容易。我們需要的這種操作看起來應該像這個樣子:idiom(Function1, Function2),于是我們上面說的打開文件的例子應該是idiom(Open, Read)這個樣子。問題是,需要有一種程序的方法能知道這“open”的反向操作是“close”。是否有一種語言,里面的方法可以反向執行?

也許會讓你驚訝:有。這就是J語言。我在這里反復嘮叨的這種編程模式,實際上是J語言里的一個內置函數,叫做under。在英語里,這打開文件的例子可以說成“read under open”。

“under”在J語言里一個非常常見的用處就是計算vector的數量級。算法非常簡單:平方每個元素,把值加起來,然后取平方根。哈哈,這第三步正好是第一步的反向。求和 “under” 平方。在J語言里的寫法是:

mag =: +/&.:*:

+/ is “相加”。 這&號,點號,分號序列就是“under”。*:就是“平方”。

本文轉載自: 外刊IT評論 http://www.aqee.net/

 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!