青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

平凡的世界

神鷹忽展翅,頭頂青天飛
隨筆 - 10, 文章 - 0, 評論 - 34, 引用 - 0
數據加載中……

[原][譯] Tips for Better Coding Style --- 關于更好的編程風格的建議

[C/C++] - Tips for Better Coding Style

關于更好的編程風格的建議 (v1.5)

Translated By Phoenix(phoenix8848@gmail.com)

    In this entry, I show you 4 tips that address frequently asked questions from C++ programmers of all levels of expertise. It's surprising to discover how many experienced programmers are still unaware of the deprecation of the .h notation of standard header files, the proper usage of namespaces, and the rules regarding binding of references to temporary objects, for example. These issues and others will be discussed here.
    在這篇文章里我將談談各種層次的C++程序員經常問及的四個問題。例如我很驚訝地發現還有很多程序員沒有意識到標準頭文件擴展名.h的爭議,命名空間的恰當用法以及引用臨時對象的規則。這些問題及其它將在這里進行討論。

    First, we start by explaining the difference between the deprecated “xxx.h” header names and the modern, standard-compliant “xxx” header-naming notation. Next, we explore a few dark corners of C++ which due to compilers' limitations and the somewhat recondite nature of the associated language rules tend(原文為“rulestend”) to confuse many programmers, e.g., the notion of comma-separated expressions and the rules of binding references to rvalues. Finally, we will learn how to invoke a function prior to a program's startup.

    首先我們從解釋受非議的“XXX.h”頭文件名與現代、符合標準的“<XXX>”頭文件名記號之間的區別開始。接下來我們探索C++不為人知的角落,由于編譯器的局限性和關聯語言規則某些隱蔽的自然特性迷惑了許多程序員,比如逗號分隔表達式的意義與引用型變量的規則。最后我們將學習如何在程序啟動前啟動一個函數。

    Tip 1: “iostream.h” or “iostream”?

    語題1:“iostream.h” or “iostream”?

    Many C++ programmers still use “iostream.h” instead of the newer, standard compliant “iostream” library. What are the differences between the two? First, the .h notation of standard header files was deprecated more than five years ago. Using deprecated features in new code is never a good idea. In terms of functionality, “iostream” contains a set of templatized I/O classes which support both narrow and wide characters, as opposed to “iostream.h” which only supports char-oriented streams. Third, the C++ standard specification of iostream's interface was changed in many subtle aspects. Consequently, the interfaces and implementation of “iostream” differ from those of “iostream.h”. Finally, “iostream” components are declared in namespace std whereas “iostream.h” components are global.

     很多C++程序員還在使用“iostream.h”代替新的符合標準的“iostream”庫。兩者有什么區別呢?首先,標準頭文件“.h”擴展名在五年前就倍受爭議。在新代碼中使用有爭議的(過時的)特性永遠都不是一個好主意。從本質上看,“iostream”包括一系列支持窄字符與寬字符的模板化(templatized) I/O輸入輸出類,而相反地,“iostream.h”只支持字符流。第三,iostream接口的標準C++規范在許多細節方面進行了變動。因此,“iostream”的接口與實現同那些“iostream.h”是有區別的。最后,“iostream”是在std命名空間中定義的而“iostream.h”則是全局的。

    Because of these substantial differences, you cannot mix the two libraries in one program. As a rule, use “iostream” unless you're dealing with legacy code that is only compatible with “iostream.h”.

    由于這些本質方面的不同,不能在同一程序中混合使用這兩種庫。作為一個規則,應盡量使用“iostream”,除非你要處理的是只能與“iostream.h”兼容的遺留代碼。(感謝autumnm1981

    Tip 2: Binding a Reference to an R-Value

    話題2:將引用與右值綁定

    (R-Value:右值,與“左值”相對。例如x=3中,“x”是一個“左值”,“3”是一個右值。從本質上講,左值是一個內存的地址,右值是一個實際的二進制值。)

    R-Values and L-Values are a fundamental concept of C++ programming. In essence, an R-Value is an expression that cannot appear on the left-hand side of an assignment expression. By contrast, an L-Value refers to an object (in its wider sense), or a chunk of memory, to which you can write a value. References can be bound to both R-Values and L-Values. However, due to the language's restrictions regarding R-Values, you have to be aware of the restrictions on binding references to R-Values, too.

    右值和左值是C++編程的一個基本概念。本質上來講右值是一個不可能出現在等號左邊的表達式。相反,左值引用一個對象(廣義范圍上的),或者一塊可讀寫的內存。引用既可以指向右值也可以指向左值。然而,由于語言在處理右值上的限制,你也得在將引用指向右值是慎重考慮。

    Binding a reference to an R-Value is allowed as long as the reference is bound to a const type. The rationale behind this rule is straightforward: you can't change an R-Value, and only a reference to const ensures that the program doesn't modify an R-Value through its reference. In the following example, the function f() takes a reference to const int:

    將引用與右值綁定像引用常量(這里const type應為"常量",感謝新奧爾良土鱉 )一樣也是被允許的。這條原則背后的原理是很顯而易見的:你無法改變右值,因為對常量的引用確保程序不會通過這個接口改變右值。下面的例子,f()函數包含一個對整型變量的引用。

1 void f(const int & i);
2 
3 int main()
4 {
5 f(2); /* OK */
6 }


    The program passes the R-Value 2 as an argument to f(). At runtime, C++ creates a temporary object of type int with the value 2 and binds it to the reference i. The temporary and its reference exist from the moment f() is invoked until it returns; they are destroyed immediately afterwards. Note that had we declared the reference i without the const qualifier, the function f() could have modified its argument, thereby causing undefined behavior. For this reason, you may only bind references to const objects.

    這段代碼將右值“2”做為函數f()的一個參數。代碼運行時,C++將創建一個值為2的臨時整型變量并將其與引用類型i綁定。這個臨時對象與它的接口將在 f()運行期間一直存到直到函數f返回。函數f返回后它們立即被釋放。注意我們沒有將i聲明為常量類型,但是函數f仍有可能修改它的這個參數,這將引起異常。因此最好是將引用與常量類型綁定。

    The same rule applies to user-defined objects. You may bind a reference to a temporary object only if it's const:

    同樣的規則適用于自定義類型。只有一個臨時對象為常量時才可以與引用類型綁定。

struct A{};

1 void f(const A& a);
2 
3 int main()
4 {
5     f(A()); /* OK, binding a temporary A to a const reference*/
6 }


    Tip 3: Comma-Separated Expressions

    話題3:逗號表達式

Comma-separated expressions were inherited from C. It's likely that you use such expressions in for- and while-loops rather often. Yet, the language rules in this regard are far from being intuitive. First, let's see what a comma separated expression is.

    逗號表達式是從C語言沿襲下來的。它就像你經常使用的for循環與while-loop循環一樣。但是這里面的語法規則遠不像看起來的那樣。首先,讓我們看看什么是逗號表達式。

    An expression may consist of one or more sub-expressions separated by commas. For example:

    一個表達式可以被逗號分隔為一個或若干個子表達式。例如:

1     if(++x, --y, cin.good()) /*three expressions*/


The if condition contains three expressions separated by commas. C++ ensures that each of the expressions is evaluated and its side effects take place. However, the value of an entire comma-separated expression is only the result of the rightmost expression. Therefore, the if condition above evaluates as true only if cin.good() returns true. Here's another example of a comma expression:

    這條if語句被逗號分事為三個表達式。從C++的角度每個表達式都是合法的但是副作用產生了。整個逗號表達式的值是由最右邊的表達式決定的。于是只有con.good()的返回值是true時整個表達式的值才是true。這里有另一個關于逗號表達式的例子。

1 int j=10;
2 int i=0;
3 
4 while++i, --j)
5 {
6     /*..repeat as long as j is not 0*/
7 }


    Tip 4: Calling a Function Before Program's Startup

    在程序啟動前調用函數

Certain applications need to invoke startup functions that run before the main program starts. For example, polling, billing, and logger functions must be invoked before the actual program begins. The easiest way to achieve this is by calling these functions from a constructor of a global object. Because global objects are conceptually constructed before the program's outset, these functions will run before main() starts. For example:

    有些應用需要在主程序啟運前運行啟動函數。例如投票、支付和登錄函數必須在實際種程序啟動前運行。一個最簡單的實現方法就是在一個全局對象的構造函數里調用這些函數。因為全局對象在程序的最開頭被隱式的創建,這些函數就可以在main()函數之前得到運行。例如:

 1 class Logger
 2 {
 3 public:
 4     Logger()
 5     {
 6         activate_log();
 7     }
 8 };
 9 
10 Logger log; /*global instance*/
11 
12 int main()
13 {
14     record * prec=read_log();
15     //.. application code
16 }


    The global object log is constructed before main() starts. During its construction, log invokes the function activate_log(). Thus, when main() starts, it can read data from the log file.

    全局對象log在main()函數啟動之前被創建。在它的構造函數里,log調用了active_log()函數。于是,當main()函數啟動時,它可以從日志文件中讀取數據。


posted on 2008-09-15 23:13 西門有悔 閱讀(2471) 評論(12)  編輯 收藏 引用

評論

# re: [原][譯]關于更好的編程風格的建議  回復  更多評論   

很好的東西呀!
Tip1里講的東西我以前還真沒意識到,一直用.h呢,呵呵。
2008-09-16 00:14 | abettor

# re: [原][譯]關于更好的編程風格的建議  回復  更多評論   

@abettor

謝謝。

我是第一次試著翻譯一些自己認為比較好的文檔,一方面是為了增加自己的知識,另一方面也是為與大家一起分享。

有什么翻譯得不好的地方歡迎討論。我的email:phoenix8848@gmail.com
2008-09-16 01:42 | 西門有悔

# re: [原][譯]關于更好的編程風格的建議  回復  更多評論   

As a rule, use “iostream” unless you're dealing with legacy code that is only compatible with “iostream.h”.
結論為除非在處理與“iostream”保持兼容的歷史遺留代碼時否則最好使用“iostream.h”。

這里翻譯有誤,應該譯為:應盡量使用“iostream”,除非你要處理的是只能與“iostream.h”兼容的遺留代碼。
2008-09-16 09:06 | autumnm1981

# re: [原][譯]關于更好的編程風格的建議  回復  更多評論   

const應該翻譯成常量
靜態是static
2008-09-16 10:02 | 新奧爾良土鱉

# re: [原][譯]關于更好的編程風格的建議  回復  更多評論   

為什么都喜歡留著英文?一跳一跳的,覺得不方便閱讀啊
2008-09-16 11:52 | 肥仔

# re: [原][譯]關于更好的編程風格的建議[未登錄]  回復  更多評論   

因為有時候翻譯可能不正確
2008-09-16 13:05 | 陳梓瀚(vczh)

# re: [原][譯]關于更好的編程風格的建議  回復  更多評論   

@autumnm1981

對啊。非常感謝!我馬上更新
2008-09-16 15:52 | 西門有悔

# re: [原][譯]關于更好的編程風格的建議  回復  更多評論   

@新奧爾良土鱉

寒啊。竟然犯這樣低級的錯誤。也反映了平時我以靜態變量與常量沒有在意。

謝謝。馬上更新。
2008-09-16 15:53 | 西門有悔

# re: [原][譯]關于更好的編程風格的建議  回復  更多評論   

@陳梓瀚(vczh)

對啊。昨天晚上沒有睡覺,半睡半醒狀態下翻的。說實話很多英文的文檔看起來還是很費勁。雖然俺也過了CET6,不過是五年前的事了。
2008-09-16 15:55 | 西門有悔

# re: [原][譯] Tips for Better Coding Style --- 關于更好的編程風格的建議[未登錄]  回復  更多評論   

睡覺是人生的終極目標……
2008-09-17 13:10 | 陳梓瀚(vczh)

# re: [原][譯] Tips for Better Coding Style --- 關于更好的編程風格的建議  回復  更多評論   

Thx to your great sharing!
From:Kven
2008-09-18 00:40 | Kven

# re: [原][譯] Tips for Better Coding Style --- 關于更好的編程風格的建議  回復  更多評論   

The same rule applies to user-defined objects. You may bind a reference to a temporary object only if it's const:

同樣的規則適用于自定義類型。只有一個臨時對象為常量時才可以與引用類型綁定。


這里的"only if it's const"感覺應該是修飾"reference",即翻譯為“只有當引用為const時才可以將其綁定到一個臨時對象”,《C++編程思想》上好像也提到了這點,不知道是不是我理解有誤。
2009-07-22 10:01 | k.j
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲小说欧美另类社区| 亚洲区欧美区| 欧美亚洲一区二区三区| 性欧美videos另类喷潮| 国产精品女人久久久久久| 欧美有码视频| 欧美精品在线观看一区二区| 99re6热在线精品视频播放速度| 亚洲激情在线激情| 欧美三级在线播放| 午夜精品久久久久久99热| 欧美一区二区三区啪啪| 亚洲精品中文字幕在线| 亚洲欧美日韩一区二区| 日韩午夜精品| 久久久亚洲影院你懂的| 久久激情视频| 国产精品久久综合| 亚洲激情婷婷| 在线播放国产一区中文字幕剧情欧美| 另类亚洲自拍| 欧美精品二区| 欧美第一黄色网| 国产精品中文在线| 日韩午夜免费视频| 一区二区三区不卡视频在线观看| 久久九九免费视频| 久久欧美中文字幕| 国产亚洲一级| 欧美一区二区视频97| 久久―日本道色综合久久| 国产精品一区2区| 亚洲欧美日韩国产精品| 小黄鸭精品aⅴ导航网站入口| 国产精品专区第二| 欧美一区2区视频在线观看| 久久久久久高潮国产精品视| 国产精品性做久久久久久| 久久久久国产成人精品亚洲午夜| 国产精品久久久久久久午夜| 午夜激情综合网| 欧美91视频| 亚洲欧美变态国产另类| 韩国v欧美v日本v亚洲v| 牛人盗摄一区二区三区视频| 91久久在线观看| 亚洲一区在线播放| 亚洲国产精品美女| 国产精品久久久久婷婷| 久久综合免费视频影院| 亚洲午夜羞羞片| 欧美成人高清| 久久精品99久久香蕉国产色戒| 黄色亚洲网站| 国产精品入口夜色视频大尺度| 久久久99免费视频| 亚洲欧美国产日韩中文字幕| 最新亚洲视频| 老鸭窝亚洲一区二区三区| 一本高清dvd不卡在线观看| 国语自产在线不卡| 国产色综合久久| 国产精品扒开腿做爽爽爽软件 | 欧美女主播在线| 久久免费黄色| 久久国产加勒比精品无码| av成人毛片| 一区二区三区精密机械公司| 亚洲日本中文| 中文有码久久| 亚洲欧美在线x视频| 香蕉久久一区二区不卡无毒影院 | 在线播放日韩专区| 狠色狠色综合久久| 亚洲国产成人porn| 91久久国产综合久久| 亚洲激情专区| 在线视频精品一区| 久久成人国产| 久久亚洲私人国产精品va媚药| 欧美在线影院| 亚洲高清三级视频| 99视频超级精品| 久久久久久97三级| 欧美三级午夜理伦三级中视频| 国产精品美女999| 亚洲性线免费观看视频成熟| 欧美不卡视频| 午夜精品在线看| 亚洲精品乱码久久久久久蜜桃麻豆 | 久久成人一区| 亚洲三级影院| 欧美亚洲日本一区| 欧美国产日韩视频| 国产精品一区二区久久久| 韩国一区二区三区美女美女秀| 91久久国产精品91久久性色| 亚洲男人的天堂在线观看| 老色鬼久久亚洲一区二区| 香蕉尹人综合在线观看| 香蕉久久夜色精品国产使用方法 | 在线观看日韩国产| 欧美亚洲视频一区二区| 亚洲视频在线观看免费| 久久久人成影片一区二区三区观看 | 欧美一区二区精品久久911| 亚洲国产一区视频| 香蕉久久夜色精品国产| 亚洲婷婷免费| 国产麻豆综合| 美乳少妇欧美精品| 久久蜜桃精品| 夜久久久久久| 亚洲一区国产视频| 国产一区二区三区黄视频| 久久久五月婷婷| 久久久亚洲一区| 99re视频这里只有精品| 一本在线高清不卡dvd | 久久成人精品| 麻豆精品精华液| 在线一区日本视频| 午夜日韩在线观看| 亚洲人成啪啪网站| 亚洲免费影视| 亚洲黄色天堂| 午夜一区二区三区不卡视频| 伊人一区二区三区久久精品| 亚洲乱码国产乱码精品精可以看| 国产精品久久久久久久第一福利 | 欧美a级一区| 午夜精品网站| 欧美日本国产精品| 久久久久国产精品人| 欧美日韩久久| 亚洲高清自拍| 狠狠爱综合网| 欧美有码视频| 欧美一区二区三区在| 欧美日韩精品免费观看视一区二区 | 日韩写真视频在线观看| 亚洲精品乱码久久久久| 欧美在线视频免费| 久久国产精品电影| 国产日韩欧美综合| 亚洲国产成人porn| 夜夜嗨av一区二区三区| 午夜精品久久久久久久白皮肤| 一区电影在线观看| 欧美全黄视频| 亚洲一区在线免费| 欧美影院一区| 在线观看精品视频| 久久艳片www.17c.com| 亚洲二区在线观看| 日韩一级精品| 国产免费一区二区三区香蕉精| 亚洲在线1234| 狂野欧美性猛交xxxx巴西| 亚洲黄一区二区三区| 欧美日韩一区二区三区在线看| 夜夜夜久久久| 久久最新视频| 亚洲免费小视频| 伊人激情综合| 国产精品国产三级国产a| 久久欧美肥婆一二区| 日韩视频中午一区| 欧美成人蜜桃| 久久精品国产91精品亚洲| 亚洲国产精品一区二区www| 欧美日韩一级黄| 久久嫩草精品久久久久| 午夜精品久久99蜜桃的功能介绍| 欧美a级片网站| 久久久久久999| 亚洲一区二区精品| 亚洲伦理在线观看| 亚洲电影免费观看高清完整版在线| 国产精品hd| 欧美性猛交一区二区三区精品| 蜜臀av一级做a爰片久久| 久久成人这里只有精品| 性欧美1819性猛交| 亚洲自拍另类| 亚洲欧美激情一区| 亚洲一区免费观看| 亚洲欧美国产日韩中文字幕| 99国产精品久久久久久久成人热| 欧美成人免费观看| 欧美激情一区二区久久久| 两个人的视频www国产精品| 嫩模写真一区二区三区三州| 欧美成人午夜激情在线| 欧美国产一区二区| 一本色道综合亚洲| 久久精品亚洲一区| 久久一区二区三区av| 免费国产一区二区| 99精品视频网|