《松本行弘的程序世界》讀書筆記(上)——面向對象、程序塊、設計模式、ajax


1. 前言

半個月之前買了這本書,還是經園子里的一位網友推薦的。到現在看了一半多,基礎的都看完了,剩下的幾章可做高級部分來看。這本書看到現在,可以說感觸很深,必須做一次讀書筆記!

關於這本書,不了解的可以去網上查查。作者是Ruby語言的創始人,可謂是程序世界中的高手,開卷有益,不管你是哪個層次的編程人員,相信都能或多或少的汲取到你想要的營養。

下面將總結一下看完本書我記錄下的一些知識點。有的是書中的原話,有的是我個人的理解,供參考。

 

2. 面向對象

2.1 多態性

面向對象三大原則:繼承、封裝和多態,其中最重要的技術是“多態性”,多態往往會用繼承來表現,而封裝又保證多態的獨立性。多態性可以讓程序只關注做什么,而不是關注怎么做。根據情況的不同,自動選擇最合適的方法來處理。多態也是程序擴展性的基礎。

2.2 歷史

面向對象語言從60年代的Simula,到70、80年代的SmallTalk,直到后來的C++和java,java是最成功、應用最普遍的面向對象語言。本人用C#,和java差不多。UML是描述面向對象方法設計模型的圖示方法(不會UML的抓緊補補吧,這也算是基礎了)。

2.3 結構化編程

在很久很久以前,一些比較低級語言,是通過goto語句來執行代碼的。C語言中有goto語句,一開始學的時候老師就不讓用。goto語句是在出現if...else...(條件判斷)和for、while等循環結構之前,人們用來控制程序的方法。大家試想,如果不讓你用if..else..和for循環,通篇都是goto,那將會是什么結果??所以,用【順序】、【條件】和【迭代】來代替goto語句,是程序開發的一大變革。

另外提一句,如果你從事.net開發,你可能有幸解除到goto語句——IL中間語言,IL相當於.net中的匯編預研。將一個簡單的 if..else...編譯成IL之后,結果如下:

2.4 數據抽象化

前面講到程序結構從goto語句中解放出來,那么程序所操作的數據結構呢?也需要有一種抽象的表達方式,而不是計算式世界所能理解的二進制代碼。最常見是我們常用的數組、鏈表、字典等結構。其實,嚴格來說,程序中的整數、浮點數、各國的語言文字,都是數據抽象的結果。因為計算機只認識二進制字符串。

2.5 多重繼承

如果你是一名java、C#開發人員,你用不到多繼承,因為他們根本就不提供。但是有些語言是支持多繼承的,C++、python。現實世界中需要多繼承,例如以為程序員同時也可能是一位作家,一個部門經理同事也可能是一位父親。但是多繼承如果開放到程序中,就會帶來許多問題。允許一個類有多個父類,復雜度可想而知,因此java禁止使用。但是它用什么來彌補這一缺失——接口interface。

至此,大家要了解接口是因為什么才來到這個世界——因為彌補進制使用多繼承而帶來的問題。但是接口真的能很好的解決這個問題嗎?不見得。因為接口畢竟不能像父類那樣使用。

Ruby中沒有接口(不是所有面向對象語言都有接口的),它通過引用程序塊的方式來實現多繼承。我沒有深入了解Ruby的這塊功能,有興趣的朋友可以研究。

2.6 面向對象是現實世界中具體事物的反映嗎?

作者認為,對“面向對象”最好的解釋是“對數據的結構化”。前文講到結構化編程是將程序流程分為順序、條件和循環三種結構,而面向對象則是在此基礎上的延伸,它將程序處理的數據進行了結構化。通過對象來組織數據,數據就成為一個整體,而不再松散。

這是面向對象最根本的意義,如果理解這一點,那么是否反映現實世界就不重要了。其實像數組、字符串,你也找不出現實世界的什么東西與之對應。

程序是處理抽象數據的。無論以后學習什么技術,都不要滿足於小貓小狗之類的例子。

另外,關於“繼承”,也不要看成是現實世界的真實反映,它就是一些抽象、公用功能的重用方法,這樣反而更好理解。

2.7 靜態語言 VS 動態語言

這里所謂的靜態和動態,指的是數據類型的強弱。例如C#、java就是強類型,js、Ruby就是弱類型。強類型中,每個變量都有明確的數據類型,不能更改,也不能賦其他類型的值,要不然會報錯。而在若類型中,變量的類型是隨着其存儲值動態改變的。

兩者各有好壞。強類型可以在編譯時識別類型錯誤,程序執行的速度會更快,但是不靈活。弱類型靈活,但是有些潛在的錯誤不容易發現。

我恰巧C#和js都用,在我看來,這兩種方式都可以,只要你認真對待,哪個都不會出現大問題。所以了解即可,不必太糾結到底哪個好。

 

3. 程序塊

3.1 閉包

“閉包”這個詞,我是在js中第一次接觸的。不過看來業界通用這個詞匯,大體意思就是應用外部的變量和環境,和js中一樣。作者提到Ruby中可以通過傳遞程序塊的方式實現閉包,我沒有仔細去看細節。不過讀到這里,我想起了以下幾點:

01. jQuery源碼中用到了大量的閉包,了解到js中的閉包會影響到性能和內存。所以,我以后將會非常注意jQuery中閉包的使用,真正深入了解閉包;

02. C語言的函數指針是閉包嗎?

03. C#和java中,哪些用到了閉包?

以后再遇到這種問題、知識點,將關注以下。

3.2 for循環

Ruby中實現for循環的方式是 obj.each(....) 這種方式,和jquery的each循環類似。作者在本章節的后面提到“不用for語句”,因為for語句會破壞對象的封裝性。其實這一點在設計模式中也有專門的解決方案——迭代器模式。

 

4. 設計模式

首先,書中沒有一個一個挨着講每個設計模式。有興趣可以看看我寫的關於設計模式的博客:

換種思路去理解設計模式(上) 

換種思路去理解設計模式(中)

換種思路去理解設計模式(下)

 

大家最好要知道,“設計模式”一詞來源於建築業(曾經是我比較向往的專業,呵呵)。大家常說的設計模式,一般是指《設計模式.可復用軟件的基礎》一書中提到的二十三中設計模式,作者們是GoF。其實這些設計模式並不是作者們創新出來的,而是他們總結當時日常設計工作中,最常用的23中模式,給他們分組、取名,最后成就了一部偉大的作品。所以,GoF做出的貢獻就是將原本沒有名字的東西,給他們起名字,並讓他們成為結構化的知識。這是件很了不起的事,例如美國PMI將日常項目管理工作總結為10大知識領域5大過程組一樣。

 

4.1 設計模式和類庫

類庫是把常用的算法、接口封裝起來,供系統其他模塊使用,或者供其他系統使用,它可以“0成本”重用的。但設計模式的重用,卻不是“0成本”,它是一個很抽象的東西,你要根據實際情況來具體確定。

4.2 開放-封閉 原則(簡稱:OCP)

業界有5大設計原則,其中最重要的就是“開放-封閉原則”——即對擴展開放、對修改封閉。了解設計原則可以查閱:換種思路去理解設計模式(上) 

這里所謂的“對擴展開放”,在面向對象編程中是通過繼承和多態來實現的,繼承允許功能的添加,多態保證接口的穩定性。從實用主義的觀點來看,面向對象的精髓就在於對OCP的實踐。至於把對象看做物體理解起來比較容易,能夠建立現實世界的模型等,只不過是一些錦上添花的東西。

一個優秀的設計模式,肯定能經得住OCP的考驗!

 

5. Ajax

ajax是web開發中比較基礎的東西,基本概念此處不再贅述。

 

5.1 Ajax中的“x”

“x”指的是“XML”。因為在ajax剛開始用的時候,都是用xml格式來傳遞數據,因此xml也被說成是ajax的基本部分之一。但是現在隨着json越來越流行,xml的用武之地越來越少,高版本的瀏覽器直接支持JSON轉換接口。

所以,此處了解即可。開發時該用什么用什么。

5.2 javascript——基於對象的語言

可能你會經常聽到:js是以對象為基礎的語言,所有的數據都是對象,js是基於原型的語言。對,js中沒有“類”的概念,除了基本的值類型之外,其他的數據都以對象來處理,都可以自定義添加屬性,包括函數。js是通過原型來實現所謂的繼承的。

另外,js中的閉包是比較出名的,閉包在js中的應用很多,jQuery源碼中大量使用閉包就是個例證。

這兩個問題,不是一兩句話能說明白的,說實話我現在感覺自己知道一些,但是了解的不是很透徹。不過正在努力的補充。要想把js的“對象”和“閉包”講明白,我想還需要從其他方面下手,將會是一個比較系統的工程。后期我定會搞定它們,並以某種方式講出來。此處點到為止。

 

6 MVC和“猴子補丁”

6.1 MVC

感覺作者本文中只是講述了MVC這個理念,並用小例子解釋。由於我沒有真正參與過MVC的項目,也只是日常的了解,所以對這塊感觸不是很深。

6.2 猴子補丁

所謂的“猴子補丁”,其實就是C#中的部分類和擴展方法。在不改變原來代碼結構的基礎上,添加新代碼。個人不建議這種做法,如果重復這樣做,將會導致代碼松散難以維護。

 

-----------------------------------------------------------------------------

推薦一下我錄制的《asp.net petshop4.0源碼解讀》教程,免費學習!

-----------------------------------------------------------------------------

今晚先到這里,明天繼續寫:

7. 文字編碼

8. 正則表達式

9. 整數與小數

(個人感覺“文字編碼”和“整數與小數”兩章,作者介紹的很好)

 

《松本行弘的程序世界》讀書筆記(下)——文字編碼、整數、浮點小數

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM