


slog: Bagaimanakah perkembangan pakej log berstruktur rasmi Go berjalan? Bagaimana cara menggunakannya?
Pelajar yang biasa dengan Go tahu bahawa log perpustakaan standard bahasa Go mempunyai banyak titik kesakitan, seperti tiada klasifikasi log, tiada struktur (tiada format JSON), skalabiliti yang lemah, dll. Untuk menyelesaikan masalah ini, Go melancarkan slog pakej log berstruktur secara rasmi, perpustakaan ini sedang dibangunkan dan telah memasuki perpustakaan percubaan: golang.org/x/exp/slog Versi semasa ialah v0.0.0.
Dalam artikel ini, mari kita lihat cara menggunakan pakej slog? . daripada log perpustakaan standard. Struktur yang sangat penting dalam perpustakaan slog ialah Logger, yang melaluinya fungsi pengelogan Info(), Debug(), dll. boleh dipanggil. Kami belum mencipta Logger untuk ini dan akan menggunakan yang lalai Anda boleh klik masuk untuk melihat kod sumber.
Handler
Handler ditakrifkan sebagai antara muka, yang boleh menjadikan slog lebih berskala menyediakan dua pelaksanaan Handler terbina dalam: TextHandler dan JSONHandler Selain itu, kami boleh mentakrifkannya berdasarkan log pihak ketiga pakej atau diri kita sendiri Tentukan pelaksanaan Handler, yang akan kita bincangkan kemudian.
go get golang.org/x/exp/slog
Pengendali Teks
TextHandler akan mengeluarkan log sebagai baris teks sama seperti pakej log perpustakaan standard.
func main() { slog.Info("Go is best language!", "公众号", "Golang来啦") }
Output:
2023/01/23 10:23:37 INFO Go is best language! 公众号=Golang来啦
Kami melihat bahawa log keluaran dibentangkan dalam bentuk "key1=value1 key2=value2 ... keyN=valueN". JSON Handler
Kami menggantikan NewTextHandler() di atas dengan NewJSONHandler()
Output:Atas ialah kandungan terperinci slog: Bagaimanakah perkembangan pakej log berstruktur rasmi Go berjalan? Bagaimana cara menggunakannya?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas





Dalam Go, mesej WebSocket boleh dihantar menggunakan pakej gorila/soket web. Langkah khusus: Wujudkan sambungan WebSocket. Hantar mesej teks: Panggil WriteMessage(websocket.TextMessage,[]bait("Mesej")). Hantar mesej binari: panggil WriteMessage(websocket.BinaryMessage,[]bait{1,2,3}).

Dalam Go, kitaran hayat fungsi termasuk definisi, pemuatan, pemautan, pemulaan, panggilan dan skop pembolehubah dibahagikan kepada tahap fungsi dan tahap blok Pembolehubah dalam fungsi boleh dilihat secara dalaman, manakala pembolehubah dalam blok hanya kelihatan dalam blok .

Dalam Go, anda boleh menggunakan ungkapan biasa untuk memadankan cap masa: susun rentetan ungkapan biasa, seperti yang digunakan untuk memadankan cap masa ISO8601: ^\d{4}-\d{2}-\d{2}T \d{ 2}:\d{2}:\d{2}(\.\d+)?(Z|[+-][0-9]{2}:[0-9]{2})$ . Gunakan fungsi regexp.MatchString untuk menyemak sama ada rentetan sepadan dengan ungkapan biasa.

Bahasa Go dan Go adalah entiti yang berbeza dengan ciri yang berbeza. Go (juga dikenali sebagai Golang) terkenal dengan kesesuaiannya, kelajuan penyusunan pantas, pengurusan memori dan kelebihan merentas platform. Kelemahan bahasa Go termasuk ekosistem yang kurang kaya berbanding bahasa lain, sintaks yang lebih ketat dan kekurangan penaipan dinamik.

Kebocoran memori boleh menyebabkan memori program Go terus meningkat dengan: menutup sumber yang tidak lagi digunakan, seperti fail, sambungan rangkaian dan sambungan pangkalan data. Gunakan rujukan yang lemah untuk mengelakkan kebocoran memori dan objek sasaran untuk pengumpulan sampah apabila ia tidak lagi dirujuk dengan kuat. Menggunakan go coroutine, memori tindanan coroutine akan dikeluarkan secara automatik apabila keluar untuk mengelakkan kebocoran memori.

Lihat dokumentasi fungsi Go menggunakan IDE: Tuding kursor pada nama fungsi. Tekan kekunci pintas (GoLand: Ctrl+Q; VSCode: Selepas memasang GoExtensionPack, F1 dan pilih "Go:ShowDocumentation").

Unit menguji fungsi serentak adalah penting kerana ini membantu memastikan kelakuan mereka yang betul dalam persekitaran serentak. Prinsip asas seperti pengecualian bersama, penyegerakan dan pengasingan mesti dipertimbangkan semasa menguji fungsi serentak. Fungsi serentak boleh diuji unit dengan mensimulasikan, menguji keadaan perlumbaan dan mengesahkan keputusan.

Apabila menghantar peta ke fungsi dalam Go, salinan akan dibuat secara lalai dan pengubahsuaian pada salinan tidak akan menjejaskan peta asal. Jika anda perlu mengubah suai peta asal, anda boleh menghantarnya melalui penuding. Peta kosong perlu dikendalikan dengan berhati-hati, kerana ia secara teknikal adalah penunjuk sifar, dan menghantar peta kosong kepada fungsi yang menjangkakan peta tidak kosong akan menyebabkan ralat.
