_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_dbg
errno
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.