Compartir a través de


tmpfile

Crea un archivo temporal. Esta función está en desuso, ya que existe una versión más segura; consulte tmpfile_s.

Sintaxis

FILE *tmpfile( void );

Valor devuelto

Si se realiza correctamente, tmpfile devuelve un puntero de flujo. De lo contrario, devuelve un puntero NULL.

Comentarios

La función tmpfile crea un archivo temporal y devuelve un puntero a ese flujo. El archivo temporal se crea en el directorio raíz. Para crear un archivo temporal en un directorio distinto de la raíz, use tmpnam o tempnam con fopen.

Si el archivo no se puede abrir, tmpfile devuelve un NULL puntero. Este archivo temporal se elimina automáticamente cuando se cierra el archivo, cuando el programa finaliza normalmente o cuando _rmtmp se llama, suponiendo que el directorio de trabajo actual no cambie. El archivo temporal se abre en modo w+b (lectura y escritura de archivos binarios).

Se puede producir un error al intentar más de TMP_MAX llamadas (vea STDIO.H) con tmpfile.

Requisitos

Routine Encabezado necesario
tmpfile <stdio.h>

Para obtener más información sobre compatibilidad, consulte Compatibilidad.

Ejemplo

Nota:

Este ejemplo exige privilegios administrativos para ejecutarse en Windows Vista.

// crt_tmpfile.c
// compile with: /W3
// This program uses tmpfile to create a
// temporary file, then deletes this file with _rmtmp.
#include <stdio.h>

int main( void )
{
   FILE *stream;
   int  i;

   // Create temporary files.
   for( i = 1; i <= 3; i++ )
   {
      if( (stream = tmpfile()) == NULL ) // C4996
      // Note: tmpfile is deprecated; consider using tmpfile_s instead
         perror( "Could not open new temporary file\n" );
      else
         printf( "Temporary file %d was created\n", i );
   }

   // Remove temporary files.
   printf( "%d temporary files deleted\n", _rmtmp() );
}
Temporary file 1 was created
Temporary file 2 was created
Temporary file 3 was created
3 temporary files deleted

Consulte también

E/S de secuencia
_rmtmp
_tempnam, _wtempnam, , tmpnam, _wtmpnam