Rumah >pembangunan bahagian belakang >C++ >Mengapakah `sizeof()` Mengembalikan Saiz Tatasusunan yang Salah Apabila Dihantar kepada Fungsi C?

Mengapakah `sizeof()` Mengembalikan Saiz Tatasusunan yang Salah Apabila Dihantar kepada Fungsi C?

Patricia Arquette
Patricia Arquetteasal
2025-01-01 10:41:11186semak imbas

Why Does `sizeof()` Return Incorrect Array Sizes When Passed to C Functions?

Memahami Percanggahan dalam Nilai sizeof() untuk Tatasusunan yang Dihantar kepada Fungsi dalam C

Dalam C, tatasusunan boleh mempamerkan tingkah laku yang tidak dijangka apabila diluluskan kepada fungsi. Timbul persoalan: mengapa operator sizeof() mengembalikan nilai yang salah apabila tatasusunan dihantar ke fungsi, sementara ia memberikan nilai yang betul sebelum panggilan fungsi?

Untuk menangani perkara ini, kita mesti memahami tatasusunan dalam C mengalami pereputan penunjuk apabila dihantar ke fungsi. Apabila tatasusunan diluluskan, ia merosot menjadi penuding yang menunjuk ke elemen pertama tatasusunan. Akibatnya, menggunakan sizeof() pada parameter fungsi menilai saiz penuding dan bukannya keseluruhan tatasusunan.

Contoh biasa diberikan dalam soalan:

#include <stdio.h>

void test(int arr[]) {
    int arrSize = (int)(sizeof(arr) / sizeof(arr[0]));
    printf("%d\n", arrSize); // 2 (wrong?!)
}

int main (int argc, const char * argv[]) {
    int point[3] = {50, 30, 12};

    int arrSize = (int)(sizeof(point) / sizeof(point[0]));
    printf("%d\n", arrSize); // 3 (correct :-) )

    test(point);

    return 0;
}

Dalam utama( ), saiz tatasusunan yang betul ditentukan dengan membahagikan saiz memori yang diperuntukkan (diperolehi menggunakan sizeof(point)) dengan saiz setiap elemen (saiz(titik[0])). Walau bagaimanapun, dalam fungsi test(), saiz tatasusunan yang dikira adalah tidak betul kerana sizeof(arr) mengembalikan saiz penuding kepada tatasusunan, bukan tatasusunan itu sendiri.

Untuk menyelesaikan isu ini dan membenarkan fungsi itu tentukan saiz tatasusunan, ia hendaklah diluluskan sebagai parameter berasingan:

void test(int arr[], size_t elems) {
   /* ... */
}

int main(int argc, const char * argv[]) {
   int point[3] = {50, 30, 12};
   /* ... */
   test(point, sizeof(point)/sizeof(point[0]));
   /* ... */
}

Adalah penting untuk ambil perhatian bahawa saiz(titik)/saiz(titik[0]) helah hanya berfungsi untuk tatasusunan yang diperuntukkan pada timbunan. Untuk tatasusunan yang diperuntukkan secara dinamik, ia akan mengembalikan hasil yang salah, kerana saiz tatasusunan tidak disimpan dengan penuding.

Atas ialah kandungan terperinci Mengapakah `sizeof()` Mengembalikan Saiz Tatasusunan yang Salah Apabila Dihantar kepada Fungsi C?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn