Compartir a través de


Función StgCreateStorageEx (coml2api.h)

La función stgCreateStorageEx crea un nuevo objeto de almacenamiento mediante una implementación proporcionada para la IStorage o interfaces de IPropertySetStorage. Para abrir un archivo existente, use la función StgOpenStorageEx en su lugar.

Las aplicaciones escritas para Windows 2000, Windows Server 2003 y Windows XP deben usar StgCreateStorageEx en lugar de StgCreateDocfile para aprovechar las características mejoradas de Almacenamiento estructurado de Windows 2000 y Windows XP.

Sintaxis

HRESULT StgCreateStorageEx(
  [in]  const WCHAR          *pwcsName,
  [in]  DWORD                grfMode,
  [in]  DWORD                stgfmt,
  [in]  DWORD                grfAttrs,
  [in]  STGOPTIONS           *pStgOptions,
  [in]  PSECURITY_DESCRIPTOR pSecurityDescriptor,
  [in]  REFIID               riid,
  [out] void                 **ppObjectOpen
);

Parámetros

[in] pwcsName

Puntero a la ruta de acceso del archivo que se va a crear. Se pasa sin interpretación al sistema de archivos. Puede ser un nombre relativo o NULL. Si null, se asigna un archivo temporal con un nombre único. Si noNULL, el tamaño de cadena no debe superar MAX_PATH caracteres.

Windows 2000: A diferencia de la función CreateFile de , no se puede superar el límite de MAX_PATH mediante el prefijo "\?".

[in] grfMode

Valor que especifica el modo de acceso que se va a usar al abrir el nuevo objeto de almacenamiento. Para obtener más información, vea constantes STGM. Si el autor de la llamada especifica el modo de transacción junto con STGM_CREATE o STGM_CONVERT, se produce la sobrescritura o conversión cuando se llama a la operación de confirmación para el almacenamiento raíz. Si no se llama a IStorage::Commit para el objeto de almacenamiento raíz, se restaurará el contenido anterior del archivo. STGM_CREATE y STGM_CONVERT no se pueden combinar con la marca STGM_NOSNAPSHOT, ya que se requiere una copia de instantánea cuando se sobrescribe o se convierte un archivo en el modo transaccionado.

[in] stgfmt

Valor que especifica el formato de archivo de almacenamiento. Para obtener más información, consulte la enumeración STGFMT.

[in] grfAttrs

Valor que depende del valor del parámetro stgfmt stgfmt.

Valores de parámetro Significado
STGFMT_DOCFILE
0 o FILE_FLAG_NO_BUFFERING. Para obtener más información, vea CreateFile. Si el tamaño del sector del archivo, especificado en pStgOptions, no es un entero múltiplo del tamaño del sector físico del disco subyacente, se producirá un error en esta operación.
Todos los demás valores de stgfmt
Debe ser 0.

[in] pStgOptions

El parámetro pStgOptions solo es válido si el parámetro stgfmt está establecido en STGFMT_DOCFILE. Si el parámetro stgfmt se establece en STGFMT_DOCFILE, pStgOptions apunta a la estructura STGOPTIONS, que especifica las características del objeto de almacenamiento, como el tamaño del sector. Este parámetro puede ser NULL, que crea un objeto de almacenamiento con un tamaño de sector predeterminado de 512 bytes. Si nonull, el miembro ulSectorSize debe establecerse en 512 o 4096. Si se establece en 4096, es posible que no se especifique STGM_SIMPLE en el parámetro grfMode. El miembro usVersion debe establecerse antes de llamar a StgCreateStorageEx. Para obtener más información, vea STGOPTIONS.

[in] pSecurityDescriptor

Permite establecer las ACL cuando se crea el archivo. Si no NULL, debe ser un puntero a la estructura SECURITY_ATTRIBUTES. Consulte CreateFile para obtener información sobre cómo establecer ACL en archivos.

Windows Server 2003, Windows 2000 Server, Windows XP y Windows 2000 Professional: Value debe ser NULL.

[in] riid

Valor que especifica el identificador de interfaz (IID) del puntero de interfaz que se va a devolver. Este IID puede ser para la interfaz de IStorage o la interfaz IPropertySetStorage.

[out] ppObjectOpen

Puntero a una variable de puntero de interfaz que recibe un puntero para una interfaz en el nuevo objeto de almacenamiento; contiene NULL si se produjo un error en la operación.

Valor devuelto

Esta función también puede devolver cualquier error del sistema de archivos o errores del sistema ajustados en un HRESULT. Para obtener más información, vea estrategias de control de errores y control de errores desconocidos.

Observaciones

Cuando una aplicación modifica su archivo, normalmente crea una copia del original. La función StgCreateStorageEx es una manera de crear una copia. Esta función funciona indirectamente con la API de duplicación del sistema de archivos de cifrado (EFS). Al usar esta función, deberá establecer las opciones para el almacenamiento de archivos en la estructura de STGOPTIONS.

StgCreateStorageEx es un superconjunto de la función StgCreateDocfile y debe usarse con código nuevo. Las mejoras futuras en El almacenamiento estructurado se exponen a través de la función stgCreateStorageEx . Consulte la siguiente sección Requisitos para obtener información sobre las plataformas compatibles.

La función stgCreateStorageEx crea un nuevo objeto de almacenamiento mediante una de las implementaciones de almacenamiento estructuradas proporcionadas por el sistema. Esta función se puede usar para obtener una
implementación de archivos compuestos de IStorage, una implementación de archivo compuesto IPropertySetStorage, o para obtener una implementación DE NTFS IPropertySetStorage.

Cuando se crea un nuevo archivo, la implementación de almacenamiento usada depende de la marca que especifique y del tipo de unidad en la que se almacena el archivo. Para obtener más información, consulte la enumeración STGFMT.

StgCreateStorageEx crea el archivo si no existe. Si existe, el uso de las marcas STGM_CREATE, STGM_CONVERT y STGM_FAILIFTHERE en el parámetro grfMode indican cómo continuar. Para obtener más información sobre estos valores, vea constantes STGM. No es válido, en modo directo, especificar el modo STGM_READ en el parámetro grfMode (el modo directo se indica sin especificar la marca STGM_TRANSACTED). Esta función no se puede usar para abrir un archivo existente; Use la función StgOpenStorageEx.

Puede usar la función StgCreateStorageEx para obtener acceso al almacenamiento raíz de un documento de almacenamiento estructurado o al almacenamiento del conjunto de propiedades de cualquier archivo que admita conjuntos de propiedades. Consulte la documentación de stGFMT de para obtener información sobre qué IID se admiten para diferentes valores STGFMT.

Cuando se crea un archivo con esta función para acceder a la implementación del conjunto de propiedades NTFS, se aplican reglas de uso compartido especiales. Para obtener más información, vea IPropertySetStorage-NTFS Implementación.

Si se crea un archivo compuesto en modo de transacción (especificando STGM_TRANSACTED) y modo de solo lectura (especificando STGM_READ), es posible realizar cambios en el objeto de almacenamiento devuelto. Por ejemplo, es posible llamar a IStorage::CreateStream. Sin embargo, no es posible confirmar esos cambios llamando a IStorage::Commit. Por lo tanto, estos cambios se perderán.

Especificar STGM_SIMPLE proporciona una implementación mucho más rápida de un objeto de archivo compuesto en un caso limitado, pero frecuentemente usado que implica aplicaciones que requieren una implementación de archivo compuesta con varios flujos y sin almacenamientos. Para obtener más información, vea constantes STGM. No es válido especificar que STGM_TRANSACTED si se especifica STGM_SIMPLE.

El modo simple no admite todos los métodos de IStorage. En concreto, en modo simple, los métodos de IStorage admitidos son CreateStream, Commity SetClass así como los métodos COM IUnknown de QueryInterface, AddRef y Release. Además, SetElementTimes se admite con un nombre de NULL NULL, lo que permite a las aplicaciones establecer horas en un almacenamiento raíz. Todos los demás métodos de IStorage devuelven STG_E_INVALIDFUNCTION.

Si el parámetro grfMode especifica STGM_TRANSACTED y aún no existe ningún archivo con el nombre especificado por el parámetro pwcsName, el archivo se crea inmediatamente. En un sistema de archivos controlado por acceso, el autor de la llamada debe tener permisos de escritura para el directorio del sistema de archivos en el que se crea el archivo compuesto. Si no se especifica STGM_TRANSACTED y se especifica STGM_CREATE, se destruye un archivo existente con el mismo nombre antes de crear el nuevo archivo.

También puede usar StgCreateStorageEx para crear un archivo compuesto temporal pasando un valor de NULL para el parámetro pwcsName. Sin embargo, estos archivos solo son temporales en el sentido de que tienen un nombre único proporcionado por el sistema, uno que probablemente no tenga sentido para el usuario. El autor de la llamada es responsable de eliminar el archivo temporal cuando termine con él, a menos que se haya especificado STGM_DELETEONRELEASE para el parámetro grfMode. Para obtener más información sobre estas marcas, vea constantes STGM.

Requisitos

Requisito Valor
cliente mínimo admitido Windows 2000 Professional [aplicaciones de escritorio | Aplicaciones para UWP]
servidor mínimo admitido Windows 2000 Server [aplicaciones de escritorio | Aplicaciones para UWP]
de la plataforma de destino de Windows
encabezado de coml2api.h (include Objbase.h)
biblioteca de Ole32.lib
DLL de Ole32.dll

Consulte también

CreateFile

STGFMT

constantes STGM

STGOPTIONS

StgCreateDocFileOnILockBytes

stgCreateDocfile

StgOpenStorageEx