質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.49%
Go

Go(golang)は、Googleで開発されたオープンソースのプログラミング言語です。

Q&A

1回答

984閲覧

Goでinterface型の返り値に、interfaceを満たすstructを指定できない理由について

退会済みユーザー

退会済みユーザー

総合スコア0

Go

Go(golang)は、Googleで開発されたオープンソースのプログラミング言語です。

0グッド

0クリップ

投稿2019/10/19 00:18

下記のプログラムがエラーになる理由を知りたいと思っています。
(Go Playground => https://play.golang.org/p/6vEfSxyiIy8

go

1package main 2 3type InterfaceA interface { 4 Child() InterfaceA 5} 6 7type StructA struct { 8 child *StructA 9} 10 11func (s *StructA) Child() *StructA { 12 return s.child 13} 14 15func main() { 16 var _ InterfaceA = &StructA{} 17}

エラー内容はこちらです。

./prog.go:16:6: cannot use &StructA literal (type *StructA) as type InterfaceA in assignment:
*StructA does not implement InterfaceA (wrong type for Child method)
have Child() *StructA
want Child() InterfaceA

*StructAのChild()関数の戻り値型を InterfaceA に変更すれば動くということは分かっていますが、
なぜ戻り値型が *StructA の場合にエラーとなる仕様なのか、背景を知りたいと思っています。

よろしくお願い致します。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

インターフェースの定義に書くサポートメソッドは

  • メソッド名
  • 引数の数・型
  • 返値の数・型

以上の全てが一致して初めてそのメソッドをサポートしてる扱いになるといのが原則です。
受け渡しされるものが同じ型かどうかは関係ありません。

----追記----

挙動自体は把握されてるとのことなので
あとからこの質問を参照する人のために補足だけ追記しておきます。

あくまで「InterfaceA」と「*StructA」は異なる値をもつ型です。
(前者は値と型を値として格納されており、後者は値のみです)
ある構造体をあるインターフェースの値に代入する時、互換がある場合は
暗黙(自動)で型変換されるという機能があるだけです。

仮に例示のメソッドの返値の型が「InterfaceA」と「*StructA」のどちらを記述しても
インターフェースとしての互換性があると判定できるようになっていたとしても思い当たるようなメリットがありません。

その判定を行うためには「あくまで異なる型」を一度互換がとれていると仮定して
互換が取れているのかを確認する必要が出てきます。

これではインターフェース型と非インターフェース型の互換性チェックがむやみに複雑になるし、
あとから定義を見直したときにも互換が取れているのかが読み取りにくくなります。

なのでインターフェースの互換チェックではメソッドのシグネチャ(メソッド名や入出力パラメータの数や型)が合致するかどうかというシンプルなルールだけで判定されます。

投稿2019/10/19 00:58

編集2019/10/20 14:07
nobonobo

総合スコア3367

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2019/10/19 01:11 編集

ご回答ありがとうございます。 ただ、今回の質問は、interfaceを戻り値型に指定した場合に、そのinterfaceを満たすstructが戻り値型に指定できない仕様の背景について知りたいというものでして、挙動については理解しております。
nobonobo

2019/10/19 01:33

満たさないです。原則のところをお読みください
退会済みユーザー

退会済みユーザー

2019/10/19 01:43

重ねてのご回答ありがとうございます。 先程も記載させて頂きましたが、その背景を知りたいという質問でして、満たしていないという点については理解しております。 背景の部分についてご回答いただけない場合は、以降の返信は控えさせて頂きます。
nobonobo

2019/10/19 04:19

InterfaceAと*StructAは同じ型ではないからインターフェースとの互換条件を満たさないのであって、結果として違う型でかつ互換も無いものを代入しようとしているので当然としか言えないですね。背景をお探しになってもインターフェースとダックタイプをそういう風にした以上の情報はおそらく無いと思います。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.49%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問