Aritmetik Titik Terapung: Associativity in Question
Apabila ia melibatkan operasi matematik, associativity menentukan bahawa susunan operan tidak mempengaruhi hasil. Walau bagaimanapun, dalam bidang aritmetik titik terapung, persekutuan tidak selalunya berlaku. Ini boleh membawa kepada hasil yang tidak dijangka, seperti yang digambarkan oleh isu biasa yang dihadapi oleh pengaturcara.
Pertimbangkan contoh ini:
cout << ((0.7 + 0.2 + 0.1) == 1) << endl; // Output: 0 cout << ((0.7 + 0.1 + 0.2) == 1) << endl; // Output: 1
Membingungkan, perbandingan terhadap 1 menghasilkan hasil yang berbeza bergantung pada susunan dalam yang mana nilai titik terapung ditambah. Mengapa ini berlaku?
Sifat Tidak Bersekutu Penambahan Titik Terapung
Penyebab di sebalik tingkah laku ini terletak pada sifat aritmetik titik terapung itu sendiri. Nombor titik terapung diwakili menggunakan bilangan bit terhingga, yang memperkenalkan ralat pusingan apabila operasi dilakukan. Ketaktepatan ini boleh nyata dalam penyimpangan daripada undang-undang persekutuan yang dijangkakan.
Seperti yang dijelaskan dalam kertas berwibawa "Apa Setiap Saintis Komputer Patut Tahu tentang Aritmetik Titik Terapung," peraturan praktikal berikut terpakai:
Contoh:
If x = 1e30, y = -1e30, and z = 1, then: (x + y) + z = 1 x + (y + z) = 0
Implikasi untuk Pengaturcara
Memahami bukan kaitan penambahan titik terapung adalah penting untuk pengaturcaraan yang tepat. Untuk mengelakkan hasil yang tidak dijangka, pengaturcara harus mematuhi garis panduan berikut:
Dengan mematuhi ini garis panduan, pengaturcara boleh mengurangkan kesan pengehadan persekutuan dalam aritmetik titik terapung dan memastikan tingkah laku program yang tepat dan boleh diramal.
Atas ialah kandungan terperinci Mengapa Penambahan Titik Terapung Tidak Sentiasa Mengikut Undang-undang Bersekutu?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!