偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

C++ 能否成為你新的腳本語言?

開發(fā) 后端
第一個我真正喜愛的編程語言是 C。我花了不少時(shí)間才找到它:當(dāng)我還是一個孩子,我就開始在珍貴的ZX Spectrum上使用 Z80 匯編。那些日子是你能夠真正掌握你的電腦的時(shí)候,你不需要蘋果,谷歌,微軟或者其他任何人的允許就能寫一個程序。

一些背景

***個我真正喜愛的編程語言是 C。我花了不少時(shí)間才找到它:當(dāng)我還是一個孩子,我就開始在珍貴的ZX Spectrum上使用 Z80 匯編。那些日子是你能夠真正掌握你的電腦的時(shí)候,你不需要蘋果,谷歌,微軟或者其他任何人的允許就能寫一個程序。我在漂亮的128K ZX Spectrum +2上學(xué)習(xí)了在超出 CPU 尋址空間時(shí)對內(nèi)存塊分頁。直到我進(jìn)入大學(xué),我才擁有一臺 IBM PC 機(jī) 。我玩遍了電子表格,試圖修復(fù)現(xiàn)存的 Fortran 程序,用土耳其字符給鍵盤驅(qū)動打補(bǔ)丁,還學(xué)了點(diǎn) Pascal 語言。之后,在我就職于土耳其中央銀行期間,我又學(xué)習(xí)了 SQL 和 APL。

[[135397]]

我一直對 C 語言有所耳聞,但我一直沒有接觸到一款C語言編譯器。直到我到康奈爾大學(xué)擁有了一個Unix 賬號之后,我編譯了我人生中的***個 hello.c 文件,不久之后,我有了***臺電腦……我在 DOS 分區(qū)上安裝了 DJGPP 編譯器,構(gòu)建了我人生中***個 Linux 內(nèi)核(我***個發(fā)行版是 Debian),并且開始學(xué)習(xí) C 語言。Plauger 的 “Standard C Library” 是我最喜歡的書。

當(dāng)我開始享受用 C 編程的時(shí)候,C++ 已經(jīng)廣泛應(yīng)用超過十年了。所以,我下一步使用 C++ 看起來是很自然的一步了。

除了……好吧,除了 C++ 是一片混亂。那段時(shí)間,所有人都被繼承層次深深吸引了,每個人都在編寫精心設(shè)計(jì)的字符串類。大多數(shù)硬盤都太慢,不能再有限的時(shí)間內(nèi)編譯出可靠的 C++ 庫(好吧,我有點(diǎn)夸張了),大部分 CPU 都在試圖實(shí)例化模板中融化了,大部分人,那些假裝 C++ 程序員的 C 程序員們,差點(diǎn)就把 malloc 的返回值給扔了。

在那時(shí),我正忙于試圖建立定制化的網(wǎng)絡(luò)經(jīng)濟(jì)實(shí)驗(yàn),看起來 Java 似乎很有優(yōu)勢。至少,它不需要麻煩地拼湊出一個對話框。產(chǎn)生少量的 socket 連接,并且使你的應(yīng)用編譯和運(yùn)行在多種多樣的系統(tǒng)上。當(dāng)然,AWT 和 Swing 都很丑陋且笨重,但對我的目的來說,那沒關(guān)系。

但是,僅僅是因?yàn)椴荒茉趯?shí)驗(yàn)室之外運(yùn)行我的實(shí)驗(yàn)(因?yàn)樵趯?shí)驗(yàn)室已經(jīng)配置了所有電腦,java應(yīng)用程序運(yùn)行不會有問題)。所以我快速的把 FreeBSD部署到了一臺擁有100Mhz奔騰處理器,16Mb內(nèi)存,在角落里收集灰塵的機(jī)器上,并搭建了一個擁有perl模塊(mod_perl)的 Apache服務(wù)器,然后就能工作了。那就是我愛上Perl的時(shí)候。

那份愛完全起源于實(shí)用的原因,我并不是認(rèn)為Perl特別的***,并且那時(shí)候我認(rèn)為包括其他許多語言都不是很***,他們中的每一個都有自己的瑕疵。

Perl總是能減少我必須解決的特別問題的工作的數(shù)量,有些是因?yàn)檎Z言特性,但大部分是因?yàn)?span style="font-family: 'Microsoft YaHei', Verdana, sans-serif, 宋體; font-size: 13.3333330154419px; line-height: 21.3333320617676px; background-color: #f6f6f6;"> CPAN。

舉例來說,作為一個 Perl 程序員,解析 HTML 作為 HTML 是一個解決方案。我必須決定,要么就構(gòu)造整個樹, 或者使用流化的方式。在某些情況下,前者是具有優(yōu)勢的,但后者的好處是可以使內(nèi)存的需求降至***,即使是在這個年代,如果你處理 HTML 文檔以兆字節(jié)方式還是可以奏效的。不論哪種方式,這些工具都不會在無效的 HTML 上被卡住,并在非 XML 的有效 HTML 上運(yùn)作良好。

還有,Perl 提供可移植性。如果我不需要操作系統(tǒng)特定的功能,不用任何修改地方,我的 perl 代碼就可以運(yùn)行。

當(dāng)我寫了一些類,并為它們做了封裝,也不會有復(fù)雜的架構(gòu)。

C++ 涅槃

在過去的數(shù)年,C++如獲新生。許多聰明人已經(jīng)開始意識到須要向C++程序員提供同時(shí)涵蓋 work of the ISO committee boost的構(gòu)建模塊。

在真實(shí)環(huán)境下,仍然有90%的菜鳥生成C++程序員就是沒有意識到new是一個合法符號的C程序員。在這方面,C++與Perl非常相似:大部分人寫過Perl代碼的人也沒有意識到Perl不是C、Java、Python、shell、Awk或者其他你可以列舉的語言。

但是,當(dāng)你看到新C++標(biāo)準(zhǔn)中的新東西,以及編譯器不斷實(shí)現(xiàn)浙西特性的新聞時(shí),我們無法抑制住內(nèi)心的興奮和好奇。

單詞計(jì)算練習(xí)

這是一個簡單的練習(xí),使用 C++ 或者 Perl 并且不依賴外部庫,所以這是一個很好的起點(diǎn)。

這是 Perl 版本,供您參考:

 

  1. #!/usr/bin/env perl 
  2.  
  3. use strict; 
  4. use warnings; 
  5.  
  6. run(/@ARGV); 
  7.  
  8. sub run { 
  9.     my $argv = shift; 
  10.     my @counts; 
  11.  
  12.     for my $file ( @$argv ) { 
  13.         my $count = -1; 
  14.         eval { 
  15.             $count = word_count($file); 
  16.             1; 
  17.         } or warn "$@"
  18.  
  19.         push @counts, { 
  20.             file => $file, 
  21.             word_count => $count, 
  22.         }; 
  23.     } 
  24.  
  25.     for my $result (@counts) { 
  26.         printf "%s: %d words/n", $result->{file}, $result->{word_count}; 
  27.     } 
  28.  
  29. sub word_count { 
  30.     my $file = shift; 
  31.     my %words; 
  32.  
  33.     open my $fh, '<', $file 
  34.         or die "Cannot open '$file': $!"
  35.  
  36.     while (my $line = <$fh>) { 
  37.         my @words = split ' ', $line; 
  38.         $words{ $_ } += 1 for @words; 
  39.     } 
  40.  
  41.     close $fh; 
  42.  
  43.     my $word_count; 
  44.     $word_count += $_ for values %words; 
  45.     return $word_count; 

而且,這是我***的付出在轉(zhuǎn)化 Perl 到現(xiàn)代風(fēng)格的 C++ 上面。我沒有嘗試寫特別搞笑的代碼:只是和 Perl 一樣,我把重點(diǎn)放在寫代碼上面,使得我感到非常自然,同時(shí)確保兩個程序都做大致相同的事情。

 

  1. #include <cerrno> 
  2. #include <cstdio> 
  3. #include <cstdlib> 
  4. #include <fstream> 
  5. #include <iostream> 
  6. #include <numeric> 
  7. #include <unordered_map> 
  8. #include <string> 
  9. #include <vector> 
  10.  
  11. using std::accumulate; 
  12. using std::cerr; 
  13. using std::cout; 
  14. using std::endl; 
  15. using std::ifstream; 
  16. using std::make_pair; 
  17. using std::pair; 
  18. using std::strerror; 
  19. using std::string; 
  20. using std::unordered_map; 
  21. using std::vector; 
  22.  
  23. int word_count(const char *const file) noexcept(false); 
  24.  
  25. int main(int argc, char *argv[]) { 
  26.     vector< pair<string, int> > counts {}; 
  27.  
  28.     for (auto i = 1; i < argc; i += 1) { 
  29.         try { 
  30.             counts.push_back(make_pair(argv[i], word_count(argv[i]))); 
  31.         } catch (const string& e) { 
  32.             cerr << e << endl; 
  33.             counts.push_back(make_pair(argv[i], -1)); 
  34.         } 
  35.     } 
  36.  
  37.     for (auto& result : counts) { 
  38.         cout << result.first << ": " << result.second << " words" << endl; 
  39.     } 
  40.  
  41.     return 0; 
  42.  
  43. int 
  44. word_count(const char *const file) noexcept(false) { 
  45.     errno = 0; 
  46.     ifstream fp(file); 
  47.     { 
  48.         // Does fp.fail() preserve errno? 
  49.         int save_errno = errno; 
  50.         if (fp.fail()) { 
  51.             throw("Cannot open '" + string(file) + "': " + strerror(save_errno)); 
  52.         } 
  53.     } 
  54.  
  55.     unordered_map<string, int> word_count {}; 
  56.     string word; 
  57.  
  58.     while (fp >> word) { 
  59.         word_count[word] += 1; 
  60.     } 
  61.  
  62.     fp.close(); 
  63.  
  64.     return accumulate( 
  65.         word_count.cbegin(), 
  66.         word_count.cend(), 
  67.         0, 
  68.         [](int sum, auto& el) { return sum += el.second; } 
  69.     ); 

20 行代碼用于 #include 和 using 聲明可能看起來有點(diǎn)多,但是我抬眼 using namespace std,也討厭不斷地輸入 std::… 更多的是因?yàn)槲蚁矚g較短的代碼行。

首先要注意的是沒有看得見的顯式的內(nèi)存分配。容器集裝箱管理自己的內(nèi)存。

第二,這是一個大問題:我們有自動導(dǎo)入(autovivification)!

 

  1. unordered_map<string, int> word_count {}; 
  2. string word; 
  3.  
  4. while (fp >> word) { 
  5.     word_count[word] += 1; 

第三,我們有 lambda 表達(dá)式:

  1. return accumulate( 
  2.     word_count.cbegin(), 
  3.     word_count.cend(), 
  4.     0, 
  5.     [](int sum, auto& el) { return sum += el.second; } 
  6. ); 

在這背后,accumulate 將內(nèi)部變量初始化為 0,并調(diào)用一個匿名函數(shù),其***一個參數(shù)指定為當(dāng)前值,以及word_count的下一個元素。

現(xiàn)在,我不得不承認(rèn),我不知道這些特性是如何實(shí)現(xiàn)的,但是 Microsoft Visual C++ 2015 RC 成功運(yùn)行了,微軟似乎終于趕上了在該領(lǐng)域的***發(fā)展。

現(xiàn)在的情況

然而,一切都不樂觀。盡管 boost libraries 填補(bǔ)了許多空白,而且標(biāo)準(zhǔn)庫提供了令人印象深刻的構(gòu)件,但是也很難戰(zhàn)勝 Perl 和 CPAN 結(jié)合帶來的那種編寫可在任何地方***運(yùn)行的可移植代碼的便利性。

例如,我能找到一個平臺無關(guān)的庫,可以讓我在不需要 Excel 的情況下解析或創(chuàng)建 Excel 文件嗎?這個庫能夠用 clang、g++ 和 cl 輕易地編譯出來嗎?好像不太可能。

我真的非常感謝標(biāo)準(zhǔn)委員會的人們的辛勤工作,和那些開發(fā)編譯器,眾多庫的人們。它們讓我不必在編寫 C++ 程序時(shí)辛苦的思考。

這讓我在真正控制我的計(jì)算機(jī)時(shí)還能感覺舒適。

在這里,我真的非常感謝。

你可以在/r/cpp評論本文。

責(zé)任編輯:王雪燕 來源: oschina
相關(guān)推薦

2009-06-10 08:41:15

Linux腳本語言

2024-05-24 14:16:11

2011-08-16 10:03:45

Groovy編程語言Web

2022-07-04 08:35:57

Vim 9.0Linux腳本語言

2011-08-22 18:00:53

Lua語言

2010-02-24 14:04:32

Python腳本語言

2023-01-09 16:44:53

編程語言C++C

2010-02-26 09:33:51

Python腳本

2012-07-16 11:23:18

LinuxWindows腳本語言

2011-08-25 10:40:21

Lua游戲

2011-08-22 16:59:28

Lua

2011-08-25 11:02:04

2011-06-22 10:14:49

JVM

2011-07-06 16:54:44

ASP

2011-07-05 10:39:55

JVM

2011-05-07 08:35:22

PHP

2022-07-20 15:20:40

谷歌開源

2011-08-22 18:08:09

Lua腳本

2010-02-26 13:03:31

Python腳本語言

2011-09-07 09:51:27

Javascript
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號