C# Aritmetik Integer Pendek: Memahami =
lwn. =
C# mempamerkan tingkah laku yang kelihatan bercanggah apabila menambah short
integer. Tugasan langsung (short = short short
) gagal penyusunan, manakala tugasan kompaun (short = short
) berjaya. Artikel ini menjelaskan tingkah laku ini.
Mengapa short short
Keputusan dalam int
Jumlah dua short
integer secara tersirat dinaikkan pangkat kepada int
. Pilihan reka bentuk ini menghalang kemungkinan ralat limpahan. Limpahan berlaku apabila hasil operasi aritmetik melebihi nilai maksimum yang boleh diwakili oleh jenis data.
Pertimbangkan contoh ini:
<code class="language-csharp">short[] prices = { 10000, 15000, 11000 }; short average = (prices[0] + prices[1] + prices[2]) / 3; // Compile-time error</code>
Tanpa promosi tersirat kepada int
, penambahan akan melimpah, membawa kepada average
yang tidak tepat.
Pelakon Tersirat =
Operator
Pengendali =
berbeza daripada tugasan langsung. Spesifikasi bahasa C# menentukan bahawa pengendali penugasan kompaun melakukan hantaran tersirat kepada jenis operan sebelah kiri.
Untuk a = b
, di mana a
dan b
adalah short
, pengkompil secara berkesan menterjemahkannya kepada:
<code class="language-csharp">a = (short)(a + b);</code>
Pelakon tersirat ini mengendalikan potensi limpahan dengan memangkas hasil int
kembali kepada short
. Ambil perhatian bahawa pemangkasan ini boleh membawa kepada kehilangan data jika jumlahnya melebihi julat short
.
Ringkasnya
Tambahan dua nilai short
menghasilkan int
untuk mengelakkan limpahan. Pelakon tersirat pengendali =
membenarkan kod ringkas sambil mengurangkan, tetapi tidak menghapuskan, risiko kehilangan data akibat potensi limpahan semasa operasi. Ini memberikan fleksibiliti, membolehkan pengiraan yang sebaliknya akan mengakibatkan ralat penyusunan.
Atas ialah kandungan terperinci Mengapa C# Membenarkan `short = short` Tetapi Tidak `short = short short`?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!