Funzione DeleteFile (winbase.h)
Elimina un file esistente.
Per eseguire questa operazione come operazione transazionata, usare la funzione DeleteFileTransacted .
Sintassi
BOOL DeleteFile(
[in] LPCTSTR lpFileName
);
Parametri
[in] lpFileName
Nome del file da eliminare.
Per impostazione predefinita, il nome è limitato a MAX_PATH caratteri. Per estendere questo limite a 32.767 caratteri wide, prependo "\\?\" al percorso. Per altre informazioni, vedere Denominazione di file, percorsi e spazi dei nomi.
Suggerimento
A partire da Windows 10, versione 1607, è possibile scegliere di rimuovere la limitazione MAX_PATH senza pre sospeso "\\?\". Per informazioni dettagliate, vedere la sezione "Limitazione massima lunghezza percorso" di nomi, nomi, percorsi e spazi dei nomi .
Valore restituito
Se la funzione ha esito positivo, il valore restituito è diverso da zero.
Se la funzione ha esito negativo, il valore restituito è zero (0). Per informazioni dettagliate sull'errore, chiamare GetLastError.
Commenti
Se un'applicazione tenta di eliminare un file che non esiste, la funzione DeleteFile non riesce con ERROR_FILE_NOT_FOUND. Se il file è un file di sola lettura, la funzione ha esito negativo con ERROR_ACCESS_DENIED.
L'elenco seguente identifica alcuni suggerimenti per l'eliminazione, la rimozione o la chiusura di file:
- Per eliminare un file di sola lettura, è prima necessario rimuovere l'attributo di sola lettura.
- Per eliminare o rinominare un file, è necessario disporre dell'autorizzazione di eliminazione per il file o eliminare l'autorizzazione figlio nella directory padre.
- Per eliminare in modo ricorsivo i file in una directory, usare la funzione SHFileOperation .
- Per rimuovere una directory vuota, usare la funzione RemoveDirectory .
- Per chiudere un file aperto, usare la funzione CloseHandle .
Se si richiede l'autorizzazione di eliminazione al momento della creazione di un file, è possibile eliminare o rinominare il file con tale handle, ma non con alcun altro handle. Per altre informazioni, vedere Sicurezza file e diritti di accesso.
La funzione DeleteFile non riesce se un'applicazione tenta di eliminare un file con altri handle aperti per la normale I/O o come file mappato alla memoria (FILE_SHARE_DELETE deve essere stato specificato quando sono stati aperti altri handle).
La funzione DeleteFile contrassegna un file per l'eliminazione in chiusura. Pertanto, l'eliminazione del file non viene eseguita fino all'ultimo handle del file chiuso. Le chiamate successive a CreateFile per aprire il file non riescono con ERROR_ACCESS_DENIED.
Comportamento di collegamento simbolico:
Se il percorso punta a un collegamento simbolico, il collegamento simbolico viene eliminato, non la destinazione. Per eliminare una destinazione, è necessario chiamare CreateFile e specificare FILE_FLAG_DELETE_ON_CLOSE.
In Windows 8 e Windows Server 2012 questa funzione è supportata dalle tecnologie seguenti.
Tecnologia | Supportato |
---|---|
Protocollo SMB (Server Message Block) 3.0 | Sì |
Failover trasparente SMB 3.0 (TFO) | Sì |
SMB 3.0 con condivisioni file con scalabilità orizzontale (SO) | Sì |
File system del volume condiviso del cluster (CsvFS) | Sì |
File system resiliente (ReFS) | Sì |
Esempi
Per un esempio, vedere Blocco e sblocco degli intervalli di byte in File.
Requisiti
Requisito | Valore |
---|---|
Client minimo supportato | Windows XP [app desktop | App UWP] |
Server minimo supportato | Windows Server 2003 [app desktop | App UWP] |
Piattaforma di destinazione | Windows |
Intestazione | winbase.h (include Windows.h) |
Libreria | Kernel32.lib |
DLL | Kernel32.dll |