配列の長さが Null でない場合、Go コードで「パニック: ランタイム エラー: インデックスが範囲外です」エラーがスローされるのはなぜですか?
"配列の長さが Null でない場合に「パニック: 実行時エラー: インデックスが範囲外です」を実行
分析
許可された範囲を超えたインデックスにアクセスしたため、提供された Go コードでランタイム エラーが発生しました。Go でスライスを操作する場合、容量と長さの概念を理解することが重要です。
スライスについて
Go スライスは、配列セグメントの記述子であり、配列へのポインター、セグメントの長さ、およびその容量 (セグメントの最大長) が含まれます。
make([]string, 0, 4) と make([]string, 4)
make 関数はスライスを初期化して割り当てます。 result := make ([]string, 0, 4) は長さ 0、容量 4 のスライスを作成します。一方、結果 := make([]string, 4) (または同等の結果 := []string{"", "", "") , ""}) は、長さと容量の両方でスライスを初期化します。 4.
Array Access
In result := make([]string, 0, 4),基になる配列は空であるため、result[0] にアクセスすると実行時エラーが発生します。これに対し、result := make([]string, 4) には 4 つの文字列要素があり、result[0]、result[1]、 result[2] および result[3]。
コードの解決策
myFunc 関数で、問題のある result := make([]string) を使用しています。 、0、4)初期化。コードに要素を追加する必要があることを考慮すると、 result := make([]string, 0) の使用を検討し、append 関数を使用して要素を追加する必要があります。あるいは、特定の要件に応じて、 result := []string{} または result := make([]string, 4) を使用することもできます。
make([] を使用したコードの動作バージョンは次のとおりです。文字列、0) を追加 (The Go Playground):
<code class="go">package main import "fmt" func main() { fmt.Println(myFunc("Political srt")) } func myFunc(input string) []string { strs := strings.Fields(input) result := make([]string, 0) // Initialize with length 0 and append as needed for _, s := range strs { if strings.ContainsAny(s, "eaiu") { result = append(result, s) // Append to the result slice } } return result }</code>
以上が配列の長さが Null でない場合、Go コードで「パニック: ランタイム エラー: インデックスが範囲外です」エラーがスローされるのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

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

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

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

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

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

ホットトピック









OpenSSLは、安全な通信で広く使用されているオープンソースライブラリとして、暗号化アルゴリズム、キー、証明書管理機能を提供します。ただし、その歴史的バージョンにはいくつかの既知のセキュリティの脆弱性があり、その一部は非常に有害です。この記事では、Debian SystemsのOpenSSLの共通の脆弱性と対応測定に焦点を当てます。 Debianopensslの既知の脆弱性:OpenSSLは、次のようないくつかの深刻な脆弱性を経験しています。攻撃者は、この脆弱性を、暗号化キーなどを含む、サーバー上の不正な読み取りの敏感な情報に使用できます。

この記事では、プロファイリングの有効化、データの収集、CPUやメモリの問題などの一般的なボトルネックの識別など、GOパフォーマンスを分析するためにPPROFツールを使用する方法について説明します。

この記事では、GOでユニットテストを書くことで、ベストプラクティス、モッキングテクニック、効率的なテスト管理のためのツールについて説明します。

Go Crawler Collyのキュースレッドの問題は、Go言語でColly Crawler Libraryを使用する問題を調査します。 �...

バックエンド学習パス:フロントエンドからバックエンドへの探査の旅は、フロントエンド開発から変わるバックエンド初心者として、すでにNodeJSの基盤を持っています...

この記事では、GOプログラミングのGo FMTコマンドについて説明します。これは、公式スタイルのガイドラインに準拠するためのコードをフォーマットします。コードの一貫性、読みやすさ、およびスタイルの議論を削減するためのGO FMTの重要性を強調しています。 Best Practices fo

Beegoormフレームワークでは、モデルに関連付けられているデータベースを指定する方法は?多くのBEEGOプロジェクトでは、複数のデータベースを同時に操作する必要があります。 Beegoを使用する場合...
