Memahami Pembahagian Titik Terapung dalam C
Walaupun ditugaskan kepada pembolehubah berganda, pembahagian (3/5) menghasilkan sifar dalam yang disediakan kod kerana pembahagian integer. C menilai operan dalam ungkapan bahagi sebagai integer secara lalai. Memandangkan 3 dan 5 ialah kedua-dua nombor bulat, pembahagiannya menghasilkan hasil integer, iaitu sifar.
Untuk melakukan pembahagian titik terapung, di mana hasilnya mengekalkan ketepatan pecahan, sekurang-kurangnya satu operan hendaklah literal titik terapung . Ini memaksa pengkompil untuk menganggap pembahagian sebagai operasi titik terapung dan mengembalikan hasil titik terapung.
Dalam kod asal, untuk mencapai pembahagian titik terapung yang dimaksudkan, seseorang boleh mengubah suainya seperti berikut:
#include <iostream> int main(int argc, char** argv) { double f = 3.0 / 5; // Change both operands to floating-point literals std::cout << f; return 0; }
Dengan menjadikan satu operan (dalam kes ini, 3.0) literal titik terapung, pengkompil akan melakukan pembahagian titik terapung, dan hasilnya akan mencerminkan nilai pecahan dengan betul.
Atas ialah kandungan terperinci Mengapa Pembahagian Integer C Menghasilkan Sifar, dan Bagaimanakah Pembahagian Titik Terapung Boleh Dicapai?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!