Megosztás a következőn keresztül:


Rögzített puffer szerializálás

A rögzített pufferstílus használatakor adjon meg egy olyan puffert, amely elég nagy ahhoz, hogy elférjen a fogóponttal végrehajtott kódolási (rendezési) műveletek. A visszafejtés megszüntetésekor adja meg azt a puffert, amely az összes dekódolni kívánt adatot tartalmazza.

A szerializálás rögzített pufferstílusa a következő rutinokat használja:

A MesEncodeFixedBufferHandleCreate függvény lefoglalja a kódolási leíróhoz szükséges memóriát, majd inicializálja azt. Az alkalmazás meghívhatja MesBufferHandleReset a leíró újraincializálásához, vagy meghívhatja MesHandleFree a leíró memóriájának felszabadításához. A rögzített stíluskódoló fogópontnak megfelelő dekódoló fogópont létrehozásához MesDecodeBufferHandleCreatekell használnia.

Az alkalmazás meghívja MesHandleFree a kódolási vagy dekódolási pufferfogópont felszabadításához.

Példák rögzített pufferkódolásra

Az alábbi szakasz bemutatja, hogyan használható rögzített pufferstílusú szerializáló leíró az eljáráskódoláshoz.

/*This is a fragment of the IDL file defining MooProc */

...
void __RPC_USER
MyProc( [in] handle_t Handle, [in,out] MyType * pMyObject,
        [in, out] ThisType * pThisObject);
...

/*This is an ACF file. MyProc is defined in the IDL file */

[
    explicit_handle
]
interface regress
{
    [ encode,decode ] MyProc();
}

Az alábbi részlet egy alkalmazás egy részét jelöli.

if (MesEncodeFixedBufferHandleCreate (
        Buffer, BufferSize, 
        pEncodedSize, &Handle) == RPC_S_OK)
{
    ...
    /* Manufacture a MyObject and a ThisObject */
    ...
    /* The serialization works from the beginning of the buffer because 
   the handle is in the initial state. The function MyProc does the    
   following when called with an encoding handle:
     - sizes all the parameters for marshalling,
     - marshalls into the buffer (and sets the internal state 
    appropriately) 
    */

    MyProc ( Handle, pMyObject, pThisObject );
    ...
    MesHandleFree ();
}
if (MesDecodeBufferHandleCreate (Buffer, BufferSize, &Handle) ==
    RPC_S_OK)
{

    /* The MooProc does the following for you when called with a decoding 
    handle:
     - unmarshalls the objects from the buffer into *pMooObject and 
       *pBarObject
*/

MyProc ( Handle, pMyObject, pThisObject);
...
MesHandleFree ( Handle );
}

Az alábbi szakasz bemutatja, hogyan használható rögzített pufferstílusú szerializáló fogópont a típuskódoláshoz.

/* This is an ACF file. MyType is defined in the IDL file */

[    
    explicit_handle
]
interface regress
{
    typedef [ encode,decode ] MyType;
}

Az alábbi részlet a releváns alkalmazástöredékeket mutatja be.

if (MesEncodeFixedBufferHandleCreate (Buffer, BufferSize, 
    pEncodedSize, &Handle) == RPC_S_OK)
{
    //...
    /* Manufacture a MyObject and a pMyObject */
    //...
    MyType_Encode ( Handle, pMyObject );
    //...
    MesHandleFree ();
}
if (MesDecodeBufferHandleCreate (Buffer, BufferSize, &Handle) ==
    RPC_S_OK )
{
    MooType_Decode (Handle, pMooObject);
    //...
    MesHandleFree ( Handle );
}