diff --git a/howto/mro.po b/howto/mro.po
index e492034a8e..38ad23d9f8 100644
--- a/howto/mro.po
+++ b/howto/mro.po
@@ -19,7 +19,7 @@ msgstr ""
#: ../../howto/mro.rst:4
msgid "The Python 2.3 Method Resolution Order"
-msgstr ""
+msgstr "Python 2.3 方法解析順序"
#: ../../howto/mro.rst:8
msgid ""
@@ -27,10 +27,13 @@ msgid ""
"documentation. The Method Resolution Order discussed here was *introduced* "
"in Python 2.3, but it is still used in later versions -- including Python 3."
msgstr ""
+"這是一份歷史文件,作為正式文件的附錄提供。此處討論的方法解析順序 (Method "
+"Resolution Order) 是在 Python 2.3 中\\ *引入*\\ 的,但仍在後續版本中使用,包"
+"括 Python 3。"
#: ../../howto/mro.rst:13
msgid "By `Michele Simionato `__."
-msgstr ""
+msgstr "作者:`Michele Simionato `__。"
#: ../../howto/mro.rst:0
msgid "Abstract"
@@ -44,10 +47,13 @@ msgid ""
"not aware of other publicly available documents with the same scope, "
"therefore it should be useful.*"
msgstr ""
+"*此文件適用於想要了解 Python 2.3 中使用的 C3 方法解析順序的 Python 程式設計"
+"師。雖然它不是為初學者準備的,但透過許多實際範例進行教學。我沒找到其他具有相"
+"同範圍的公開文件,因此這應該很有用。*"
#: ../../howto/mro.rst:23
msgid "Disclaimer:"
-msgstr ""
+msgstr "免責聲明:"
#: ../../howto/mro.rst:25
msgid ""
@@ -56,12 +62,15 @@ msgid ""
"follows* should *be correct, but I don't give any warranty. Use it at your "
"own risk and peril!*"
msgstr ""
+"*我根據 Python 2.3 授權條款將此文件捐贈給 Python 軟體基金會。如同往常,我警告"
+"讀者,以下內容\\ *應該*\\ 是正確的,但我不提供任何保證。使用時風險自負!*"
#: ../../howto/mro.rst:30
msgid "Acknowledgments:"
-msgstr "致謝"
+msgstr "致謝:"
#: ../../howto/mro.rst:32
+#, fuzzy
msgid ""
"*All the people of the Python mailing list who sent me their support. Paul "
"Foley who pointed out various imprecisions and made me to add the part on "
@@ -70,16 +79,21 @@ msgid ""
"Rossum who enthusiastically added this document to the official Python 2.3 "
"home-page.*"
msgstr ""
+"*感謝 Python 郵件清單中所有向我提供支持的人員。Paul Foley 指出了各種不精確之"
+"處,並促使我加入了本地優先順序 (local precedence ordering) 的部分。David "
+"Goodger 協助 reStructuredText 的格式化。David Mertz 協助編輯。最後,Guido "
+"van Rossum 熱情地將此文件加入到 Python 2.3 官方首頁。*"
#: ../../howto/mro.rst:40
msgid "The beginning"
-msgstr ""
+msgstr "開端"
#: ../../howto/mro.rst:42
msgid "*Felix qui potuit rerum cognoscere causas* -- Virgilius"
-msgstr ""
+msgstr "*Felix qui potuit rerum cognoscere causas* -- Virgilius"
#: ../../howto/mro.rst:44
+#, fuzzy
msgid ""
"Everything started with a post by Samuele Pedroni to the Python development "
"mailing list [#]_. In his post, Samuele showed that the Python 2.2 method "
@@ -91,8 +105,15 @@ msgid ""
"readable discussion of the C3 algorithm for Pythonistas who want to "
"understand the reasons for the change."
msgstr ""
+"一切始於 Samuele Pedroni 向 Python 開發郵件清單發表的貼文 [#]_。在他的貼文"
+"中,Samuele 指出 Python 2.2 的方法解析順序不是單調的 (monotonic),並提議用 "
+"C3 方法解析順序來取代它。Guido 同意他的論點,因此 Python 2.3 現在使用 C3。C3 "
+"方法本身與 Python 無關,因為它是由研究 Dylan 語言的人所發明的,並在針對 Lisp "
+"程式設計師的論文 [#]_ 中描述。本文為想要了解變更原因的 Python 程式設計師提供"
+"了 C3 演算法的(希望)易懂的討論。"
#: ../../howto/mro.rst:55
+#, fuzzy
msgid ""
"First of all, let me point out that what I am going to say only applies to "
"the *new style classes* introduced in Python 2.2: *classic classes* "
@@ -103,12 +124,18 @@ msgid ""
"differs from the Python 2.2 method resolution order are so rare that no real "
"breaking of code is expected. Therefore:"
msgstr ""
+"首先,讓我指出的是,我要說的只是適用於 Python 2.2 中引入的\\ *新式類別 (new "
+"style classes)*:*經典類別 (classic classes)*\\ 保持其舊方法解析順序,深度優"
+"先然後由左到右。因此,經典類別的舊程式碼不會被破壞。即使原則上 Python 2.2 新"
+"式類別的程式碼可能會被破壞,但實際上 C3 解析順序與 Python 2.2 方法解析順序不"
+"同的情況是如此罕見,以至於預期不會真正破壞程式碼。因此:"
#: ../../howto/mro.rst:64
msgid "*Don't be scared!*"
-msgstr ""
+msgstr "*別怕!*"
#: ../../howto/mro.rst:66
+#, fuzzy
msgid ""
"Moreover, unless you make strong use of multiple inheritance and you have "
"non-trivial hierarchies, you don't need to understand the C3 algorithm, and "
@@ -116,24 +143,33 @@ msgid ""
"know how multiple inheritance works, then this paper is for you. The good "
"news is that things are not as complicated as you might expect."
msgstr ""
+"此外,除非你大量使用多重繼承並且具有複雜的類別階層,否則你無需了解 C3 演算"
+"法,可以輕鬆跳過本文。另一方面,如果你真的想知道多重繼承的運作原理,那麼本文"
+"適合你。好消息是,事情並不像你想像的那樣複雜。"
#: ../../howto/mro.rst:73
msgid "Let me begin with some basic definitions."
-msgstr ""
+msgstr "讓我從一些基本定義開始。"
#: ../../howto/mro.rst:75
+#, fuzzy
msgid ""
"Given a class C in a complicated multiple inheritance hierarchy, it is a non-"
"trivial task to specify the order in which methods are overridden, i.e. to "
"specify the order of the ancestors of C."
msgstr ""
+"給定複雜多重繼承階層中的類別 C,指定方法被覆寫 (override) 的順序是一項複雜的"
+"任務,也就是指定 C 的祖先順序。"
#: ../../howto/mro.rst:79
+#, fuzzy
msgid ""
"The list of the ancestors of a class C, including the class itself, ordered "
"from the nearest ancestor to the furthest, is called the class precedence "
"list or the *linearization* of C."
msgstr ""
+"類別 C 的祖先串列(包含類別本身),從最近的祖先到最遠的祖先排序,稱為類別優先"
+"串列 (class precedence list) 或 C 的\\ *線性化 (linearization)*。"
#: ../../howto/mro.rst:83
msgid ""
@@ -141,8 +177,11 @@ msgid ""
"linearization. In the Python literature, the idiom \"the MRO of C\" is also "
"used as a synonymous for the linearization of the class C."
msgstr ""
+"*方法解析順序 (Method Resolution Order, MRO)* 是建構線性化的一組規則。在 "
+"Python 文獻中,習慣用語「C 的 MRO」也是 C 類別線性化的同義詞。"
#: ../../howto/mro.rst:88
+#, fuzzy
msgid ""
"For instance, in the case of single inheritance hierarchy, if C is a "
"subclass of C1, and C1 is a subclass of C2, then the linearization of C is "
@@ -151,8 +190,13 @@ msgid ""
"it is more difficult to construct a linearization that respects *local "
"precedence ordering* and *monotonicity*."
msgstr ""
+"例如,在單一繼承階層的情況下,如果 C 是 C1 的子類別,而 C1 是 C2 的子類別,那"
+"麼 C 的線性化就是串列 [C, C1, C2]。然而,在多重繼承階層中,線性化的建構更加複"
+"雜,因為要建構一個尊重\\ *局部優先順序 (local precedence ordering)* 和\\ *單"
+"調性 (monotonicity)* 的線性化更加困難。"
#: ../../howto/mro.rst:96
+#, fuzzy
msgid ""
"I will discuss the local precedence ordering later, but I can give the "
"definition of monotonicity here. A MRO is monotonic when the following is "
@@ -162,24 +206,35 @@ msgid ""
"potentially introducing very subtle bugs. Examples where this happens will "
"be shown later."
msgstr ""
+"我將在稍後討論局部優先順序,但可以在此給出單調性的定義。當以下條件為真時,"
+"MRO 是單調的:*如果 C1 在 C 的線性化中先於 C2,那麼 C1 在 C 的任何子類別的線"
+"性化中也先於 C2*。否則,衍生新類別這個看似無害的操作可能會改變方法的解析順"
+"序,可能引入非常微妙的錯誤。稍後將展示發生這種情況的範例。"
#: ../../howto/mro.rst:104
+#, fuzzy
msgid ""
"Not all classes admit a linearization. There are cases, in complicated "
"hierarchies, where it is not possible to derive a class such that its "
"linearization respects all the desired properties."
msgstr ""
+"並非所有類別都接受線性化。在某些情況下,在復雜的階層結構中,無法得出一個類"
+"別,使其線性化尊重所有所需的屬性。"
#: ../../howto/mro.rst:108
+#, fuzzy
msgid "Here I give an example of this situation. Consider the hierarchy"
-msgstr ""
+msgstr "在這裡,我舉例說明了這種情況。考慮階層結構"
#: ../../howto/mro.rst:116
+#, fuzzy
msgid ""
"which can be represented with the following inheritance graph, where I have "
"denoted with O the ``object`` class, which is the beginning of any hierarchy "
"for new style classes:"
msgstr ""
+"可以用以下繼承圖來表示,我用 O ``object`` 類別表示,這是新式類別的任何階層結"
+"構的開始:"
#: ../../howto/mro.rst:120
msgid ""
@@ -206,108 +261,130 @@ msgstr ""
" ?"
#: ../../howto/mro.rst:133
+#, fuzzy
msgid ""
"In this case, it is not possible to derive a new class C from A and B, since "
"X precedes Y in A, but Y precedes X in B, therefore the method resolution "
"order would be ambiguous in C."
msgstr ""
+"在這種情況下,不可能從 A 和 B 衍生出新的類別 C,因為 X 在 A 中先於 Y,但 Y "
+"在 B 中先於 X,因此方法解析順序在 C 中會產生歧義。"
#: ../../howto/mro.rst:137
+#, fuzzy
msgid ""
"Python 2.3 raises an exception in this situation (TypeError: MRO conflict "
"among bases Y, X) forbidding the naive programmer from creating ambiguous "
"hierarchies. Python 2.2 instead does not raise an exception, but chooses an "
"*ad hoc* ordering (CABXYO in this case)."
msgstr ""
+"Python 2.3 在這種情況下提出了一個例外(TypeError: MRO conflict among bases "
+"Y, X)禁止幼稚的程式設計師建立模棱兩可的階層結構。Python 2.2 不提出例外,而是"
+"選擇*ad hoc* 訂購(在這種情況下為 CABXYO)。"
#: ../../howto/mro.rst:143
msgid "The C3 Method Resolution Order"
-msgstr ""
+msgstr "C3 方法解析順序"
#: ../../howto/mro.rst:145
+#, fuzzy
msgid ""
"Let me introduce a few simple notations which will be useful for the "
"following discussion. I will use the shortcut notation::"
-msgstr ""
+msgstr "讓我介紹一些簡單的符號,這對於以下討論很有用。我將使用快捷符號: ::"
#: ../../howto/mro.rst:148
msgid "C1 C2 ... CN"
msgstr "C1 C2 ... CN"
#: ../../howto/mro.rst:150
+#, fuzzy
msgid "to indicate the list of classes [C1, C2, ... , CN]."
-msgstr ""
+msgstr "指示類別串列 [C1, C2, ... , CN]。"
#: ../../howto/mro.rst:152
+#, fuzzy
msgid "The *head* of the list is its first element::"
-msgstr ""
+msgstr "列表的 *head* 是其第一個元素: ::"
#: ../../howto/mro.rst:154
msgid "head = C1"
msgstr "head = C1"
#: ../../howto/mro.rst:156
+#, fuzzy
msgid "whereas the *tail* is the rest of the list::"
-msgstr ""
+msgstr "而 *tail* 是列表的其餘部分: ::"
#: ../../howto/mro.rst:158
msgid "tail = C2 ... CN."
msgstr "tail = C2 ... CN."
#: ../../howto/mro.rst:160
+#, fuzzy
msgid "I shall also use the notation::"
-msgstr ""
+msgstr "我還將使用符號: ::"
#: ../../howto/mro.rst:162
msgid "C + (C1 C2 ... CN) = C C1 C2 ... CN"
msgstr "C + (C1 C2 ... CN) = C C1 C2 ... CN"
#: ../../howto/mro.rst:164
+#, fuzzy
msgid "to denote the sum of the lists [C] + [C1, C2, ... ,CN]."
-msgstr ""
+msgstr "表示列表的總和[C] + [C1,C2,...,CN]。"
#: ../../howto/mro.rst:166
+#, fuzzy
msgid "Now I can explain how the MRO works in Python 2.3."
-msgstr ""
+msgstr "現在,我可以解釋 MRO 在 Python 2.3 中的工作方式。"
#: ../../howto/mro.rst:168
+#, fuzzy
msgid ""
"Consider a class C in a multiple inheritance hierarchy, with C inheriting "
"from the base classes B1, B2, ... , BN. We want to compute the "
"linearization L[C] of the class C. The rule is the following:"
msgstr ""
+"考慮多重繼承階層結構中的類別 C,C 從基本類別 B1、B2、...、BN 繼承。我們想計算"
+"類別 C 的線性化 L[C]。規則是以下內容:"
#: ../../howto/mro.rst:173
+#, fuzzy
msgid ""
"*the linearization of C is the sum of C plus the merge of the linearizations "
"of the parents and the list of the parents.*"
-msgstr ""
+msgstr "*C 的線性化是 C 加上父類別們的線性化合併以及父類別串列的總和。*"
#: ../../howto/mro.rst:176
msgid "In symbolic notation::"
-msgstr ""
+msgstr "用符號標示法: ::"
#: ../../howto/mro.rst:178
msgid "L[C(B1 ... BN)] = C + merge(L[B1] ... L[BN], B1 ... BN)"
msgstr "L[C(B1 ... BN)] = C + merge(L[B1] ... L[BN], B1 ... BN)"
#: ../../howto/mro.rst:180
+#, fuzzy
msgid ""
"In particular, if C is the ``object`` class, which has no parents, the "
"linearization is trivial::"
msgstr ""
+"特別是,如果 C 是沒有父類別的 ``object`` 類別,那麼線性化是微不足道的: ::"
#: ../../howto/mro.rst:183
msgid "L[object] = object."
msgstr "L[object] = object."
#: ../../howto/mro.rst:185
+#, fuzzy
msgid ""
"However, in general one has to compute the merge according to the following "
"prescription:"
-msgstr ""
+msgstr "但是,一般而言必須根據以下規則來計算合併:"
#: ../../howto/mro.rst:188
+#, fuzzy
msgid ""
"*take the head of the first list, i.e L[B1][0]; if this head is not in the "
"tail of any of the other lists, then add it to the linearization of C and "
@@ -317,30 +394,43 @@ msgid ""
"this case, it is impossible to construct the merge, Python 2.3 will refuse "
"to create the class C and will raise an exception.*"
msgstr ""
+"*取第一個串列的頭部,也就是 L[B1][0];如果此頭部不在其他任何串列的尾部中,那"
+"麼將它加入到 C 的線性化中,並從合併中的所有串列移除它;否則查看下一個串列的頭"
+"部,如果它是一個好的頭部就取它。然後重複此操作,直到所有類別都被移除或無法找"
+"到好的頭部。在後一種情況下,無法建構合併,Python 2.3 將拒絕建立類別 C 並引發"
+"例外。*"
#: ../../howto/mro.rst:197
+#, fuzzy
msgid ""
"This prescription ensures that the merge operation *preserves* the ordering, "
"if the ordering can be preserved. On the other hand, if the order cannot be "
"preserved (as in the example of serious order disagreement discussed above) "
"then the merge cannot be computed."
msgstr ""
+"此處方可確保合併操作\\ *保留*\\ 順序,如果可以保留訂購。另一方面,如果無法保"
+"留順序(如上面討論的嚴重順序分歧的示例),則無法計算合併。"
#: ../../howto/mro.rst:202
+#, fuzzy
msgid ""
"The computation of the merge is trivial if C has only one parent (single "
"inheritance); in this case::"
msgstr ""
+"如果 C 只有一個父類別(單一繼承),則合併的計算是微不足道的。在這種情況"
+"下: ::"
#: ../../howto/mro.rst:205
msgid "L[C(B)] = C + merge(L[B],B) = C + L[B]"
msgstr "L[C(B)] = C + merge(L[B],B) = C + L[B]"
#: ../../howto/mro.rst:207
+#, fuzzy
msgid ""
"However, in the case of multiple inheritance things are more cumbersome and "
"I don't expect you can understand the rule without a couple of examples ;-)"
msgstr ""
+"但是,在多個繼承情況下,事情更加繁瑣,我希望沒有幾個示例就可以理解該規則;-)"
#: ../../howto/mro.rst:212
msgid "Examples"
@@ -348,11 +438,11 @@ msgstr "範例"
#: ../../howto/mro.rst:214
msgid "First example. Consider the following hierarchy:"
-msgstr ""
+msgstr "第一個例子,請參考以下階層結構:"
#: ../../howto/mro.rst:224
msgid "In this case the inheritance graph can be drawn as:"
-msgstr ""
+msgstr "在這種情況下,繼承圖可以繪製為:"
#: ../../howto/mro.rst:226
msgid ""
@@ -378,10 +468,32 @@ msgid ""
"Level 0 0 | A | (more specialized)\n"
" ---"
msgstr ""
+" 6\n"
+" ---\n"
+"Level 3 | O | (more general)\n"
+" / --- \\\n"
+" / | \\ |\n"
+" / | \\ |\n"
+" / | \\ |\n"
+" --- --- --- |\n"
+"Level 2 3 | D | 4| E | | F | 5 |\n"
+" --- --- --- |\n"
+" \\ \\ _ / | |\n"
+" \\ / \\ _ | |\n"
+" \\ / \\ | |\n"
+" --- --- |\n"
+"Level 1 1 | B | | C | 2 |\n"
+" --- --- |\n"
+" \\ / |\n"
+" \\ / \\ /\n"
+" ---\n"
+"Level 0 0 | A | (more specialized)\n"
+" ---"
#: ../../howto/mro.rst:251
+#, fuzzy
msgid "The linearizations of O,D,E and F are trivial::"
-msgstr ""
+msgstr "O、D、E 和 F 的線性化是微不足道的: ::"
#: ../../howto/mro.rst:253
msgid ""
@@ -390,16 +502,21 @@ msgid ""
"L[E] = E O\n"
"L[F] = F O"
msgstr ""
+"L[O] = O\n"
+"L[D] = D O\n"
+"L[E] = E O\n"
+"L[F] = F O"
#: ../../howto/mro.rst:258
msgid "The linearization of B can be computed as::"
-msgstr ""
+msgstr "B 的線性化可以計算為: ::"
#: ../../howto/mro.rst:260
msgid "L[B] = B + merge(DO, EO, DE)"
msgstr "L[B] = B + merge(DO, EO, DE)"
#: ../../howto/mro.rst:262
+#, fuzzy
msgid ""
"We see that D is a good head, therefore we take it and we are reduced to "
"compute ``merge(O,EO,E)``. Now O is not a good head, since it is in the "
@@ -407,6 +524,10 @@ msgid ""
"the next sequence. Then we see that E is a good head; we take it and we are "
"reduced to compute ``merge(O,O)`` which gives O. Therefore::"
msgstr ""
+"我們看到 D 是一個好的頭部,因此我們取它,並將其簡化為 ``merge(O, EO, E)``。現"
+"在 O 不是一個好的頭部,因為它位於序列 EO 的尾部。在這種情況下,規則說我們必須"
+"跳到下一個序列。然後我們看到 E 是一個好的頭部;我們取它,並簡化為計算 "
+"``merge(O, O)`` 得出 O。因此: ::"
#: ../../howto/mro.rst:268
msgid "L[B] = B D E O"
@@ -414,7 +535,7 @@ msgstr "L[B] = B D E O"
#: ../../howto/mro.rst:270
msgid "Using the same procedure one finds::"
-msgstr ""
+msgstr "使用相同的程序可以發現: ::"
#: ../../howto/mro.rst:272
msgid ""
@@ -430,7 +551,7 @@ msgstr ""
#: ../../howto/mro.rst:277
msgid "Now we can compute::"
-msgstr ""
+msgstr "現在我們可以計算出: ::"
#: ../../howto/mro.rst:279
msgid ""
@@ -451,25 +572,31 @@ msgstr ""
" = A B C D E F O"
#: ../../howto/mro.rst:287
+#, fuzzy
msgid ""
"In this example, the linearization is ordered in a pretty nice way according "
"to the inheritance level, in the sense that lower levels (i.e. more "
"specialized classes) have higher precedence (see the inheritance graph). "
"However, this is not the general case."
msgstr ""
+"在此示例中,線性化是根據繼承級別以相當不錯的方式排序的,因為較低級別(即更專"
+"業的類別)具有更高的優先級(請參見繼承圖)。但是,這不是一般情況。"
#: ../../howto/mro.rst:292
msgid ""
"I leave as an exercise for the reader to compute the linearization for my "
"second example:"
-msgstr ""
+msgstr "第二個範例的線性化之計算我留給讀者當作練習:"
#: ../../howto/mro.rst:303
+#, fuzzy
msgid ""
-"The only difference with the previous example is the change B(D,E) --> B(E,"
-"D); however even such a little modification completely changes the ordering "
-"of the hierarchy:"
+"The only difference with the previous example is the change B(D,E) --> "
+"B(E,D); however even such a little modification completely changes the "
+"ordering of the hierarchy:"
msgstr ""
+"與上一個示例的唯一區別是變化 B(D,E) --> B(E,D);但是,即使是這樣的修改,也完"
+"全改變了階層結構的順序:"
#: ../../howto/mro.rst:307
msgid ""
@@ -518,25 +645,34 @@ msgstr ""
" ---"
#: ../../howto/mro.rst:332
+#, fuzzy
msgid ""
"Notice that the class E, which is in the second level of the hierarchy, "
"precedes the class C, which is in the first level of the hierarchy, i.e. E "
"is more specialized than C, even if it is in a higher level."
msgstr ""
+"請注意,階層結構的第二層中的類別 E,先於階層結構第一層的類別 C,即 E 比 C 更"
+"專業,即使它處於更高級別。"
#: ../../howto/mro.rst:336
+#, fuzzy
msgid ""
"A lazy programmer can obtain the MRO directly from Python 2.2, since in this "
"case it coincides with the Python 2.3 linearization. It is enough to invoke "
"the :meth:`~type.mro` method of class A:"
msgstr ""
+"懶惰的程式設計師可以直接從 Python 2.2 獲得 MRO,因為在這種情況下,它與 "
+"Python 2.3 線性化一致。呼叫類別 A 的 :meth:`~type.mro` 方法就足夠了:"
#: ../../howto/mro.rst:345
+#, fuzzy
msgid ""
"Finally, let me consider the example discussed in the first section, "
"involving a serious order disagreement. In this case, it is straightforward "
"to compute the linearizations of O, X, Y, A and B:"
msgstr ""
+"最後,讓我考慮第一部分中討論的示例,涉及嚴重的順序分歧。在這種情況下,計算 "
+"O、X、Y、A 和 B 的線性化是很簡單的:"
#: ../../howto/mro.rst:349
msgid ""
@@ -553,10 +689,11 @@ msgstr ""
"L[B] = B Y X O"
#: ../../howto/mro.rst:357
+#, fuzzy
msgid ""
"However, it is impossible to compute the linearization for a class C that "
"inherits from A and B::"
-msgstr ""
+msgstr "但是,不可能計算從 A 和 B 繼承的類別 C 的線性化: ::"
#: ../../howto/mro.rst:360
msgid ""
@@ -569,34 +706,43 @@ msgstr ""
" = C + A + B + merge(XYO, YXO)"
#: ../../howto/mro.rst:364
+#, fuzzy
msgid ""
"At this point we cannot merge the lists XYO and YXO, since X is in the tail "
"of YXO whereas Y is in the tail of XYO: therefore there are no good heads "
"and the C3 algorithm stops. Python 2.3 raises an error and refuses to "
"create the class C."
msgstr ""
+"在這一點上,我們無法合併串列 XYO 和 YXO,因為 X 位於 YXO 的尾部,而 Y 則位於 "
+"XYO 的尾部:因此,沒有好的頭部,C3 演算法停止。Python 2.3 引起了錯誤,拒絕建"
+"立類別 C。"
#: ../../howto/mro.rst:370
msgid "Bad Method Resolution Orders"
-msgstr ""
+msgstr "不良的方法解析順序"
#: ../../howto/mro.rst:372
+#, fuzzy
msgid ""
"A MRO is *bad* when it breaks such fundamental properties as local "
"precedence ordering and monotonicity. In this section, I will show that "
"both the MRO for classic classes and the MRO for new style classes in Python "
"2.2 are bad."
msgstr ""
+"當 MRO 打破諸如局部優先順序和單調性之類的基本屬性時,MRO 是 *不良* 的。在本節"
+"中,我將證明經典類別的 MRO 和 Python 2.2 的新式類別的 MRO 都是不好的。"
#: ../../howto/mro.rst:377
+#, fuzzy
msgid ""
"It is easier to start with the local precedence ordering. Consider the "
"following example:"
-msgstr ""
+msgstr "從局部優先順序開始就更容易。考慮以下示例:"
#: ../../howto/mro.rst:384
+#, fuzzy
msgid "with inheritance diagram"
-msgstr ""
+msgstr "帶有繼承圖"
#: ../../howto/mro.rst:386
msgid ""
@@ -610,26 +756,43 @@ msgid ""
"\n"
" (buy eggs or spam ?)"
msgstr ""
+" O\n"
+" |\n"
+"(buy spam) F\n"
+" | \\\n"
+" | E (buy eggs)\n"
+" | /\n"
+" G\n"
+"\n"
+" (buy eggs or spam ?)"
#: ../../howto/mro.rst:399
+#, fuzzy
msgid ""
"We see that class G inherits from F and E, with F *before* E: therefore we "
-"would expect the attribute *G.remember2buy* to be inherited by *F."
-"remember2buy* and not by *E.remember2buy*: nevertheless Python 2.2 gives"
+"would expect the attribute *G.remember2buy* to be inherited by "
+"*F.remember2buy* and not by *E.remember2buy*: nevertheless Python 2.2 gives"
msgstr ""
+"我們看到類別 G 從 F 和 E 繼承,F 在 E *之前*:因此,我們希望屬性 "
+"*G.remember2buy* 被 *F.remember2buy* 繼承,而不是 *E.remember2buy*:儘管如"
+"此,Python 2.2 給出"
#: ../../howto/mro.rst:407
+#, fuzzy
msgid ""
"This is a breaking of local precedence ordering since the order in the local "
"precedence list, i.e. the list of the parents of G, is not preserved in the "
"Python 2.2 linearization of G::"
msgstr ""
+"這是局部優先順序的破壞,因為局部優先串列中的順序,即 G 的父類別串列,在 "
+"Python 2.2 的 G 的線性化中不被保留: ::"
#: ../../howto/mro.rst:411
msgid "L[G,P22]= G E F object # F *follows* E"
-msgstr "L[G,P22]= G E F object # F *follows* E"
+msgstr "L[G,P22]= G E F object # F *跟隨* E"
#: ../../howto/mro.rst:413
+#, fuzzy
msgid ""
"One could argue that the reason why F follows E in the Python 2.2 "
"linearization is that F is less specialized than E, since F is the "
@@ -637,13 +800,17 @@ msgid ""
"quite non-intuitive and error prone. This is particularly true since it is "
"a different from old style classes:"
msgstr ""
+"有人可能會說,F 在 Python 2.2 線性化中跟隨 E 的原因是 F 比 E 專業化程度較低,"
+"因為 F 是 E 的超類別;然而,局部優先順序的破壞非常不直覺且容易出錯。尤其如"
+"此,因為它與舊式類別不同:"
#: ../../howto/mro.rst:425
msgid ""
"In this case the MRO is GFEF and the local precedence ordering is preserved."
-msgstr ""
+msgstr "在這種情況下,MRO 是 GFEF 並且保留局部優先順序。"
#: ../../howto/mro.rst:428
+#, fuzzy
msgid ""
"As a general rule, hierarchies such as the previous one should be avoided, "
"since it is unclear if F should override E or vice-versa. Python 2.3 solves "
@@ -651,6 +818,9 @@ msgid ""
"effectively stopping the programmer from generating ambiguous hierarchies. "
"The reason for that is that the C3 algorithm fails when the merge::"
msgstr ""
+"通常,應避免諸如上一個等階層結構,因為尚不清楚 F 是否應覆蓋 E 或反之亦然。 "
+"Python 2.3 透過在建立類別 G 時提出例外來解決歧義,從而有效地阻止程式設計師產"
+"生模棱兩可的階層結構。原因是當合併: ::"
#: ../../howto/mro.rst:435
msgid "merge(FO,EFO,FE)"
@@ -660,14 +830,17 @@ msgstr "merge(FO,EFO,FE)"
msgid ""
"cannot be computed, because F is in the tail of EFO and E is in the tail of "
"FE."
-msgstr ""
+msgstr "無法計算,因為 F 在 EFO 的尾部,而 E 在 FE 的尾部。"
#: ../../howto/mro.rst:440
+#, fuzzy
msgid ""
"The real solution is to design a non-ambiguous hierarchy, i.e. to derive G "
"from E and F (the more specific first) and not from F and E; in this case "
"the MRO is GEF without any doubt."
msgstr ""
+"真正的解決方案是設計一個非歧義的階層結構,即源自 E 和 F(更具體的第一)而不"
+"是 F 和E;在這種情況下,MRO 毫無疑問是 GEF。"
#: ../../howto/mro.rst:444
msgid ""
@@ -680,55 +853,73 @@ msgid ""
" G\n"
" (eggs, no doubt)"
msgstr ""
+" O\n"
+" |\n"
+" F (spam)\n"
+" / |\n"
+"(eggs) E |\n"
+" \\ |\n"
+" G\n"
+" (eggs, no doubt)"
#: ../../howto/mro.rst:456
msgid ""
"Python 2.3 forces the programmer to write good hierarchies (or, at least, "
"less error-prone ones)."
-msgstr ""
+msgstr "Python 2.3 迫使程式設計師要編寫良好(或至少較不易於出錯)的階層結構。"
#: ../../howto/mro.rst:459
+#, fuzzy
msgid ""
"On a related note, let me point out that the Python 2.3 algorithm is smart "
"enough to recognize obvious mistakes, as the duplication of classes in the "
"list of parents:"
msgstr ""
+"與之相關的是,我指出的是,Python 2.3 演算法足夠聰明,可以識別出明顯的錯誤,例"
+"如父類別串列中類別的重複:"
#: ../../howto/mro.rst:469
+#, fuzzy
msgid ""
"Python 2.2 (both for classic classes and new style classes) in this "
"situation, would not raise any exception."
msgstr ""
+"在這種情況下,Python 2.2(無論是經典類別還是新式類別)不會引起任何例外。"
#: ../../howto/mro.rst:472
+#, fuzzy
msgid ""
"Finally, I would like to point out two lessons we have learned from this "
"example:"
-msgstr ""
+msgstr "最後,我想指出我們從這個示例中學到的兩個教訓:"
#: ../../howto/mro.rst:475
msgid ""
"despite the name, the MRO determines the resolution order of attributes, not "
"only of methods;"
-msgstr ""
+msgstr "儘管名稱如此,但不僅是方法的解析順序,MRO 也決定了屬性的解析順序;"
#: ../../howto/mro.rst:478
msgid ""
"the default food for Pythonistas is spam ! (but you already knew that ;-)"
-msgstr ""
+msgstr "Pythonistas 的預設食物是 spam!(但是你已經知道 ;-)"
#: ../../howto/mro.rst:481
+#, fuzzy
msgid ""
"Having discussed the issue of local precedence ordering, let me now consider "
"the issue of monotonicity. My goal is to show that neither the MRO for "
"classic classes nor that for Python 2.2 new style classes is monotonic."
msgstr ""
+"在討論了局部優先順序的問題之後,讓我現在考慮單調性問題。我的目標是表明經典類"
+"別的 MRO 或 Python 2.2 新式類別都不是單調的。"
#: ../../howto/mro.rst:486
+#, fuzzy
msgid ""
"To prove that the MRO for classic classes is non-monotonic is rather "
"trivial, it is enough to look at the diamond diagram:"
-msgstr ""
+msgstr "為了證明經典類別的 MRO 是非單調的,查看鑽石圖就足夠了:"
#: ../../howto/mro.rst:489
msgid ""
@@ -750,45 +941,59 @@ msgstr ""
#: ../../howto/mro.rst:500
msgid "One easily discerns the inconsistency::"
-msgstr ""
+msgstr "可以很容易地辨別出這種不一致: ::"
#: ../../howto/mro.rst:502
+#, fuzzy
msgid ""
"L[B,P21] = B C # B precedes C : B's methods win\n"
"L[D,P21] = D A C B C # B follows C : C's methods win!"
msgstr ""
+"L[B,P21] = B C # B precedes C : B's methods win\n"
+"L[D,P21] = D A C B C # B follows C : C's methods win!"
#: ../../howto/mro.rst:505
+#, fuzzy
msgid ""
"On the other hand, there are no problems with the Python 2.2 and 2.3 MROs, "
"they give both::"
-msgstr ""
+msgstr "另一方面,Python 2.2 和 2.3 MRO 沒有問題,它們給出了這兩個: ::"
#: ../../howto/mro.rst:508
msgid "L[D] = D A B C"
msgstr "L[D] = D A B C"
#: ../../howto/mro.rst:510
+#, fuzzy
msgid ""
"Guido points out in his essay [#]_ that the classic MRO is not so bad in "
"practice, since one can typically avoids diamonds for classic classes. But "
"all new style classes inherit from ``object``, therefore diamonds are "
"unavoidable and inconsistencies shows up in every multiple inheritance graph."
msgstr ""
+"Guido 在他的文章 [#]_ 中指出,經典的 MRO 在實踐中還不錯,因為通常可以避開經典"
+"類別的鑽石圖。但是所有新式類別都從 ``object`` 繼承,因此鑽石圖是不可避免的,"
+"並且在每個多重繼承圖中都出現了不一致之處。"
#: ../../howto/mro.rst:516
+#, fuzzy
msgid ""
"The MRO of Python 2.2 makes breaking monotonicity difficult, but not "
"impossible. The following example, originally provided by Samuele Pedroni, "
"shows that the MRO of Python 2.2 is non-monotonic:"
msgstr ""
+"Python 2.2 的 MRO 使單調性的打破困難,但並非不可能。以下最初由 Samuele "
+"Pedroni 提供的示例表明,Python 2.2 的 MRO 是非單調的:"
#: ../../howto/mro.rst:530
+#, fuzzy
msgid ""
"Here are the linearizations according to the C3 MRO (the reader should "
"verify these linearizations as an exercise and draw the inheritance "
"diagram ;-) ::"
msgstr ""
+"以下是根據 C3 MRO 的線性化(讀者應將這些線性化驗證為練習並繪製繼承"
+"圖 ;-) : ::"
#: ../../howto/mro.rst:534
msgid ""
@@ -817,12 +1022,15 @@ msgid ""
"Python 2.2 gives exactly the same linearizations for A, B, C, D, E, K1, K2 "
"and K3, but a different linearization for Z::"
msgstr ""
+"Python 2.2 給出了 A、B、C、D、E、K1、K2 和 K3 完全相同的線性化,但是 Z 的線性"
+"化卻不同: ::"
#: ../../howto/mro.rst:547
msgid "L[Z,P22] = Z K1 K3 A K2 D B C E O"
msgstr "L[Z,P22] = Z K1 K3 A K2 D B C E O"
#: ../../howto/mro.rst:549
+#, fuzzy
msgid ""
"It is clear that this linearization is *wrong*, since A comes before D "
"whereas in the linearization of K3 A comes *after* D. In other words, in K3 "
@@ -834,12 +1042,19 @@ msgid ""
"the linearization of Z K2 *follows* K3. These problems explain why the 2.2 "
"rule has been dismissed in favor of the C3 rule."
msgstr ""
+"顯然,這種線性化是\\ *錯誤*\\ 的,因為 A 在 D 之前,而在 K3 的線性化中,A 在 "
+"D *之後*。換句話說,在 K3 中由 D 衍生的方法會覆寫由 A 衍生的方法,但在 Z 中"
+"(它仍然是 K3 的子類別),由 A 衍生的方法卻覆寫由 D 衍生的方法!這是對單調性"
+"的違反。此外,Z 的 Python 2.2 線性化也與局部優先順序不一致,因為類別 Z 的局部"
+"優先串列是 [K1, K2, K3](K2 先於 K3),但在 Z 的線性化中 K2 *跟隨* K3。這些問"
+"題解釋了為什麼 2.2 規則被摒棄而採用 C3 規則。"
#: ../../howto/mro.rst:561
msgid "The end"
-msgstr ""
+msgstr "結語"
#: ../../howto/mro.rst:563
+#, fuzzy
msgid ""
"This section is for the impatient reader, who skipped all the previous "
"sections and jumped immediately to the end. This section is for the lazy "
@@ -852,6 +1067,12 @@ msgid ""
"the last line to play with the various examples I have discussed in this "
"paper.::"
msgstr ""
+"本節適用於不耐煩的讀者,後者跳過了所有以前的部分,並立即跳到了最後。本節也適"
+"用於懶惰的程式設計師,他們不想鍛煉她/他的大腦。最後,這是針對有一些傲慢的程式"
+"設計師的,否則他/他不會在多重繼承階層結構中閱讀有關 C3 方法解析順序的論文;-)"
+"這三種三種優點(並且 *不* 單獨)應獲得獎勵:獎品是一個簡短的 Python 2.2 腳"
+"本,使你可以在沒有風險的情況下使用 2.3 MRO 的腳本。只需更改最後一行以與我在本"
+"文中討論的各種示例一起播放: ::"
#: ../../howto/mro.rst:574
msgid ""
@@ -938,30 +1159,115 @@ msgid ""
"\n"
"#"
msgstr ""
+"#\n"
+"\n"
+"\"\"\"Samuele Pedroni 撰寫的 C3 演算法(增強了可讀性)。\"\"\"\n"
+"\n"
+"class __metaclass__(type):\n"
+" \"所有類別都會被神奇地修改以便美觀地列印\"\n"
+" __repr__ = lambda cls: cls.__name__\n"
+"\n"
+"class ex_2:\n"
+" \"嚴重的順序分歧\" # 來自 Guido\n"
+" class O: pass\n"
+" class X(O): pass\n"
+" class Y(O): pass\n"
+" class A(X,Y): pass\n"
+" class B(Y,X): pass\n"
+" try:\n"
+" class Z(A,B): pass # 在 Python 2.2 中會建立 Z(A,B)\n"
+" except TypeError:\n"
+" pass # 在 Python 2.3 中無法建立 Z(A,B)\n"
+"\n"
+"class ex_5:\n"
+" \"我的第一個範例\"\n"
+" class O: pass\n"
+" class F(O): pass\n"
+" class E(O): pass\n"
+" class D(O): pass\n"
+" class C(D,F): pass\n"
+" class B(D,E): pass\n"
+" class A(B,C): pass\n"
+"\n"
+"class ex_6:\n"
+" \"我的第二個範例\"\n"
+" class O: pass\n"
+" class F(O): pass\n"
+" class E(O): pass\n"
+" class D(O): pass\n"
+" class C(D,F): pass\n"
+" class B(E,D): pass\n"
+" class A(B,C): pass\n"
+"\n"
+"class ex_9:\n"
+" \"Python 2.2 MRO 與 C3 的差異\" # 來自 Samuele\n"
+" class O: pass\n"
+" class A(O): pass\n"
+" class B(O): pass\n"
+" class C(O): pass\n"
+" class D(O): pass\n"
+" class E(O): pass\n"
+" class K1(A,B,C): pass\n"
+" class K2(D,B,E): pass\n"
+" class K3(D,A): pass\n"
+" class Z(K1,K2,K3): pass\n"
+"\n"
+"def merge(seqs):\n"
+" print '\\n\\nCPL[%s]=%s' % (seqs[0][0],seqs),\n"
+" res = []; i=0\n"
+" while 1:\n"
+" nonemptyseqs=[seq for seq in seqs if seq]\n"
+" if not nonemptyseqs: return res\n"
+" i+=1; print '\\n',i,'round: candidates...',\n"
+" for seq in nonemptyseqs: # 在序列頭部中尋找合併候選者\n"
+" cand = seq[0]; print ' ',cand,\n"
+" nothead=[s for s in nonemptyseqs if cand in s[1:]]\n"
+" if nothead: cand=None # 拒絕候選者\n"
+" else: break\n"
+" if not cand: raise \"不一致的階層結構\"\n"
+" res.append(cand)\n"
+" for seq in nonemptyseqs: # 移除候選者\n"
+" if seq[0] == cand: del seq[0]\n"
+"\n"
+"def mro(C):\n"
+" \"根據 C3 計算類別優先串列 (mro)\"\n"
+" return merge([[C]]+map(mro,C.__bases__)+[list(C.__bases__)])\n"
+"\n"
+"def print_mro(C):\n"
+" print '\\nMRO[%s]=%s' % (C,mro(C))\n"
+" print '\\nP22 MRO[%s]=%s' % (C,C.mro())\n"
+"\n"
+"print_mro(ex_9.Z)\n"
+"\n"
+"#"
#: ../../howto/mro.rst:656
msgid "That's all folks,"
-msgstr ""
+msgstr "就這樣,各位,"
#: ../../howto/mro.rst:658
msgid "enjoy !"
-msgstr ""
+msgstr "祝使用愉快!"
#: ../../howto/mro.rst:662
msgid "Resources"
-msgstr ""
+msgstr "資源"
#: ../../howto/mro.rst:664
msgid ""
"The thread on python-dev started by Samuele Pedroni: https://mail.python.org/"
"pipermail/python-dev/2002-October/029035.html"
msgstr ""
+"Samuele Pedroni 發起的 python-dev 主題討論:https://mail.python.org/"
+"pipermail/python-dev/2002-October/029035.html"
#: ../../howto/mro.rst:667
msgid ""
-"The paper *A Monotonic Superclass Linearization for Dylan*: https://doi."
-"org/10.1145/236337.236343"
+"The paper *A Monotonic Superclass Linearization for Dylan*: https://doi.org/"
+"10.1145/236337.236343"
msgstr ""
+"論文 *A Monotonic Superclass Linearization for Dylan*: https://doi.org/"
+"10.1145/236337.236343"
#: ../../howto/mro.rst:670
msgid ""
@@ -969,3 +1275,6 @@ msgid ""
"https://web.archive.org/web/20140210194412/http://www.python.org/download/"
"releases/2.2.2/descrintro"
msgstr ""
+"Guido van Rossum 的文章,*Unifying types and classes in Python 2.2*:https://"
+"web.archive.org/web/20140210194412/http://www.python.org/download/releases/"
+"2.2.2/descrintro"