Perbezaan Saiz Aksara dalam C dan C
Dalam kedua-dua C dan C , operator saiz menyediakan maklumat tentang saiz jenis data atau pembolehubah. Dengan memeriksa output program menggunakan operator ini, pengaturcara boleh mempelajari butiran penting tentang data yang mereka gunakan. Walau bagaimanapun, secara mengejutkan, saiz pengendali menghasilkan hasil yang berbeza apabila digunakan pada nilai aksara antara C dan C .
Pertimbangkan program C berikut:
#include <stdio.h> int main(void) { printf("sizeof(char) = %zu\n", sizeof(char)); printf("sizeof('a') = %zu\n", sizeof('a')); }
Setelah dilaksanakan, atur cara ini akan mencetak:
sizeof(char) = 1 sizeof('a') = 4
Sekarang, mari kita lihat program yang sama yang ditulis dalam C :
#include <iostream> int main() { std::cout << "sizeof(char) = " << sizeof(char) << std::endl; std::cout << "sizeof('a') = " << sizeof('a') << std::endl; }
Apabila dijalankan dalam C , ia mengeluarkan:
sizeof(char) = 1 sizeof('a') = 1
Perbezaan utama terletak pada cara C dan C mewakili pemalar aksara secara dalaman. Dalam C, pemalar aksara seperti 'a' dianggap sebagai integer dengan nilai ASCII yang sepadan. Inilah sebabnya sizeof('a') mengembalikan 4 dalam C, kerana saiz integer biasanya 4 bait. Sebaliknya, dalam C , pemalar aksara dianggap sebagai jenis data aksara, yang mempunyai saiz 1 bait.
Atas ialah kandungan terperinci Mengapakah `sizeof('a')` Berbeza Antara C dan C ?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!