構造スライス! =それが実装するインターフェーススライス?
php エディタ Apple は、構造スライスに関するパズルを明らかにするためにここにいます。構造スライスと、それが実装するインターフェイス スライスの違いは何ですか? Go 言語では、スライスはサイズを動的に変更できる便利で柔軟なデータ構造です。構造体スライスは特殊な形式のスライスで、構造体タイプの要素を格納します。しかし、同じインターフェイスを実装するスライスとどう違うのでしょうか?一緒に答えを見つけてみましょう。
質問の内容
インターフェイス Model
があり、構造体 person
によって実装されています。
モデル インスタンスを取得するために、次のヘルパー関数があります:
リーリー上記のメソッドにより、正しいタイプの Person インスタンスを返すことができます (同じメソッドを使用して、後で新しいモデルを簡単に追加できます)。
モデル スライスを返すためにこのようなことを実行しようとすると、エラーが発生します。コード:
リーリーGo は次のように不満を述べています: newpersons() (タイプ []パーソン) をタイプ []Model の戻りパラメータとして使用できません
私の目標は、リクエストされたあらゆるモデル タイプのスライスを返すことです ([]Person
、[]FutureModel
、[]Terminator2000
、w/ e)。何が欠けているのでしょうか?そのようなソリューションを適切に実装するにはどうすればよいですか?
解決策
これは、先ほど答えた質問と非常によく似ています: https://www.php.cn/link/2c029952e202c0e560626a4c5980d64c
簡単に言えば、あなたの言う通りです。構造体のスライスは、構造体によって実装されるインターフェイスのスライスと等しくありません。
[]person
と []Model
のメモリ レイアウトは異なります。これは、それらが属する型のメモリ レイアウトが異なるためです。 Model
はインターフェイス値であり、メモリ内で 2 ワードのサイズであることを意味します。 1 つのワードはタイプ情報を表し、もう 1 つのワードはデータを表します。 Person
は、含まれるフィールドによってサイズが異なる構造体です。 []Person
から []Model
に変換するには、配列をループして各要素を型キャストする必要があります。
この変換は O(n) 操作であり、新しいスライスが作成されるため、Go はこの操作を暗黙的に実行することを拒否します。次のコードを使用して、これを明示的に行うことができます。
リーリーdskinner が指摘したように、 必要なのはスライスへのポインタではなく、スライスへのポインタである可能性が高いです。通常、スライスへのポインタは必要ありません。
リーリー以上が構造スライス! =それが実装するインターフェーススライス?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











redisstreamを使用してGo言語でメッセージキューを実装する問題は、GO言語とRedisを使用することです...

Golandのカスタム構造ラベルが表示されない場合はどうすればよいですか?ゴーランドを使用するためにGolandを使用する場合、多くの開発者はカスタム構造タグに遭遇します...

はい、H5ページの生産は、HTML、CSS、JavaScriptなどのコアテクノロジーを含むフロントエンド開発のための重要な実装方法です。開発者は、< canvas>の使用など、これらのテクノロジーを巧みに組み合わせることにより、動的で強力なH5ページを構築します。グラフィックを描画するタグまたはJavaScriptを使用して相互作用の動作を制御します。

CSSでサイズ変更シンボルをカスタマイズする方法は、背景色で統一されています。毎日の開発では、調整など、ユーザーインターフェイスの詳細をカスタマイズする必要がある状況に遭遇することがよくあります...

セグメントターの45度の曲線効果を達成する方法は?セグメンテーションデバイスを実装する過程で、左ボタンをクリックすると、適切な境界線を45度の曲線に変える方法とポイント...

JavaScriptまたはCSSを使用して、ブラウザの印刷設定のページの上部と端を制御する方法。ブラウザの印刷設定には、ディスプレイが...

インラインブロック要素の誤った整列ディスプレイの理由とソリューションに関して。 Webページのレイアウトを書くとき、私たちはしばしばいくつかの奇妙な表示の問題に遭遇します。比較する...

大企業または有名なオープンソースプロジェクトによって開発されたGOのどのライブラリが開発されていますか? GOでプログラミングするとき、開発者はしばしばいくつかの一般的なニーズに遭遇します...
