• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            隨筆 - 6  文章 - 8  trackbacks - 0
            <2025年8月>
            272829303112
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            常用鏈接

            留言簿(1)

            隨筆檔案

            搜索

            •  

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            一種語(yǔ)言代表了一種思維,而思維決定了問(wèn)題的解決方式。

            ?

            從程序設(shè)計(jì)語(yǔ)言出現(xiàn)到現(xiàn)在已經(jīng)經(jīng)歷了四代。大多數(shù)高級(jí)語(yǔ)言都對(duì)應(yīng)到第三代或四代程序設(shè)計(jì)語(yǔ)言。按其主要支持的編程模型(思維模式)分類,大致可以分為如下類型

            1 過(guò)程型:這類語(yǔ)言把應(yīng)用抽象為序列化的操作步驟,其典型代表如PASCAL,C等。

            2 函數(shù)型:這類語(yǔ)言把應(yīng)用抽象為函數(shù)(按定義,函數(shù)是從一個(gè)域到另一個(gè)域的映射);它們?cè)噲D把問(wèn)題分解為集合和集合間的函數(shù)關(guān)系。典型代表是LISP。

            3 邏輯型:這類語(yǔ)言把問(wèn)題抽象為事實(shí)與規(guī)則的結(jié)合,試圖通過(guò)邏輯演算解決實(shí)際問(wèn)題。典型代表是PROLOG。

            4 面向?qū)ο笮停哼@類語(yǔ)言從上世紀(jì)80年代后迅速發(fā)展,這類語(yǔ)言試圖將實(shí)際問(wèn)題抽象為獨(dú)立的對(duì)象以及對(duì)象間的交互,典型代表是早期的SmallTalkEiffel

            5 面向數(shù)據(jù)結(jié)構(gòu)型:這類語(yǔ)言將問(wèn)題抽象為對(duì)結(jié)構(gòu)化數(shù)據(jù)的操作,例如現(xiàn)在常用的SQL。

            ?

            作為一個(gè)誕生與上世紀(jì)80年代初期的編程語(yǔ)言,C++被廣泛的認(rèn)為是一種支持面向?qū)ο蟮恼Z(yǔ)言;但是,我認(rèn)為C++的偉大之處卻更多的在于(除了所提供完備的面向?qū)ο笾С郑┧瑯犹峁┝?/span>C的面向過(guò)程的編程模型以及只有少數(shù)高級(jí)語(yǔ)言能支持的范型編程(我更喜歡叫它面向算法的編程)。在實(shí)際的應(yīng)用過(guò)程中,我們往往需要不同層次的抽象,C++所支持的廣泛的編程模型為我們提供了強(qiáng)大和靈活的工具,使得我們?cè)谠O(shè)計(jì)和實(shí)現(xiàn)時(shí)能自如的選擇不同的模型,以最合理的(組合)方式解決問(wèn)題。

            ?

            不可否認(rèn),在當(dāng)今的程序設(shè)計(jì)中,面向?qū)ο笠呀?jīng)基本上是一統(tǒng)江湖,但它往往并不是最合理的選擇;例如在針對(duì)協(xié)議棧的開發(fā)中,使用面向過(guò)程的模型往往優(yōu)于使用面向?qū)ο蟮哪P停ɑ蛟S這也是為什么主流的電信設(shè)備供應(yīng)商堅(jiān)持使用C的原因?);而在針對(duì)算法進(jìn)行抽象時(shí),使用面向?qū)ο蟮乃季S模式幾乎完全是不可行的(算法和對(duì)象間的不同之處是顯而易見(jiàn)的);如果機(jī)械的運(yùn)用面向?qū)ο笏季S,只能使最終產(chǎn)品的質(zhì)量、可維護(hù)性、可讀性下降。

            ?

            或許有人會(huì)問(wèn),那么應(yīng)該如何選擇抽象方式呢?我覺(jué)得這個(gè)應(yīng)該是因人和問(wèn)題的不同而不同的,關(guān)鍵是在使用C++的過(guò)程中,多從這些方面進(jìn)行思考、總結(jié),以體會(huì)采用不同模式解決問(wèn)題的優(yōu)缺點(diǎn),努力使用最合理的方式(或組合)對(duì)問(wèn)題進(jìn)行抽象并加以解決。我也常常為這些種種選擇而迷惑,因此在這兒也希望那些已經(jīng)到了“不惑”層次的哥們多多指教。

            ?

            當(dāng)然,從另一方面來(lái)說(shuō),越多的選擇往往意味著越難的選擇,這或許也是為什么現(xiàn)在這么多人趨騖與更單純、更簡(jiǎn)單的JAVA,C#的原因吧;但是當(dāng)我們真正理解并掌握C++提供的這些編程模型時(shí),我想我們會(huì)更加堅(jiān)定當(dāng)初選擇C++的信念;D

            ?

            時(shí)間倉(cāng)促,不正之處敬請(qǐng)指教。

            posted on 2007-03-28 14:29 Neal 閱讀(1205) 評(píng)論(1)  編輯 收藏 引用

            FeedBack:
            # re: C++的編程模型 2007-03-29 00:58 小熊
            學(xué)習(xí)學(xué)習(xí)了  回復(fù)  更多評(píng)論
              

            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


            久久综合狠狠色综合伊人| 欧美午夜A∨大片久久| 久久精品中文闷骚内射| 久久精品国产一区| 伊人色综合九久久天天蜜桃| 99久久精品国产麻豆| 午夜精品久久久久9999高清| 久久久精品国产sm调教网站| 99久久精品费精品国产| 日韩人妻无码一区二区三区久久99 | 国产精品中文久久久久久久| 久久人做人爽一区二区三区| 国产成人精品三上悠亚久久| 久久99久久99小草精品免视看| 香蕉99久久国产综合精品宅男自 | 日韩va亚洲va欧美va久久| 久久精品国产乱子伦| 欧美午夜精品久久久久久浪潮| 久久久久夜夜夜精品国产| 亚洲人成伊人成综合网久久久| 久久国产精品偷99| 亚洲乱亚洲乱淫久久| 91久久精品91久久性色| 日韩精品久久无码人妻中文字幕| 久久综合九色综合欧美就去吻| 精品久久久无码中文字幕| 久久96国产精品久久久| 蜜臀av性久久久久蜜臀aⅴ | 一本一道久久精品综合| 狠狠色丁香婷婷综合久久来| 人妻精品久久久久中文字幕一冢本| 久久受www免费人成_看片中文| 久久久久国产成人精品亚洲午夜| 99久久综合狠狠综合久久| 国产福利电影一区二区三区久久老子无码午夜伦不 | 综合久久一区二区三区 | 亚洲伊人久久成综合人影院| 久久av免费天堂小草播放| 久久精品三级视频| 久久99久久成人免费播放| 无码精品久久一区二区三区|