很多人剛看到文學編程這幾個字,就覺得這玩意很好玩匈子,但這些人稍加了解后,又會覺得這玩意是智商稅闯袒,最后一笑而過了虎敦。
只有很少人真正去深入嘗試,在實踐中探索什么是文學編程搁吓。也只有這些人才懂得文學編程的意義原茅。
本文主要總結一下我最近使用文學編程的一些心得。
文學編程的意義到底是什么堕仔?在我是看來擂橘,它的意義在于能夠讓自己更自在地,更順暢地寫代碼摩骨。
當今時代混飯用的編程語言大多是面向對象的語言通贞,不管啥業(yè)務需求,都得分別寫在各式各樣的class里面恼五。如果不寫到class昌罩,輕者被當做傻子,重者被炒了魷魚灾馒。因此代碼的組織結構其實就是class茎用,就是一個個分離的文件。這其實會打斷編程思維的。比如說話轨功,原本一口氣把整段話完整說出即可旭斥,非要把一段話拆成幾段,存成個mp3文件而且還放在不同的文件夾中古涧,這無疑給人理解帶來麻煩垂券。寫代碼跟寫文章一樣,都存在一定的思路羡滑。寫文章可以自由自在地安排段落的順序菇爪,然而寫代碼卻不能,數(shù)據(jù)操作相關的代碼只能放在數(shù)據(jù)類的文件夾中柒昏,工具類的代碼只能放在通用文件夾中凳宙。把某些代碼分類放入不同的文件夾,本質上就是給代碼貼標簽昙楚。遺憾的在于這種方式只能貼一個標簽近速,因為一個代碼文件只能放在一個文件夾中。
而文學編程不是貼標簽堪旧,它像寫文章一樣,你可以自由地安排代碼在文章的位置奖亚,經過文學編程引擎處理之后淳梦,卻能夠滿足工程上的“貼標簽”。
所以我非常喜歡這種文學編程風格昔字。
我使用emacs來玩文學編程爆袍。emacs中有個org模式也是天生適合文學編程的。markdown應該也行作郭,但我沒有嘗試過陨囊。就算markdown可以做,也需要一個不錯的編輯器夹攒,能夠識別代碼的語法錯誤蜘醋。不然開發(fā)效率還是低下。
教程可以參閱:
https://orgmode.org/worg/org-contrib/babel/intro.html
有人翻譯了一部分中文:
https://brantou.github.io/2017/04/01/babel-intro/
其中重點在于如何在文檔中插入代碼咏尝,以及如何生成代碼文件压语。
插入代碼很簡單,emacs快捷鍵: C-c C-, s
emscs會插入如下字符串:
#+begin_src
#+end_src
如果你想編寫的是javascript编检,那么在begin_src后面加上對應的語言名稱即可胎食。
如果想要指定生成文件的路徑,這加上 :tangle 文件路徑
即可允懂。如果不想生成代碼文件厕怜,則不加。
如下:
#+begin_src javascript :tangle task/transTask.js
console.log('hello world')
#+end_src
有時候想要將某些代碼片段加入到一些代碼當中,則參考以下方式:
#+name: hello-world-prefix
#+begin_src sh :exports none
echo "/-----------------------------------------------------------\\"
#+end_src
#+name: hello-world-postfix
#+begin_src sh :exports none
echo "\-----------------------------------------------------------/"
#+end_src
#+name: hello-world
#+begin_src sh :tangle hello.sh :exports none :noweb yes
<<hello-world-prefix>>
echo "| hello world |"
<<hello-world-postfix>>
#+end_src
上面有兩個代碼片段名字分別為: hello-world-prefix粥航, hello-world-postfix琅捏。最后的代碼片段將會輸出到hello.sh,內容引用了前面兩個代碼片段躁锡。
這種方式對于復用一些代碼片段是非常有用午绳。
代碼文章已經編寫完成了,應該如何將代碼輸出呢映之?
快捷鍵: C-c C-v t
就這么簡單拦焚。