Bagaimana untuk menghasilkan UUID/GUID di C?
Terdapat tiga cara yang berkesan untuk menjana UUIDs atau GUID dalam C: 1. Gunakan Perpustakaan Boost, yang menyediakan sokongan multi-versi dan mudah untuk antara muka; 2. Secara manual menjana versi 4 uuid sesuai untuk keperluan mudah; 3. Gunakan API spesifik platform (seperti Windows 'cocreateeguid), tanpa kebergantungan pihak ketiga. Boost sesuai untuk kebanyakan projek moden, pelaksanaan manual sesuai untuk senario ringan, dan API Platform sesuai untuk persekitaran perusahaan.
Sekiranya anda perlu menjana UUID atau GUID di C, tiada sokongan perpustakaan standard terbina dalamnya sebelum C 20, dan walaupun itu, ia terhad. Oleh itu, kebanyakan pemaju sama ada menggunakan perpustakaan luaran atau melaksanakan penyelesaian mereka sendiri berdasarkan versi UUID yang diketahui.

Berikut adalah cara anda boleh melakukannya dengan berkesan bergantung kepada keperluan dan persekitaran anda.

Gunakan perpustakaan seperti boost::uuids
Boost adalah salah satu cara yang paling biasa dan boleh dipercayai untuk menjana UUID dalam c. Ia menyokong pelbagai versi UUID dan menyediakan API yang bersih.
- Pasang Boost (jika belum dipasang) melalui pengurus pakej seperti VCPKG atau terus dari sumber.
- Sertakan
<boost></boost>
dan<boost></boost>
. - Gunakan penjana rawak seperti ini:
#include <boost/uuid/uuid.hpp> #include <boost/uuid/uuid_generators.hpp> #include <boost/uuid/uuid_io.hpp> #include <iostream> int main () { Boost :: uuids :: uuid uuid = boost :: uuids :: random_generator () (); std :: cout << uuid << std :: endl; kembali 0; }
Ini memberi anda versi 4 uuid secara lalai. Jika anda memerlukan versi lain, Boost mempunyai sokongan untuk perkara-perkara seperti nama (versi 3 atau 5) dan berasaskan masa (versi 1) UUIDs juga.

Menjana secara manual untuk keperluan mudah
Jika anda tidak mahu menarik perpustakaan besar seperti Boost, anda boleh menjana versi asas 4 uuid secara manual.
Versi 4 uuid kelihatan seperti ini: xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx
Di mana:
- Kumpulan ketiga bermula dengan "4" (menunjukkan versi 4).
- Kumpulan keempat bermula dengan "8", "9", "A", atau "B".
Anda boleh membuat rentetan rawak mengikut corak itu menggunakan sesuatu seperti:
#include <candrand> #include <string> #include <iostream> std :: string penjana_uuid_v4 () { statik std :: random_device rd; statik std :: mt19937 gen (rd ()); statik std :: uniform_int_distribusi <> dis (0, 15); statik std :: uniform_int_distribusi <> dis2 (8, 11); std :: string uuid = "xxxxxxx-xxxx-4xxx-yxxxx-xxxxxxxxxxxxxxxx"; untuk (int i = 0; i <uuid.size (); i) { jika (uuid [i] == 'x') { int r = dis (gen); uuid [i] = "0123456789Abcdef" [r]; } else if (uuid [i] == 'y') { int r = dis2 (gen); uuid [i] = "89ab" [r - 8]; } } kembali uuid; } int main () { std :: cout << generate_uuid_v4 () << std :: endl; kembali 0; }
Ini tidak selamat secara kritikal tetapi berfungsi dengan baik untuk aplikasi mudah.
Gunakan API khusus platform (contoh Windows)
Di Windows, anda boleh menggunakan API CoCreateGuid
asli, yang merupakan sebahagian daripada perpustakaan COM.
Langkah:
- Termasuk
<objbase.h>
- Pautan terhadap
ole32.lib
- Panggil
CoCreateGuid()
untuk mengisi strukturGUID
Contoh:
#include <objbase.h> #include <iostream> std :: string guid_to_string (const guid & guid) { Char Guidstr [37]; sprintf_s (guidstr, "X- X- X- X- X X- XXXXXX", guid.data1, guid.data2, guid.data3, guid.data4 [0], guid.data4 [1], guid.data4 [2], guid.data4 [3], guid.data4 [4], guid.data4 [5], guid.data4 [6], guid.data4 [7]); kembali std :: string (guidstr); } int main () { Coinitialize (nullptr); GUID GUID; Cocreateguid (& guid); std :: cout << guid_to_string (guid) << std :: endl; Couninitialize (); kembali 0; }
Kaedah ini mengelakkan kebergantungan pihak ketiga dan menggunakan alat peringkat OS, yang boleh membantu dalam persekitaran perusahaan.
Ringkasan Pilihan
- Boost : Full foted, mudah digunakan, menyokong pelbagai versi UUID.
- Generasi manual : ringan, baik untuk keperluan asas, tidak selamat.
- API khusus platform : Tiada kebergantungan luaran, tetapi tidak mudah alih.
Bergantung pada persediaan dan keperluan projek anda, pilih kaedah yang paling sesuai. Bagi kebanyakan projek moden, Boost adalah pertaruhan yang paling mudah dan paling selamat melainkan jika anda mempunyai had ketergantungan yang ketat.
Pada dasarnya itu sahaja.
Atas ialah kandungan terperinci Bagaimana untuk menghasilkan UUID/GUID di C?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undress AI Tool
Gambar buka pakaian secara percuma

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

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

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)

Kaedah yang paling biasa untuk mencari elemen vektor di C adalah menggunakan std :: cari. 1. Gunakan std :: cari untuk mencari dengan julat iterator dan nilai sasaran. Dengan membandingkan sama ada Iterator yang dikembalikan adalah sama dengan akhir (), kita boleh menilai sama ada ia dijumpai; 2. Untuk jenis tersuai atau keadaan kompleks, std :: find_if harus digunakan dan fungsi predikat atau ekspresi lambda harus diluluskan; 3. Apabila mencari jenis standard seperti rentetan, anda boleh lulus rentetan sasaran secara langsung; 4. Kerumitan setiap carian adalah O (n), yang sesuai untuk data berskala kecil. Untuk carian yang kerap, anda harus mempertimbangkan menggunakan std :: set atau std :: unordered_set. Kaedah ini mudah, berkesan dan meluas untuk pelbagai senario carian.

Jawapannya ialah: Gunakan std :: String constructor untuk menukar array char ke std :: string. Jika array mengandungi pertengahan '\ 0', panjang mesti ditentukan. 1. Untuk rentetan gaya C yang berakhir dengan '\ 0', gunakan std :: stringstr (charArray); untuk melengkapkan penukaran; 2. Jika array char mengandungi pertengahan '\ 0' tetapi perlu menukar aksara n pertama, gunakan std :: stringstr (chararray, panjang); untuk menentukan panjangnya; 3. Apabila memproses pelbagai saiz tetap, pastikan ia berakhir dengan '\ 0' dan kemudian tukarnya; 4. Gunakan Str.Assign (CharArray, CharArray Strl

Direktori apa yang ringkas (membuktikan) yang mencipta ringkas (membuktikan)? Modal teroka mana yang menyokong ringkas (membuktikan)? Betapa ringkasnya (membuktikan) berfungsi SP1ZKVM dan penguasaan rangkaian Opsuccon Teknologi Pengesahan rantaian rantaian membuktikan token token token token peruntukan token utiliti yang berpotensi pemegang token membuktikan ramalan harga token membuktikan aktiviti perdagangan pra-pasaran pra-pasaran ramalan masyarakat membuktikan harga token mengapa memilih yang ringkas? Succ

STD :: MUTEX digunakan untuk melindungi sumber bersama untuk mencegah persaingan data. Contohnya, penguncian automatik dan pembukaan std :: lock_guard digunakan untuk memastikan keselamatan multi-thread; 1. Menggunakan std :: mutex dan std :: lock_guard boleh mengelakkan risiko abnormal yang dibawa oleh pengurusan manual kunci; 2. Pembolehubah yang dikongsi seperti kaunter mesti dilindungi dengan mutex apabila mengubah suai multi-threads; 3. Pengurusan kunci gaya RAII disyorkan untuk memastikan keselamatan pengecualian; 4. Elakkan kebuntuan dan banyak kunci dalam urutan tetap; 5. Sebarang senario akses berbilang thread kepada sumber yang dikongsi harus menggunakan penyegerakan mutex, dan program akhir dengan betul output yang dijangkakan: 10000 dan sebenarnya: 10000.

TODEBUGAC ApplicingGDBinVisualStudiCode, ConfigureTheLaunch.JsonFileCorrectly; KeysettingSincludespecyingTheExecutablePathwith "Program", Menetapkan "Mimode" kepada "GDB" dan "Type" kepada "CPPDBG", menggunakan "EX

Jika ia meleleh apabila memadam elemen, anda mesti mengelakkan menggunakan Iterator yang gagal. ① Cara yang betul adalah menggunakannya = vec.erase (IT), dan gunakan iterator yang sah yang dikembalikan dengan memadam untuk terus melintasi; ② Idiom yang disyorkan untuk penghapusan batch: vec.erase (std :: rove_if (vec.begin (), vec.end (), syarat), vec.end ()), yang selamat dan cekap; ③ Anda boleh menggunakan iterator terbalik untuk memadam dari belakang ke depan, logiknya jelas, tetapi anda perlu memberi perhatian kepada arah keadaan. Kesimpulan: Sentiasa mengemas kini iterator dengan nilai pulangan memadam, melarang operasi pada Iterator yang gagal, jika tidak, tingkah laku yang tidak ditentukan akan dihasilkan.

Theautokeywordinc deducesthetypeofavariableFromitsinitializer, MakingCodeCleanerAndmoremaintainable.1.itreduceRosities, terutamanyaWithcomplextypesikeiterators.2.itenhancesmaintabilitybyautomaticallyAdAdAdAdAttottoTypeChanges.3.Isisnessaryaryaryypechanges

Tagdispatching menggunakan tag jenis untuk memilih kelebihan fungsi optimum semasa tempoh penyusunan untuk mencapai polimorfisme yang cekap. 1. Gunakan std :: iterator_traits untuk mendapatkan tag kategori iterator; 2. Tentukan pelbagai fungsi kelebihan DO_Advance, dan proses random_access_iterator_tag, bidrectional_iterator_tag dan input_iterator_tag masing -masing; 3. Fungsi utama My_Advance memanggil versi yang sepadan berdasarkan jenis tag yang diperolehi untuk memastikan tidak ada overhead runtime semasa keputusan masa kompilasi; 4. Teknologi ini diterima pakai oleh perpustakaan standard seperti STD :: Advance, dan menyokong penyesuaian lanjutan.
