json.Marshal エラー処理: 入力によって引き起こされるエラーを理解する
ドキュメントで強調表示されている json.Marshal 関数は、周期的なエラーの処理に失敗します。データ構造が壊れ、実行時パニックが発生します。これは一般的なシナリオですが、代わりに非パニック エラーが生成される状況が発生する可能性があります。
エラー生成を引き起こす入力
非パニック エラーを説明するには、パニック シナリオでは、次の例を考えてみましょう:
<code class="go">type Node struct { Value int Next *Node } func main() { node1 := Node{1, nil} node2 := Node{2, &node1} node1.Next = &node2 _, err := json.Marshal(node1) if err != nil { fmt.Printf("Error encountered: %v\n", err) } }</code>
結果:
上記のプログラムはパニックせずに実行され、代わりにエラー: json: unsupported type: * を返します。 main.Node
エラーの種類
json.Marshal 関数は、次の 2 種類のエラーを生成できます:
指定された例では、エラーは無効な型ではなく無効な値 (循環データ構造) に関係しているため、UnsupportedValueError カテゴリに分類されます。
追加の例:
json.Marshal が非 nil エラーを返す可能性のある追加のシナリオをいくつか示します:
<code class="go">_, err := json.Marshal(nil) // Error: json: unsupported value: nil _, err := json.Marshal(1e100) // Error: json: unsupported value: 1e+100, must be finite</code>
以上が「json.Marshal」がパニック以外のエラーを返すのはいつですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。