|
Overview |
|
|
|
Group |
|
|
|
Quick Info
Windows NT
| Yes
| Win95
| Yes
| Win32s
| No
| Import Library
| kernel32.lib
| Header File
| winbase.h
| Unicode
| No
| Platform Notes
| Windows 95: Only on serial and IOCTL devices
|
|
|
GetOverlappedResult
The GetOverlappedResult function returns the results of an overlapped operation on the specified
file, named pipe, or communications device.
Windows 95: This function works only on serial devices or on files opened by using the DeviceIoControl function.
BOOL GetOverlappedResult(
HANDLE hFile,
| // handle of file, pipe, or communications device
| LPOVERLAPPED lpOverlapped,
| // address of overlapped structure
| LPDWORD lpNumberOfBytesTransferred,
| // address of actual bytes count
| BOOL bWait
| // wait flag
| );
|
|
Parameters
hFile
Identifies the file, named pipe, or communications device. This is the same
handle that was specified when the overlapped operation was started by a call to
the ReadFile, WriteFile, ConnectNamedPipe, TransactNamedPipe, DeviceIoControl, or WaitCommEvent function.
lpOverlapped
Points to an OVERLAPPED structure that was specified when the overlapped operation was started.
lpNumberOfBytesTransferred
Points to a 32-bit variable that receives the number of bytes that were
actually transferred by a read or write operation. For a TransactNamedPipe operation, this is the number of bytes that were read from the pipe. For a DeviceIoControl operation, this is the number of bytes of output data returned by the device
driver. For a ConnectNamedPipe or WaitCommEvent operation, this value is undefined.
bWait
Specifies whether the function should wait for the pending overlapped
operation to be completed. If TRUE, the function does not return until the operation
has been completed. If FALSE and the operation is still pending, the function
returns FALSE and the GetLastError function returns ERROR_IO_INCOMPLETE.
Return Values
If the function succeeds, the return value is nonzero.
If the function fails, the return value is zero. To get extended error
information, call GetLastError.
Remarks
The results reported by the GetOverlappedResult function are those of the specified handle's last overlapped operation to
which the specified OVERLAPPED structure was provided, and for which the operation's results were pending. A
pending operation is indicated when the function that started the operation
returns FALSE, and the GetLastError function returns ERROR_IO_PENDING. When an I/O operation is pending, the
function that started the operation resets the hEvent member of the OVERLAPPED structure to the nonsignaled state. Then when the pending operation has been
completed, the system sets the event object to the signaled state.
If the bWait parameter is TRUE, GetOverlappedResult determines whether the pending operation has been completed by waiting for
the event object to be in the signaled state.
If the hEvent member of the OVERLAPPED structure is NULL, the system uses the state of the hFile handle to signal when the operation has been completed. Use of file, named
pipe, or communications-device handles for this purpose is discouraged. It is
safer to use an event object because of the confusion that can occur when multiple
simultaneous overlapped operations are performed on the same file, named pipe,
or communications device. In this situation, there is no way to know which
operation caused the object's state to be signaled.
Specify a manual-reset event object in the OVERLAPPED structure. If an auto-reset event object is used, the event handle must not
be specified in any other wait operation in the interval between starting the
overlapped operation and the call to GetOverlappedResult. For example, the event object is sometimes specified in one of the wait
functions to wait for the operation's completion. When the wait function returns,
the system sets an auto-reset event's state to nonsignaled, and a subsequent
call to GetOverlappedResult with the bWait parameter set to TRUE causes the function to be blocked indefinitely.
See Also
CancelIo, ConnectNamedPipe, CreateEvent, DeviceIoControl, GetLastError, OVERLAPPED, ReadFile, TransactNamedPipe, WaitCommEvent, WriteFile
| Last news from Greatis Software |
 |
|
Nostalgia .Net |
|
.Net is powerful, but not all-powerful, so sometimes we need to use Win32 API for our .Net applications. It's simple enough with Platform Invoke if you have Win32 skill, but we do not always have time to dig the ancient documentation, declare the special types that are compatible with Win32, find the values of the Win32's constants and so on. Nostalgia .Net offers several simple-to-use classes, and components that will allow you to forget about the headache of Win32 and just use the power of Win32 in your application the same way as you use the native. Net classes. More » |
| Recommended software for developers |
 |
|
Ultimate Pack |
|
Component pack for Delphi and C++ Builder that contains runtime form designer, runtime object inspector, print suite and much more for the very special price. More » |
 |
|
Form Designer .Net |
|
Unique runtime form design solution that allows to edit any form in .Net WinForms application at runtime without manual coding. Full C# source codes are available More » |
 |
|
Print Suite .Net |
|
Print Suite .Net is a set of components for easy printing texts, images and grids from your WinForms applications. Full C# source codes are available More » |
 |
|
Gradient Controls .Net |
|
Gradient Controls .Net offers controls with gradient background feature. Labels, panels and so on... Full C# source codes are available More » |
 |
|
Greatis iGrid |
|
iGrid plots drawing grid right over your desktop, so you can use it everywhere, with any drawing application without any special plugins for different graphic editors. More » |
Related LinksSoftware for Visual Studio .NET developers Software for Delphi and C++ Builder developers Software for Visual Basic 6 developers Delphi Tips&Tricks MegaDetailed.NET More Online Helps Win32 Programmer's Reference Win32 Multimedia Programmer's Reference OLE Programmer's Reference Microsoft Windows Pen API Programmer's Reference Microsoft Windows Sockets 2 Reference Microsoft Windows Telephony API (TAPI) Programmer's Reference Unix Manual Pages
|