Funzione GetPrivateProfileStringA (winbase.h)
Recupera una stringa dalla sezione specificata in un file di inizializzazione.
Sintassi
DWORD GetPrivateProfileStringA(
[in] LPCSTR lpAppName,
[in] LPCSTR lpKeyName,
[in] LPCSTR lpDefault,
[out] LPSTR lpReturnedString,
[in] DWORD nSize,
[in] LPCSTR lpFileName
);
Parametri
[in] lpAppName
Nome della sezione contenente il nome della chiave. Se questo parametro è NULL, la funzione GetPrivateProfileString copia tutti i nomi di sezione nel file nel buffer fornito.
[in] lpKeyName
Nome della chiave la cui stringa associata deve essere recuperata. Se questo parametro è
[in] lpDefault
Stringa predefinita. Se non è possibile trovare la chiave lpKeyName
Se questo parametro è NULL, il valore predefinito è una stringa vuota, "".
Evitare di specificare una stringa predefinita con caratteri vuoti finali. La funzione inserisce un carattere null nel buffer lpReturnedString per rimuovere eventuali spazi vuoti finali.
[out] lpReturnedString
Puntatore al buffer che riceve la stringa recuperata.
[in] nSize
Dimensioni del buffer a cui punta il parametro lpReturnedString, in caratteri.
[in] lpFileName
Nome del file di inizializzazione. Se questo parametro non contiene un percorso completo del file, il sistema cerca il file nella directory di Windows.
Valore restituito
Il valore restituito è il numero di caratteri copiati nel buffer, senza includere il carattere di terminazione null.
Se né
Se lpAppName o lpKeyName è NULL e il buffer di destinazione fornito è troppo piccolo per contenere tutte le stringhe, l'ultima stringa viene troncata e seguita da due caratteri null. In questo caso, il valore restituito è uguale a nSize meno due.
Se il file di inizializzazione specificato da lpFileName non viene trovato o contiene valori non validi, questa funzione imposta errorno con il valore '0x2' (File Non trovato). Per recuperare informazioni sull'errore estese, chiamare GetLastError.
Osservazioni
La funzione GetPrivateProfileString
[section]
key=string
.
.
.
Se lpAppName è NULL, GetPrivateProfileString copia tutti i nomi di sezione nel file specificato nel buffer fornito. Se lpKeyName è NULL, la funzione copia tutti i nomi di chiave nella sezione specificata nel buffer fornito. Un'applicazione può usare questo metodo per enumerare tutte le sezioni e le chiavi in un file. In entrambi i casi, ogni stringa è seguita da un carattere null e la stringa finale è seguita da un secondo carattere null. Se il buffer di destinazione fornito è troppo piccolo per contenere tutte le stringhe, l'ultima stringa viene troncata e seguita da due caratteri null.
Se la stringa associata a lpKeyName è racchiusa tra virgolette singole o doppie, i segni vengono eliminati quando la funzione GetPrivateProfileString recupera la stringa.
La funzione GetPrivateProfileString
Per recuperare una stringa dal file Win.ini, usare la funzione GetProfileString
Il sistema esegue il mapping della maggior parte dei riferimenti di file .ini al Registro di sistema usando il mapping definito nella chiave del Registro di sistema seguente:HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion\IniFileMapping
Questo mapping è probabile se un'applicazione modifica i file di inizializzazione dei componenti di sistema, ad esempio Control.ini, System.inie Winfile.ini. In questi casi, la funzione recupera le informazioni dal Registro di sistema, non dal file di inizializzazione; la modifica nella posizione di archiviazione non ha alcun effetto sul comportamento della funzione.
Le funzioni del profilo usano i passaggi seguenti per individuare le informazioni di inizializzazione:
- Cercare nel Registro di sistema il nome del file di inizializzazione nella chiave IniFileMapping.
- Cercare il nome della sezione specificato da lpAppName. Si tratta di un valore denominato nella chiave con il nome del file di inizializzazione o di una sottochiave con questo nome oppure il nome non esisterà come valore o sottochiave.
- Se il nome della sezione specificato da lpAppName è un valore denominato, tale valore specifica dove nel Registro di sistema troverai le chiavi per la sezione.
- Se il nome della sezione specificato da lpAppName è una sottochiave, i valori denominati in tale sottochiave specificano dove nel Registro di sistema si troveranno le chiavi per la sezione. Se la chiave che si sta cercando non esiste come valore denominato, sarà presente un valore senza nome (visualizzato come <Nessun nome>) che specifica il percorso predefinito nel Registro di sistema in cui si trova la chiave.
- Se il nome della sezione specificato da lpAppName non esiste come valore denominato o come sottochiave, sarà presente un valore senza nome (visualizzato come <Nessun nome>) che specifica il percorso predefinito nel Registro di sistema in cui si troveranno le chiavi per la sezione.
- Se non è presente alcuna sottochiave o voce per il nome della sezione, cercare il file di inizializzazione effettivo sul disco e leggerne il contenuto.
- ! : questo carattere forza tutte le scritture a passare sia al Registro di sistema che al file .ini su disco.
- # : questo carattere fa sì che il valore del Registro di sistema venga impostato sul valore nel file di Windows 3.1 .ini quando un nuovo utente accede per la prima volta dopo l'installazione.
- @ - Questo carattere impedisce alle letture di passare al file .ini su disco se i dati richiesti non vengono trovati nel Registro di sistema.
- USR: questo prefisso è l'acronimo di HKEY_CURRENT_USERe il testo dopo il prefisso è relativo a tale chiave.
- SYS: questo prefisso è l'acronimo di HKEY_LOCAL_MACHINE\SOFTWAREe il testo dopo il prefisso è relativo a tale chiave.
Esempio
Nell'esempio seguente viene illustrato l'uso di GetPrivateProfileString.
// Gets a profile string called "Preferred line" and converts it to an int.
GetPrivateProfileString (
"Preference",
"Preferred Line",
gszNULL,
szBuffer,
MAXBUFSIZE,
gszINIfilename
);
// if szBuffer is not empty.
if ( lstrcmp ( gszNULL, szBuffer ) )
{
dwPreferredPLID = (DWORD) atoi( szBuffer );
}
else
{
dwPreferredPLID = (DWORD) -1;
}
Nota
L'intestazione winbase.h definisce GetPrivateProfileString come alias che seleziona automaticamente la versione ANSI o Unicode di questa funzione in base alla definizione della costante del preprocessore UNICODE. La combinazione dell'utilizzo dell'alias indipendente dalla codifica con il codice non indipendente dalla codifica può causare mancate corrispondenze che generano errori di compilazione o di runtime. Per altre informazioni, vedere convenzioni di per i prototipi di funzioni.
Fabbisogno
Requisito | Valore |
---|---|
client minimo supportato | Windows 2000 Professional [solo app desktop] |
server minimo supportato | Windows 2000 Server [solo app desktop] |
piattaforma di destinazione | Finestre |
intestazione |
winbase.h (include Windows.h) |
libreria |
Kernel32.lib |
dll | Kernel32.dll |