Skip to content

Commit f590a12

Browse files
committed
Merge pull request #80 from pocket7878/operator-overload
4.32. Operators and Overloading
2 parents 04d1f66 + af5e588 commit f590a12

File tree

1 file changed

+51
-28
lines changed

1 file changed

+51
-28
lines changed

1.6/ja/book/operators-and-overloading.md

Lines changed: 51 additions & 28 deletions
Original file line numberDiff line numberDiff line change
@@ -1,11 +1,15 @@
1-
% Operators and Overloading
1+
% 演算子とオーバーロード
2+
<!-- % Operators and Overloading -->
23

3-
Rust allows for a limited form of operator overloading. There are certain
4-
operators that are able to be overloaded. To support a particular operator
5-
between types, there’s a specific trait that you can implement, which then
6-
overloads the operator.
4+
<!-- Rust allows for a limited form of operator overloading. There are certain -->
5+
<!-- operators that are able to be overloaded. To support a particular operator -->
6+
<!-- between types, there’s a specific trait that you can implement, which then -->
7+
<!-- overloads the operator. -->
8+
Rustは制限された形式での演算子オーバーロードを提供しており、オーバーロード可能な演算子がいくつか存在します。
9+
型同士の間の演算子をサポートするためのトレイトが存在し、それらを実装することで演算子をオーバーロードすることができます。
710

8-
For example, the `+` operator can be overloaded with the `Add` trait:
11+
<!-- For example, the `+` operator can be overloaded with the `Add` trait: -->
12+
例えば、 `+` の演算子は `Add` トレイトを利用することでオーバーロードすることができます:
913

1014
```rust
1115
use std::ops::Add;
@@ -34,17 +38,23 @@ fn main() {
3438
}
3539
```
3640

37-
In `main`, we can use `+` on our two `Point`s, since we’ve implemented
38-
`Add<Output=Point>` for `Point`.
41+
<!-- In `main`, we can use `+` on our two `Point`s, since we’ve implemented -->
42+
<!-- `Add<Output=Point>` for `Point`. -->
43+
`main` 中で、2つの `Point` に対して `+` を使うことができます、
44+
これは `Point` に対して `Add<Output=Point>` を実装したためです。
3945

40-
There are a number of operators that can be overloaded this way, and all of
41-
their associated traits live in the [`std::ops`][stdops] module. Check out its
42-
documentation for the full list.
46+
<!-- There are a number of operators that can be overloaded this way, and all of -->
47+
<!-- their associated traits live in the [`std::ops`][stdops] module. Check out its -->
48+
<!-- documentation for the full list. -->
49+
同じ方法でオーバーロード可能な演算子が多数あります、
50+
それらに対応したトレイトは [`std::ops`][stdops] モジュール内に存在します。
51+
全てのオーバーロード可能な演算子と対応するトレイトについては [`std::ops`][stdops] のドキュメントを読んで確認して下さい。
4352

4453
[stdops]: ../std/ops/index.html
4554

46-
Implementing these traits follows a pattern. Let’s look at [`Add`][add] in more
47-
detail:
55+
<!-- Implementing these traits follows a pattern. Let’s look at [`Add`][add] in more -->
56+
<!-- detail: -->
57+
それらのトレイトの実装はパターンに従います。 [`Add`][add] トレイトを詳しく見ていきましょう:
4858

4959
```rust
5060
# mod foo {
@@ -58,9 +68,11 @@ pub trait Add<RHS = Self> {
5868

5969
[add]: ../std/ops/trait.Add.html
6070

61-
There’s three types in total involved here: the type you `impl Add` for, `RHS`,
62-
which defaults to `Self`, and `Output`. For an expression `let z = x + y`, `x`
63-
is the `Self` type, `y` is the RHS, and `z` is the `Self::Output` type.
71+
<!-- There’s three types in total involved here: the type you `impl Add` for, `RHS`, -->
72+
<!-- which defaults to `Self`, and `Output`. For an expression `let z = x + y`, `x` -->
73+
<!-- is the `Self` type, `y` is the RHS, and `z` is the `Self::Output` type. -->
74+
関連する3つの型が存在します: `impl Add` を実装するもの、 デフォルトが `Self``RHS`、 そして `Output`
75+
例えば、式 `let z = x + y` においては `x``Self``y` は RHS、 `z``Self::Output` 型となります。
6476

6577
```rust
6678
# struct Point;
@@ -69,23 +81,28 @@ impl Add<i32> for Point {
6981
type Output = f64;
7082

7183
fn add(self, rhs: i32) -> f64 {
72-
// add an i32 to a Point and get an f64
84+
# // // add an i32 to a Point and get an f64
85+
// i32をPointに加算しf64を返す
7386
# 1.0
7487
}
7588
}
7689
```
7790

78-
will let you do this:
91+
<!-- will let you do this: -->
92+
上のコードによって以下の様に書けるようになります:
7993

8094
```rust,ignore
8195
let p: Point = // ...
8296
let x: f64 = p + 2i32;
8397
```
8498

85-
# Using operator traits in generic structs
99+
<!-- # Using operator traits in generic structs -->
100+
# オペレータトレイトをジェネリック構造体で使う
86101

87-
Now that we know how operator traits are defined, we can define our `HasArea`
88-
trait and `Square` struct from the [traits chapter][traits] more generically:
102+
<!-- Now that we know how operator traits are defined, we can define our `HasArea` -->
103+
<!-- trait and `Square` struct from the [traits chapter][traits] more generically: -->
104+
オペレータトレイトがどのように定義されているかについて学びましたので、
105+
[トレイトについての章][traits]`HasArea` トレイトと `Square` 構造体をさらに一般的に定義することができます:
89106

90107
[traits]: traits.html
91108

@@ -120,16 +137,22 @@ fn main() {
120137
}
121138
```
122139

123-
For `HasArea` and `Square`, we just declare a type parameter `T` and replace
124-
`f64` with it. The `impl` needs more involved modifications:
140+
<!-- For `HasArea` and `Square`, we just declare a type parameter `T` and replace -->
141+
<!-- `f64` with it. The `impl` needs more involved modifications: -->
142+
`HasArea``Square` について、型パラメータ `T` を宣言し `f64` で置換しました。
143+
`impl` はさらに関連するモディフィケーションを必要とします:
125144

126145
```ignore
127146
impl<T> HasArea<T> for Square<T>
128147
where T: Mul<Output=T> + Copy { ... }
129148
```
130149

131-
The `area` method requires that we can multiply the sides, so we declare that
132-
type `T` must implement `std::ops::Mul`. Like `Add`, mentioned above, `Mul`
133-
itself takes an `Output` parameter: since we know that numbers don't change
134-
type when multiplied, we also set it to `T`. `T` must also support copying, so
135-
Rust doesn't try to move `self.side` into the return value.
150+
<!-- The `area` method requires that we can multiply the sides, so we declare that -->
151+
<!-- type `T` must implement `std::ops::Mul`. Like `Add`, mentioned above, `Mul` -->
152+
<!-- itself takes an `Output` parameter: since we know that numbers don't change -->
153+
<!-- type when multiplied, we also set it to `T`. `T` must also support copying, so -->
154+
<!-- Rust doesn't try to move `self.side` into the return value. -->
155+
`area` メソッドは辺を掛けることが可能なことを必要としています。
156+
そのため型 `T``std::ops::Mul` を実装していなければならないと宣言しています。
157+
上で説明した `Add` と同様に、`Mul``Output` パラメータを取ります: 数値を掛け算した時に型が変わらないことを知っていますので、 `Output``T` と設定します。
158+
また `T` は、Rustが `self.side` を返り値にムーブするのを試みないようにコピーをサポートしている必要があります。

0 commit comments

Comments
 (0)