Condividi tramite


Funzione PathCombineA (shlwapi.h)

Concatena due stringhe che rappresentano percorsi correttamente formati in un unico percorso; concatena anche tutti gli elementi di percorso relativi.

Nota uso improprio di questa funzione può causare un sovraccarico del buffer. È consigliabile usare il PathCchCombine più sicuro o funzione PathCchCombineEx.
 

Sintassi

LPSTR PathCombineA(
  [out]          LPSTR  pszDest,
  [in, optional] LPCSTR pszDir,
  [in]           LPCSTR pszFile
);

Parametri

[out] pszDest

Tipo: LPTSTR

Puntatore a un buffer che, quando questa funzione viene restituita correttamente, riceve la stringa di percorso combinata. È necessario impostare le dimensioni di questo buffer su MAX_PATH per assicurarsi che sia sufficientemente grande da contenere la stringa restituita.

[in, optional] pszDir

Tipo: LPCTSTR

Puntatore a una stringa con terminazione Null di lunghezza massima MAX_PATH che contiene il primo percorso. Questo valore può essere NULL.

[in] pszFile

Tipo: LPCTSTR

Puntatore a una stringa con terminazione Null di lunghezza massima MAX_PATH che contiene il secondo percorso. Questo valore può essere NULL.

Valore restituito

Tipo: LPTSTR

Puntatore a un buffer che, quando questa funzione viene restituita correttamente, riceve la stringa di percorso concatenata. Si tratta della stessa stringa a cui punta pszPathOut. Se questa funzione non restituisce correttamente, questo valore viene NULL.

Osservazioni

Il percorso della directory deve essere nel formato A:,B:, ..., Z:. Il percorso del file deve essere in un formato corretto che rappresenta la parte del nome file del percorso. Se il percorso della directory termina con una barra rovesciata, la barra rovesciata verrà mantenuta. Si noti che mentre lpszDir e lpszFile sono entrambi parametri facoltativi, non possono essere entrambi NULL.

Esempi

#include <windows.h>
#include <iostream.h>
#include "Shlwapi.h"

void main( void )
{
// Buffer to hold combined path.
char buffer_1[MAX_PATH] = "";
char *lpStr1;
lpStr1 = buffer_1;

// String for balance of path name.
char buffer_2[ ] = "One\\Two\\Three";
char *lpStr2;
lpStr2 = buffer_2;

// String for directory name.
char buffer_3[ ] = "C:";
char *lpStr3;
lpStr3 = buffer_3;

cout << "The file path to be combined is  " 
     << lpStr2 << endl;
cout << "The directory name path is       " 
     << lpStr3 << endl;
cout << "The combined path is             " 
     << PathCombine(lpStr1,lpStr3,lpStr2) << endl;
}

------------
INPUT:
------------
Path for directory part: "C:"
Path for file part: "One\Two\Three"
------------
OUTPUT:
------------
The file path to be combined is  One\Two\Three
The directory name path is       C:
The combined path is             C:\One\Two\Three

Nota

L'intestazione shlwapi.h definisce PathCombine 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, Windows XP [solo app desktop]
server minimo supportato Windows 2000 Server [solo app desktop]
piattaforma di destinazione Finestre
intestazione shlwapi.h
libreria Shlwapi.lib
dll Shlwapi.dll (versione 4.71 o successiva)