この記事は、Go 言語で Json を使用する方法を紹介する golang チュートリアル コラムによって提供されており、困っている友人の役に立てば幸いです。
エンコード
オブジェクトを JSON
データにエンコードし、interface{}
オブジェクトを受け入れます、[]byte
と error
を返します:
func Marshal(v interface{}) ([]byte, error)
Marshal
この関数はオブジェクト全体を再帰的に走査し、メンバーの型によってオブジェクトを評価します。エンコーディング、型変換ルールは次のとおりです:
-
bool
型をJSON
Boolean
## に変換します。 - #整数、浮動小数点数、その他の数値型は
JSON
Number
に変換されます。 #string
の文字列に変換します ("" 引用符付き)
struct
# の
に変換します##JSONObject
を作成し、 配列またはスライスを - JSON
の
Array
## に再帰的にパックします。各メンバーの型に基づきます。
#[]byte - は、最初に
base64
エンコードされてから、
JSON文字列に変換されます
map - は
Object
##interface{}に変換され、
JSONに変換されました。
keyは
である必要がありますstring 実際の内部型に応じて変換します -
#nil 変換 - JSON
、null
##channel
func - 、およびその他の型は
UnsupportedTypeError を返します。
type ColorGroup struct { ID int Name string Colors []string } group := ColorGroup{ ID: 1, Name: "Reds", Colors: []string{"Crimson", "Red", "Ruby", "Maroon"}, } b, err := json.Marshal(group) if err != nil { fmt.Println("error:", err) } os.Stdout.Write(b) Output: {"ID":1,"Name":"Reds","Colors":["Crimson","Red","Ruby","Maroon"]}
デコード
デコード JSONdata
func Unmarshal(data []byte, v interface{}) error型変換ルールと上記のルール
var jsonBlob = []byte(`[ {"Name": "Platypus", "Order": "Monotremata"}, {"Name": "Quoll", "Order": "Dasyuromorphia"} ]`) type Animal struct { Name string Order string } var animals []Animal err := json.Unmarshal(jsonBlob, &animals) if err != nil { fmt.Println("error:", err) } fmt.Printf("%+v", animals) Output: [{Name:Platypus Order:Monotremata} {Name:Quoll Order:Dasyuromorphia}]
構造体
構造体は、処理するには大文字で始まるメンバーである必要があります。 JSON による、小文字で始まるメンバーは効果がありません。
Mashal、構造体のメンバー変数名は、
JSON
Object# の key
として ## に直接パッケージ化されます。 JSON
;Unmashal
、対応する変数名は割り当てのために自動的に照合され、大文字と小文字は区別されません。 Unmarshal
の際、JSON
に余分なフィールドがある場合、それらは直接破棄されます。
にフィールドがない場合は、構造内の変数に値を代入しないことは無視され、エラーは報告されません。 <pre class="brush:php;toolbar:false">type Message struct {
Name string
Body string
Time int64
inner string
} var m = Message{
Name: "Alice",
Body: "Hello",
Time: 1294706395881547000,
inner: "ok", } b := []byte(`{"nAmE":"Bob","Food":"Pickle", "inner":"changed"}`) err := json.Unmarshal(b, &m) if err != nil {
fmt.Printf(err.Error())
return} fmt.Printf("%v", m) Output: {Bob Hello 1294706395881547000 ok}</pre>
StructTag
構造体のメンバーと JSON の間の対応関係を手動で構成する場合構造体にラベルを付けるときは、メンバーにラベルを付けます。 フィールドが
nil または 0 値 (数値 0) の場合は、使い慣れた omitempty
を使用します。 、文字列 ""、空の配列 [] など)、パッケージ化された
結果にはこのフィールドはありません。 <pre class="brush:php;toolbar:false">type Message struct {
Name string `json:"msg_name"` // 对应JSON的msg_name
Body string `json:"body,omitempty"` // 如果为空置则忽略字段
Time int64 `json:"-"` // 直接忽略字段 } var m = Message{
Name: "Alice",
Body: "",
Time: 1294706395881547000, } data, err := json.Marshal(m) if err != nil {
fmt.Printf(err.Error())
return} fmt.Println(string(data)) Output: {"msg_name":"Alice"}</pre>
使用の柔軟性が向上JSON
json.RawMessageを使用
json .RawMessage は、実際には []byte 型の再定義です。キャスト可能です。
構造内のフィールドの 1 つの形式が不明なシナリオがあります: <pre class="brush:php;toolbar:false">type Command struct {
ID int
Cmd string
Args *json.RawMessage
}</pre>
json.RawMessage
が使用されている場合、
#Unmarshal
の場合、## フィールドは解析されず、バイト データはArgs に直接割り当てられます。まず最初のレイヤーの
JSON データを解凍し、次に
Cmd の値に基づいて
Args の特定のタイプを 2 回目に決定します
アンマーシャル。
ここで、ポインタ型
*json.RawMessage を使用する必要があることに注意してください。そうでない場合、
Args は
[]byte
base64 エンコードされた文字列にパックされます。
インターフェース{}
インターフェース{}type を使用すると、JSON が自動的に対応するデータ型:
JSON的boolean 转换为boolJSON的数值 转换为float64JSON的字符串 转换为stringJSON的Array 转换为[]interface{}JSON的Object 转换为map[string]interface{}JSON的null 转换为nil注意すべき点が 2 つあります。 1 つは、すべての
JSON 値が
float64 型に自動的に変換されることです。使用する場合は、必要な
int、## に手動で変換する必要があります。 #int64
およびその他の型。 2 つ目は
の object
で、自動的に map[string]interface{}
型に変換されます。アクセスする際は JSON ``Object'' を使用します。 ## 直接 # のフィールド名は
key としてアクセスされます。
JSON データの形式がわからない場合は、
interface{} を使用できます。
自定义类型
如果希望自己定义对象的打包解包方式,可以实现以下的接口:
type Marshaler interface { MarshalJSON() ([]byte, error) } type Unmarshaler interface { UnmarshalJSON([]byte) error }
实现该接口的对象需要将自己的数据打包和解包。如果实现了该接口,json
在打包解包时则会调用自定义的方法,不再对该对象进行其他处理。
以上がGo で Json を使用する方法を教えますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

GolangとPythonの主な違いは、並行性モデル、タイプシステム、パフォーマンス、実行速度です。 1. GolangはCSPモデルを使用します。これは、同時タスクの高いタスクに適しています。 Pythonは、I/O集約型タスクに適したマルチスレッドとGILに依存しています。 2。Golangは静的なタイプで、Pythonは動的なタイプです。 3.ゴーランコンパイルされた言語実行速度は高速であり、Python解釈言語開発は高速です。

Golangは通常Cよりも遅くなりますが、Golangはプログラミングと開発効率の同時により多くの利点があります。1)Golangのゴミ収集と並行性モデルにより、同時性の高いシナリオではうまく機能します。 2)Cは、手動のメモリ管理とハードウェアの最適化により、より高いパフォーマンスを取得しますが、開発の複雑さが高くなります。

GolangはクラウドコンピューティングとDevOpsで広く使用されており、その利点はシンプルさ、効率性、および同時プログラミング機能にあります。 1)クラウドコンピューティングでは、GolangはGoroutineおよびチャネルメカニズムを介して同時リクエストを効率的に処理します。 2)DevOpsでは、Golangの高速コンピレーションとクロスプラットフォーム機能により、自動化ツールの最初の選択肢になります。

GolangとCにはそれぞれ、パフォーマンス効率に独自の利点があります。 1)GolangはGoroutineおよびGarbage Collectionを通じて効率を向上させますが、一時停止時間を導入する場合があります。 2)Cは、手動のメモリ管理と最適化を通じて高性能を実現しますが、開発者はメモリリークやその他の問題に対処する必要があります。選択するときは、プロジェクトの要件とチームテクノロジースタックを考慮する必要があります。

Golangは高い並行性タスクにより適していますが、Pythonには柔軟性がより多くの利点があります。 1.Golangは、GoroutineとChannelを介して並行性を効率的に処理します。 2。Pythonは、GILの影響を受けるが、複数の並行性メソッドを提供するスレッドとAsyncioに依存しています。選択は、特定のニーズに基づいている必要があります。

GolangとCのパフォーマンスの違いは、主にメモリ管理、コンピレーションの最適化、ランタイム効率に反映されています。 1)Golangのゴミ収集メカニズムは便利ですが、パフォーマンスに影響を与える可能性があります。

seetgolangforhighperformance andconcurrency、ithyforbackendservicesandnetworkプログラミング、selectthonforrapiddevelopment、datascience、andmachinelearningduetoistsversitydextentextensextensentensiveLibraries。

GolangとPythonにはそれぞれ独自の利点があります。Golangは高性能と同時プログラミングに適していますが、PythonはデータサイエンスとWeb開発に適しています。 Golangは同時性モデルと効率的なパフォーマンスで知られていますが、Pythonは簡潔な構文とリッチライブラリエコシステムで知られています。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

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

ZendStudio 13.5.1 Mac
強力な PHP 統合開発環境

VSCode Windows 64 ビットのダウンロード
Microsoft によって発売された無料で強力な IDE エディター

MantisBT
Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

SecLists
SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。
