


Adakah selamat untuk digunakan tidak selamat. Penunjuk untuk terus menukar struct 'titik' kepada struct lain?
Feb 09, 2024 pm 06:48 PMDalam bahasa Go, anda boleh terus menukar satu struktur kepada struktur lain menggunakan `unsafe.Pointer`. Walau bagaimanapun, sama ada penukaran ini selamat adalah persoalan yang patut dibincangkan. Seseorang mesti berhati-hati apabila menggunakan `unsafe.Pointer` untuk penukaran struktur kerana ia boleh membawa kepada ralat capaian memori atau kerosakan data. Dalam kes ini, boleh dikatakan bahawa adalah tidak selamat untuk menggunakan `unsafe.Pointer` untuk menukar secara langsung struct `point` kepada struct lain. Disebabkan keperluan untuk memudahkan teks, isu ini tidak boleh dibincangkan dengan lebih terperinci. Adalah disyorkan untuk menggunakan kaedah penukaran ini dengan berhati-hati dalam pembangunan sebenar dan menggunakan kaedah selamat yang lain untuk menukar struktur.
Kandungan soalan
Adakah ia selamat?
1 |
|
Kod contoh:
1 2 3 4 5 6 7 8 9 10 11 12 |
|
teams := testtrans()
Adakah ahli array akan dikumpul sampah?
Terdapat banyak struktur dan medan yang dikembalikan melalui grpc, dan takrifannya adalah sama dengan takrifan tempatan, jadi saya mahu menggunakan cara yang lebih cekap ini ((*teamdata)(unsafe.pointer(&team.id))
), tetapi saya tidak tahu sama ada akan ada sebarang risiko.
Contoh penuh: Dokumentasi untuk https://go.dev/play/p/q3gwp2mervj
Workaround
unsafe.pointer menerangkan penggunaan yang disokong. Terutamanya:
(1) Tukar *t1 kepada penunjuk kepada *t2.
Premisnya ialah t2 tidak lebih besar daripada t1 dan kedua-duanya berkongsi satu Susun atur memori yang setara, transformasi ini membolehkan data ditafsir semula Satu jenis bertindak sebagai data untuk jenis lain.
Pengumpul sampahgo mengetahui petunjuk dalaman dan tidak akan mengutip peruntukan mentah sehingga tiada rujukan yang tinggal kepada blok tersebut.
Oleh itu, apabila ada sepasang *teamdata
的引用时,较大的分配(示例中的 grpcretteam
) akan dibaiki.
Satu lagi pertimbangan utama ialah penjajaran medan struct. Contohnya:
1 2 3 4 5 6 7 8 9 10 11 12 |
|
Dalam kes ini, penggunaan tidak selamat daripada parent
中提取 bad
adalah tidak sah kerana susun atur memori berbeza.
Dalam kebanyakan kes, selalunya sebaiknya elakkan unsafe.pointer
helah melainkan diperlukan untuk memenuhi keperluan fungsi atau prestasi. Kod selalunya boleh difaktorkan semula untuk meminimumkan peruntukan.
Jika anda mesti menggunakan unsafe
untuk memenuhi keperluan prestasi--
Saya mengesyorkan menggunakan pakej reflect
untuk melaksanakan ujian bagi memastikan penjajaran/reka letak memori adalah sah untuk struct kanak-kanak.
Atas ialah kandungan terperinci Adakah selamat untuk digunakan tidak selamat. Penunjuk untuk terus menukar struct 'titik' kepada struct lain?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Artikel Panas

Alat panas Tag

Artikel Panas

Tag artikel 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

Cara menggunakan refleksi untuk mengakses medan dan kaedah persendirian dalam golang

Perbezaan antara ujian prestasi dan ujian unit dalam bahasa Go

Bagaimana untuk menggunakan alat analisis prestasi untuk menganalisis dan mengoptimumkan fungsi Java?

Apakah perangkap yang perlu kita perhatikan semasa mereka bentuk sistem teragih dengan teknologi Golang?

Kebocoran memori dalam aplikasi PHP: sebab, pengesanan dan penyelesaian

Perpustakaan dan alatan teknologi Golang yang digunakan dalam pembelajaran mesin

Evolusi konvensyen penamaan fungsi golang

Peranan teknologi Golang dalam pembangunan IoT mudah alih
