Изменяет объем памяти, выделенной блоку памяти с дескриптором hand.
unsigned short _SetHandSize(MHANDLE hand, unsigned long size) MHANDLE hand; /* Дескриптор блока памяти. */ unsigned int size; /* Новое число байтов. */ |
Примечания
_SetHandSize( ) возвращает значение "истина" (целое число, отличное от 0), если процесс перераспределения памяти прошел успешно, или "ложь" (0) в противном случае. Данные, соответствующие блоку с дескриптором MHANDLE, сохраняются. Если блок памяти с дескриптором hand блокирован, _SetHandSize( ) завершается с ошибкой.
Для получения дополнительной информации о том, как создавать библиотеку API и интегрировать её в Visual FoxPro, смотрите Доступ к API Visual FoxPro.
Пример
В следующем примере _SetHandSize( ) изменяет объем памяти, выделенный блоку с дескриптором MHANDLE.
Код Visual FoxPro
Copy Code | |
---|---|
SET LIBRARY TO SETHANDS = HANDTOPTR("Hello, world.") && displays "Hello, world" on screen |
Код C
Copy Code | |
---|---|
#include <pro_ext.h> void NullTerminate(Value FAR *cVal) { if (!_SetHandSize(cVal->ev_handle, cVal->ev_length + 1)) { _Error(182); // "Insufficient memory" } ((char FAR *) _HandToPtr(cVal->ev_handle))[cVal->ev_length] = '\0'; } FAR Example(ParamBlk FAR *parm) { NullTerminate(&parm->p[0].val); _HLock(parm->p[0].val.ev_handle); _PutStr(_HandToPtr(parm->p[0].val.ev_handle)); _HUnLock(parm->p[0].val.ev_handle); } FoxInfo myFoxInfo[] = { {"HANDTOPTR", (FPFI) Example, 1, "C"}, }; FoxTable _FoxTable = { (FoxTable FAR *) 0, sizeof(myFoxInfo)/sizeof(FoxInfo), myFoxInfo }; |
Смотрите также
Справочное руководство
Процедура библиотеки API _AllocHand( )Процедура библиотеки API _FreeHand( )
Процедура библиотеки API _GetHandSize( )
Процедура библиотеки API _HandToPtr( )
Процедура библиотеки API _HLock( )
Процедура библиотеки API _HUnLock( )
Процедура библиотеки API _MemAvail( )
Прочие ресурсы
Конструкции библиотеки API© Microsoft Corporation. All rights reserved. Microsoft is not reponsible for the contents of the translated help topics.