_malloca
Yığın bellek ayırır. Bu sürümü, _alloca açıklandığı gibi güvenlik geliştirmeleri ile crt güvenlik özellikleri.
void *_malloca(
size_t size
);
Parametreler
- size
Yığından ayrılacak bayt.
Dönüş Değeri
_malloca Rutin döndürür bir void herhangi bir nesne türünü depolanması için yeterince hizalanacağı garanti ayrılan alanı işaretçisi. size 0, _malloca Sıfır uzunluklu öğeyi ayırır ve bu madde için geçerli bir işaretçi döndürür.
Bir yığın taşması özel alanı tahsis oluşturulur. Yığın taşması özel bir C++ özel değildir; Bu yapısal bir istisnadır. C++ özel durum işleme kullanmak yerine, kullanmanız gereken Yapılandırılmış özel durum işleme (seh).
Notlar
_mallocaayırdığı size bayt program yığın veya isteği tarafından verilen bayt cinsinden belirli bir boyutu aşarsa öbek _ALLOCA_S_THRESHOLD. Arasındaki fark _malloca ve _alloca olan _alloca yığında boyutu ne olursa olsun her zaman ayırır. Aksine _alloca, hangi gerektirmez veya çağrı izin free bu nedenle ayrılan belleği serbest bırakmak için _malloca kullanılmasını gerektirir _freea bellek boşaltmak için. Hata ayıklama modunda _malloca her zaman öbekten bellek ayırır.
Açıkça çağırmak için kısıtlamalar vardır _malloca , bir özel durum işleyici (eh). X çalışan eh düzenleri 86 sınıfı işlemciler kendi bellek çerçevesinde çalışması: görevlerini kapsayan işlevinin yığın işaretçisi geçerli konumuna dayalı olmayan bellek alanında gerçekleştirdikleri. En yaygın uygulamaları Windows NT yapılandırılmış özel durum işleme (seh) ve C++ catch yan tümcesi deyimleri içerir. Bu nedenle, açıkça çağırmak _malloca herhangi bir program hatası return to eh yordamı çağrılırken sırasında aşağıdaki senaryolar sonuçları:
Windows NT seh özel filtre ifadesi: __except (_malloca () )
Windows NT seh son özel durum işleyici: __finally {_malloca () }
C++ eh catch yan tümcesi deyimi
Ancak, _malloca doğrudan eh yordamı içinde veya çağrılan bir uygulama tarafından sağlanan geri yukarıda listelenen eh senaryolardan biri tarafından çağrılabilir.
Güvenlik Notu |
---|
Windows XP'de, _malloca olarak adlandırılan bir try/catch bloğu içinde çağırması gerekir _resetstkoflw catch bloğu içinde. |
Yukarıdaki sınırlamalar kullanırken, ek olarak /clr (ortak dil çalışma zamanı derleme) seçeneği, _malloca kullanılamaz __except engeller. Daha fazla bilgi için bkz: /clr kısıtlamaları.
Gereksinimler
Yordamı |
Gerekli başlık |
---|---|
_malloca |
<malloc.h> |
Örnek
// crt_malloca_simple.c
#include <stdio.h>
#include <malloc.h>
void Fn()
{
char * buf = (char *)_malloca( 100 );
// do something with buf
_freea( buf );
}
int main()
{
Fn();
}
// crt_malloca_exception.c
// This program demonstrates the use of
// _malloca and trapping any exceptions
// that may occur.
#include <windows.h>
#include <stdio.h>
#include <malloc.h>
int main()
{
int size;
int numberRead = 0;
int errcode = 0;
void *p = NULL;
void *pMarker = NULL;
while (numberRead == 0)
{
printf_s("Enter the number of bytes to allocate "
"using _malloca: ");
numberRead = scanf_s("%d", &size);
}
// Do not use try/catch for _malloca,
// use __try/__except, since _malloca throws
// Structured Exceptions, not C++ exceptions.
__try
{
if (size > 0)
{
p = _malloca( size );
}
else
{
printf_s("Size must be a positive number.");
}
_freea( p );
}
// Catch any exceptions that may occur.
__except( GetExceptionCode() == STATUS_STACK_OVERFLOW )
{
printf_s("_malloca failed!\n");
// If the stack overflows, use this function to restore.
errcode = _resetstkoflw();
if (errcode)
{
printf("Could not reset the stack!");
_exit(1);
}
};
}
Girdi
1000
Örnek Çıktı
Enter the number of bytes to allocate using _malloca: 1000
.NET Framework Eşdeğeri
Yoktur. Standart c işlevi çağırmak için kullanmak PInvoke. Daha fazla bilgi için bkz: Platform Çağırma örnekleri.