Menukar uint64 kepada int64 Tanpa Kehilangan Data
Kod yang diberikan:
<code class="go">var x uint64 = 18446744073709551615 var y int64 = int64(x)</code>
menghasilkan y menjadi -1 . Ini bukan disebabkan oleh kehilangan data, sebaliknya mewakili nilai uint64 maksimum dalam int64. Kedua-dua 18446744073709551615 dan -1 mewakili nilai perduaan yang sama 0xFFFFFFFFFFFFFFFF.
Walau bagaimanapun, kebimbangan yang dibangkitkan mengenai mengekalkan sifat statistik penjana nombor rawak adalah sah. Dalam kes ini, menggunakan pengekod dan penyahkod tidak diperlukan.
Untuk menukar uint64 kepada int64 tanpa mengubah sifat statistiknya:
<code class="go">var x uint64 = 18446744073709551615 - 3 var y int64 = int64(x)</code>
Di sini, x telah dikurangkan sebanyak 3, menghasilkan y mempunyai nilai -4. Operasi ini mengekalkan perwakilan binari nombor, memastikan sifat statistik dikekalkan.
Contohnya:
<code class="go">var x uint64 = 18446744073709551615 - 3 var y int64 = int64(x) fmt.Printf("%b\n", x) // Prints: 1111111111111111111111111111111111111111111111111111111111111100 fmt.Printf("%b or %d\n", y, y) // Prints: -100 or -4</code>
Ini menunjukkan bahawa sifat statistik penjana nombor rawak kekal utuh semasa penukaran .
Atas ialah kandungan terperinci Bagaimana untuk Menukar `uint64` kepada `int64` Tanpa Kehilangan Sifat Statistik?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!