CreateStreamOnHGlobal

Returns an OLE-provided implementation of the IStream interface with the stream object stored in global memory.

HRESULT CreateStreamOnHGlobal(

HGLOBAL hGlobal,
//Memory handle for the stream object
BOOL fDeleteOnRelease,
//Indicates whether to free memory when the object is released
LPSTREAM * ppstm
//Points to location for pointer to the new stream object
);

Parameters

hGlobal

Contains the memory handle allocated by the GlobalAlloc function. The handle must be allocated as moveable and nondiscardable. If the handle is to be shared between processes, it must also be allocated as shared. New handles should be allocated with a size of zero. If hGlobal is NULL, the CreateStreamOnHGlobal function internally allocates a new shared memory block of size zero.

fDeleteOnRelease

Indicates whether the underlying handle for this stream object should be automatically freed when the stream object is released.

ppstm

Points to the location where this method places a pointer to the new stream object, that is, the new IStream instance. It cannot be NULL.

Return Values

S_OK

Indicates the stream object was created successfully.

E_OUTOFMEMORY

Indicates the stream could not be created due to lack of memory.

E_INVALIDARG

Indicates invalid value for one of the parameters.

Comments

This function creates a stream object in memory using the OLE-provided implementation of the IStream interface. The returned stream object supports both reading and writing, is not transacted, and does not support locking.

The initial contents of the stream are the current contents of the memory block provided in the hGlobal parameter. If the hGlobal paramter is NULL, this function internally allocates memory.

The current contents of the memory block are undisturbed by the creation of the new stream object. Thus, you can use this function to open an existing stream in memory.

The initial size of the stream is the size of the memory handle returned by the Win32 GlobalSize function. Because of rounding, this is not necessarily the same size that was originally allocated for the handle. If the logical size of the stream is important, you should follow the call to this function with a call to the IStream::SetSize method.

See Also

CreateStreamOnHGlobal, IStream::SetSize

GlobalSize
in Win32

Software for developers
Delphi Components
.Net Components
Software for Android Developers
More information resources
MegaDetailed.Net
Unix Manual Pages
Delphi Examples
Databases for Amazon shops developers
Amazon Categories Database
Browse Nodes Database