Skip to content

Commit 0d23c28

Browse files
committed
ci: generate pages at 86724e5 [ci skip]
1 parent 86724e5 commit 0d23c28

File tree

1 file changed

+27
-31
lines changed

1 file changed

+27
-31
lines changed

public/1.9/book/loops.html

Lines changed: 27 additions & 31 deletions
Original file line numberDiff line numberDiff line change
@@ -182,14 +182,14 @@ <h1 class="title">ループ</h1>
182182

183183
<!-- Rust currently provides three approaches to performing some kind of iterative activity. They are: `loop`, `while` and `for`. Each approach has its own set of uses. -->
184184

185-
<p>なんらかの繰り返しを伴う処理に対して、Rust言語は3種類のアプローチ: <code>loop</code>, <code>while</code>, <code>for</code> を提供します
186-
各アプローチにはそれぞれの使い道があります</p>
185+
<p>現在、Rustは、なんらかの繰り返しを伴う処理に対して、3種類の手法: <code>loop</code>, <code>while</code>, <code>for</code> を提供しています
186+
各アプローチにはそれぞれの使い方があります</p>
187187

188188
<h2 id='loop' class='section-header'><a href='#loop'>loop</a></h2>
189189
<!-- The infinite `loop` is the simplest form of loop available in Rust. Using the keyword `loop`, Rust provides a way to loop indefinitely until some terminating statement is reached. Rust's infinite `loop`s look like this: -->
190190

191191
<p>Rustで使えるループのなかで最もシンプルな形式が、無限 <code>loop</code> です。Rustのキーワード <code>loop</code> によって、
192-
何らかの終了状態に到達するまでずっとループし続ける手段を提供します。Rustの無限 <code>loop</code> はこのように:</p>
192+
何らかの終了状態に到達するまで 延々とループし続ける手段を提供します。Rustの無限 <code>loop</code> は次の通りです:</p>
193193

194194
<span class='rusttest'>fn main() {
195195
loop {
@@ -203,7 +203,7 @@ <h2 id='loop' class='section-header'><a href='#loop'>loop</a></h2>
203203
<h2 id='while' class='section-header'><a href='#while'>while</a></h2>
204204
<!-- Rust also has a `while` loop. It looks like this: -->
205205

206-
<p>Rustには <code>while</code> ループもあります。このように:</p>
206+
<p>Rustには <code>while</code> ループもあります。次の通りです:</p>
207207

208208
<span class='rusttest'>fn main() {
209209
let mut x = 5; // mut x: i32
@@ -236,7 +236,7 @@ <h2 id='while' class='section-header'><a href='#while'>while</a></h2>
236236

237237
<!-- you need to loop. -->
238238

239-
<p>何回ループする必要があるか明らかではない状況で<code>while</code> ループは正しい選択肢です</p>
239+
<p>何回ループする必要があるか明らかではない状況では<code>while</code> ループは正しい選択です</p>
240240

241241
<!-- If you need an infinite loop, you may be tempted to write this: -->
242242

@@ -249,7 +249,7 @@ <h2 id='while' class='section-header'><a href='#while'>while</a></h2>
249249

250250
<!-- However, `loop` is far better suited to handle this case: -->
251251

252-
<p>しかし、こういった場合には <code>loop</code> の方がずっと適しています</p>
252+
<p>しかし、 <code>loop</code>は、 こういった場合に はるかに適しています</p>
253253

254254
<span class='rusttest'>fn main() {
255255
loop {
@@ -268,7 +268,7 @@ <h2 id='while' class='section-header'><a href='#while'>while</a></h2>
268268

269269
<p>Rustの制御フロー解析では、必ずループすると知っていることから、これを <code>while true</code> とは異なる構造として扱います。
270270
一般に、コンパイラへ与える情報量が多いほど、安全性が高くより良いコード生成につながるため、
271-
無限にループするつもりなら常に <code>loop</code> を使うべきです。</p>
271+
無限にループするつもりであれば、常に <code>loop</code> を使うべきです。</p>
272272

273273
<h2 id='for' class='section-header'><a href='#for'>for</a></h2>
274274
<!-- The `for` loop is used to loop a particular number of times. Rust’s `for` loops -->
@@ -277,8 +277,7 @@ <h2 id='for' class='section-header'><a href='#for'>for</a></h2>
277277

278278
<!-- loop doesn’t look like this “C-style” `for` loop: -->
279279

280-
<p>特定の回数だけループするときには <code>for</code> ループを使います。しかし、Rustの <code>for</code> ループは他のシステムプログラミング言語のそれとは少し異なる働きをします。
281-
Rustの <code>for</code> ループは、次のような「Cスタイル」 <code>for</code> ループとは似ていません:</p>
280+
<p>特定の回数だけループするときには <code>for</code> ループを使います。しかし、Rustの <code>for</code> ループは他のシステムプログラミング言語のそれとは少し異なる働きをします。 Rustの <code>for</code> ループは、次のような「Cスタイル」 <code>for</code> ループとは似ていません:</p>
282281

283282
<pre><code class="language-c">for (x = 0; x &lt; 10; x++) {
284283
printf( &quot;%d\n&quot;, x );
@@ -323,36 +322,33 @@ <h2 id='for' class='section-header'><a href='#for'>for</a></h2>
323322

324323
<!-- loop is over. -->
325324

326-
<p>式(expression)は<a href="../std/iter/trait.IntoIterator.html"><code>IntoIterator</code></a>を用いて<a href="iterators.html">イテレータ</a>へと変換可能なアイテムです。
327-
イテレータは要素の連なりを返します。それぞれの要素がループの1回の反復になります。
328-
その値は名前 <code>var</code> に束縛されて、ループ本体にて有効になります。いったんループ本体を抜けると、
329-
次の値がイテレータから取り出され、次のループ処理を行います。それ以上の値が存在しない時は、
330-
<code>for</code> ループは終了します。</p>
325+
<p>式(expression)は<a href="../std/iter/trait.IntoIterator.html"><code>IntoIterator</code></a>を用いて<a href="iterators.html">イテレータ</a>へと変換することができるアイテムです。
326+
イテレータは一連の要素を返します。それぞれの要素がループの1回の反復になります。 その値は、ループ本体に有効な名前, <code>var</code> に束縛されています。いったんループ本体を抜けると、次の値がイテレータから取り出され、次のループ処理を行います。それ以上の値が存在しない時は、<code>for</code> ループは終了します。</p>
331327

332328
<!-- In our example, `0..10` is an expression that takes a start and an end position, -->
333329

334330
<!-- and gives an iterator over those values. The upper bound is exclusive, though, -->
335331

336332
<!-- so our loop will print `0` through `9`, not `10`. -->
337333

338-
<p>例示では<code>0..10</code> が開始位置と終了位置をとる式であり、同範囲の値を返すイテレータを与えます。
339-
上界はその値自身を含まないため、このループは <code>0</code> から <code>9</code> までを表示します。 <code>10</code> ではありません。</p>
334+
<p>この例では<code>0..10</code> が開始と終了位置をとる式であり、同範囲の値を返すイテレータを与えます。
335+
上限はその値自身を含まないため、このループは <code>0</code> から <code>9</code> までを表示します。 <code>10</code> ではありません。</p>
340336

341337
<!-- Rust does not have the “C-style” `for` loop on purpose. Manually controlling -->
342338

343339
<!-- each element of the loop is complicated and error prone, even for experienced C -->
344340

345341
<!-- developers. -->
346342

347-
<p>Rustでは意図的に「Cスタイル」 <code>for</code> ループを持ちません。経験豊富なC開発者でさえ
348-
ループの各要素を手動制御することは複雑であり、また間違いを犯しやすいのです。</p>
343+
<p>Rustでは意図的に「Cスタイル」 <code>for</code> ループを持ちません。経験豊富なC言語の開発者でさえ
344+
ループの各要素を手動で制御することは複雑であり、また間違いを犯しやすいのです。</p>
349345

350346
<!-- ### Enumerate -->
351347

352348
<h3 id='列挙' class='section-header'><a href='#列挙'>列挙</a></h3>
353349
<!-- When you need to keep track of how many times you already looped, you can use the `.enumerate()` function. -->
354350

355-
<p>ループ中で何回目の繰り返しかを知る必要があるなら<code>.enumerate()</code> 関数が使えます。</p>
351+
<p>ループの中で何回目の繰り返しかを把握する必要がある時<code>.enumerate()</code> 関数が使えます。</p>
356352

357353
<!-- #### On ranges: -->
358354

@@ -386,10 +382,13 @@ <h4 id='レンジを対象に' class='section-header'><a href='#レンジを対
386382
<h4 id='イテレータを対象に' class='section-header'><a href='#イテレータを対象に'>イテレータを対象に:</a></h4>
387383
<span class='rusttest'>fn main() {
388384
let lines = &quot;hello\nworld&quot;.lines();
385+
389386
for (linenumber, line) in lines.enumerate() {
390387
println!(&quot;{}: {}&quot;, linenumber, line);
391388
}
392389
}</span><pre class='rust rust-example-rendered'>
390+
<span class='kw'>let</span> <span class='ident'>lines</span> <span class='op'>=</span> <span class='string'>&quot;hello\nworld&quot;</span>.<span class='ident'>lines</span>();
391+
393392
<span class='kw'>for</span> (<span class='ident'>linenumber</span>, <span class='ident'>line</span>) <span class='kw'>in</span> <span class='ident'>lines</span>.<span class='ident'>enumerate</span>() {
394393
<span class='macro'>println</span><span class='macro'>!</span>(<span class='string'>&quot;{}: {}&quot;</span>, <span class='ident'>linenumber</span>, <span class='ident'>line</span>);
395394
}</pre>
@@ -398,10 +397,8 @@ <h4 id='イテレータを対象に' class='section-header'><a href='#イテレ
398397

399398
<p>出力:</p>
400399

401-
<pre><code class="language-text">0: Content of line one
402-
1: Content of line two
403-
2: Content of line three
404-
3: Content of line four
400+
<pre><code class="language-text">0: hello
401+
1: world
405402
</code></pre>
406403

407404
<!-- ## Ending iteration early -->
@@ -444,8 +441,8 @@ <h2 id='反復の早期終了' class='section-header'><a href='#反復の早期
444441

445442
<!-- modifying iteration: `break` and `continue`. -->
446443

447-
<p>ループをいつ終了すべきか知るため、ここでは専用の <code>mut</code> なboolean変数束縛 <code>done</code> を用いました
448-
Rustには反復の変更を手伝う2つキーワード: <code>break</code><code>continue</code> があります。</p>
444+
<p>ループを終了する時を知るために、、専用の <code>mut</code>であるboolean変数束縛, <code>done</code> を使わなければなりませんでした
445+
Rustには反復の変更を手伝けする2つのキーワード: <code>break</code><code>continue</code> があります。</p>
449446

450447
<!-- In this case, we can write the loop in a better way with `break`: -->
451448

@@ -474,8 +471,8 @@ <h2 id='反復の早期終了' class='section-header'><a href='#反復の早期
474471

475472
<!-- We now loop forever with `loop` and use `break` to break out early. Issuing an explicit `return` statement will also serve to terminate the loop early. -->
476473

477-
<p>ここでは <code>loop</code> による永久ループと <code>break</code> による早期脱出を使っています
478-
明示的な <code>return</code> 文の発行でもループの早期終了になります</p>
474+
<p>ここでは <code>loop</code> による永久ループと 早期にループを抜けるため <code>break</code> を使っています
475+
明示的な <code>return</code> 文の発行でもループを早期に終了します</p>
479476

480477
<!-- `continue` is similar, but instead of ending the loop, goes to the next -->
481478

@@ -506,7 +503,7 @@ <h2 id='ループラベル' class='section-header'><a href='#ループラベル'
506503

507504
<!-- other languages, by default a `break` or `continue` will apply to innermost -->
508505

509-
<!-- loop. In a situation where you would like to a `break` or `continue` for one -->
506+
<!-- loop. In a situation where you would like to `break` or `continue` for one -->
510507

511508
<!-- of the outer loops, you can use labels to specify which loop the `break` or -->
512509

@@ -515,9 +512,8 @@ <h2 id='ループラベル' class='section-header'><a href='#ループラベル'
515512
<!-- odd: -->
516513

517514
<p>入れ子のループがあり、<code>break</code><code>continue</code> 文がどのループに対応するか指定する必要がある、
518-
そんな状況に出会うこともあるでしょう。大抵の他言語と同様に、 <code>break</code><code>continue</code> は最内ループに適用されるのがデフォルトです。
519-
外側のループに <code>break</code><code>continue</code> を使いたいという状況では、 <code>break</code><code>continue</code> 文の適用先を指定するラベルを使えます。
520-
これは <code>x</code><code>y</code> 両方が奇数のときだけ表示を行います:</p>
515+
そのような状況に出会うかもしれません。大抵の他言語と同様に、 デフォルトで <code>break</code><code>continue</code> は最内ループに適用されます。
516+
外側のループに <code>break</code><code>continue</code> を使いたいという状況では、 <code>break</code><code>continue</code> 文の適用先を指定するラベルを使えます。これは <code>x</code><code>y</code> 両方がともに奇数のときだけ表示を行います:</p>
521517

522518
<span class='rusttest'>fn main() {
523519
&#39;outer: for x in 0..10 {

0 commit comments

Comments
 (0)