_aligned_realloc_dbg

Mengubah ukuran blok memori yang dialokasikan dengan _aligned_malloc atau _aligned_offset_malloc (hanya versi debug).

Sintaks

void * _aligned_realloc_dbg(
   void *memblock,
   size_t size,
   size_t alignment,
   const char *filename,
   int linenumber
);

Parameter

memblock
Penunjuk blok memori saat ini.

size
Ukuran alokasi memori yang diminta.

alignment
Nilai perataan, yang harus berupa kekuatan bilangan bulat 2.

filename
Penunjuk ke nama file sumber yang meminta realloc operasi atau NULL.

linenumber
Nomor baris dalam file sumber tempat realloc operasi diminta atau NULL.

Nilai hasil

_aligned_realloc_dbg mengembalikan penunjuk ke blok memori yang dialokasikan (dan mungkin dipindahkan). Nilai yang dikembalikan adalah NULL jika ukurannya nol dan argumen buffer tidak NULL, atau jika tidak ada cukup memori yang tersedia untuk memperluas blok ke ukuran yang diberikan. Dalam kasus pertama, blok asli dibeberkan. Di yang kedua, blok asli tidak berubah. Nilai pengembalian menunjuk ke ruang penyimpanan yang cocok diselaraskan untuk penyimpanan jenis objek apa pun. Untuk mendapatkan pointer ke jenis selain void, gunakan jenis cast pada nilai yang dikembalikan.

Ini adalah kesalahan untuk merealokasi memori dan mengubah perataan blok.

Keterangan

_aligned_realloc_dbg adalah versi debug dari _aligned_realloc fungsi. Ketika _DEBUG tidak ditentukan, setiap panggilan ke _aligned_realloc_dbg dikurangi menjadi panggilan ke _aligned_realloc. Baik _aligned_realloc dan _aligned_realloc_dbg realokasi blok memori di tumpukan dasar, tetapi _aligned_realloc_dbg mengakomodasi beberapa fitur debugging: buffer di salah satu sisi bagian pengguna blok untuk menguji kebocoran, dan filename/linenumber informasi untuk menentukan asal permintaan alokasi. Melacak jenis alokasi tertentu dengan parameter jenis blok bukan fitur debug yang didukung untuk alokasi yang selaras. Alokasi yang diratakan akan muncul sebagai _NORMAL_BLOCK jenis blok.

_aligned_realloc_dbg merealokasi blok memori yang ditentukan dengan sedikit lebih banyak ruang daripada yang diminta newSize. newSize mungkin lebih besar atau kurang dari ukuran blok memori yang dialokasikan awalnya. Ruang ekstra digunakan oleh manajer timbunan debug untuk menautkan blok memori debug dan untuk menyediakan aplikasi dengan informasi header debug dan menimpa buffer. Realokasi mungkin memindahkan blok memori asli ke lokasi yang berbeda di tumpukan, dan mengubah ukuran blok memori. Jika blok memori dipindahkan, konten blok asli akan ditimpa.

_aligned_realloc_dbgerrno diatur ke ENOMEM jika alokasi memori gagal atau jika jumlah memori yang diperlukan (termasuk overhead yang disebutkan sebelumnya) melebihi _HEAP_MAXREQ. Untuk informasi tentang ini dan kode kesalahan lainnya, lihat errno, , _doserrno_sys_errlist, dan _sys_nerr.

Selain itu, _aligned_realloc_dbg memvalidasi parameternya. Jika alignment bukan kekuatan 2, fungsi ini memanggil handler parameter yang tidak valid, seperti yang dijelaskan dalam Validasi parameter. Jika eksekusi diizinkan untuk melanjutkan, fungsi ini mengembalikan NULL dan mengatur errno ke EINVAL.

Untuk informasi tentang bagaimana blok memori dialokasikan, diinisialisasi, dan dikelola dalam versi debug timbunan dasar, lihat detail timbunan debug CRT. Untuk informasi tentang jenis blok alokasi dan cara penggunaannya, lihat Jenis blok pada tumpukan debug. Untuk informasi tentang perbedaan antara fungsi timbunan standar dan versi debugnya, lihat Versi debug fungsi alokasi timbunan.

Persyaratan

Rutin Header yang diperlukan
_aligned_realloc_dbg <crtdbg.h>

Untuk informasi kompatibilitas selengkapnya, lihat Kompatibilitas.

Pustaka

Debug versi pustaka run-time C saja.

Baca juga

Rutinitas debug