Condividi tramite


Funzione PathFindNextComponentA (shlwapi.h)

Analizza un percorso e restituisce la parte del percorso che segue la prima barra rovesciata.

Sintassi

LPCSTR PathFindNextComponentA(
  [in] LPCSTR pszPath
);

Parametri

[in] pszPath

Tipo: PTSTR

Puntatore a una stringa con terminazione Null contenente il percorso da analizzare. Questa stringa non deve essere più lunga di MAX_PATH caratteri, oltre al carattere Null di terminazione. I componenti del percorso sono delimitati da barre rovesciate. Ad esempio, il percorso "c:\path1\path2\file.txt" include quattro componenti: c:, path1, path2 e file.txt.

Valore restituito

Tipo: PTSTR

Restituisce un puntatore a una stringa con terminazione Null contenente il percorso troncato.

Se pszPath punta all'ultimo componente nel percorso, questa funzione restituisce un puntatore al carattere Null di terminazione.

Se pszPath punta al carattere Null di terminazione o se la chiamata non riesce, questa funzione restituisce NULL.

Osservazioni

PathFindNextComponent cammina una stringa di percorso finché non rileva una barra rovesciata ("\"), ignora tutti gli elementi fino a quel punto, inclusa la barra rovesciata e restituisce il resto del percorso. Pertanto, se un percorso inizia con una barra rovesciata (ad esempio \path1\path2), la funzione rimuove semplicemente la barra rovesciata iniziale e restituisce il resto (path1\path2).

Esempi

L'applicazione console semplice seguente passa varie stringhe a PathFindNextComponent per illustrare ciò che la funzione riconosce come componente di percorso e per mostrare cosa viene restituito. Per eseguire questo codice in Visual Studio, è necessario collegarsi a Shlwapi.lib e definire UNICODE nei comandi del preprocessore nelle impostazioni del progetto.


#include <windows.h>
#include <iostream>
#include <shlwapi.h>

#pragma comment(lib, "shlwapi.lib")     // Link to this file.

int main()
{
    using namespace std;
   
    PCWSTR path = L"c:\\path1\\path2\\file.txt";
 
    // This loop passes a full path to PathFindNextComponent and feeds the 
    // results of that call back into the function until the entire path has
    // been walked.
    while (path)
    {
        PCWSTR oldPath = path;
        path = PathFindNextComponent(path);
 
        // The path variable pointed to the terminating null character.
        if (path == NULL)
        {
            wcout << L"The terminating null character returns NULL\n\n";
        }
        // The path variable pointed to a path with only one component.
		else if (*path == 0)
        {
            wcout << L"The path " << oldPath 
                  << L" returns a pointer to the terminating null character\n"; 
        }
        else 
        {
            wcout << L"The path " << oldPath << L" returns " << path << L"\n";
        }
    }
 
    // These calls demonstrate the results of different path forms.
    // Note that where those paths begin with backslashes, those
    // backslashes are merely stripped away and the entire path is returned.

    PCWSTR path1 = L"\\path1";

    wcout << L"The path " << path1 << L" returns " 
          << PathFindNextComponent(path1);
        
    PCWSTR path2 = L"\\path1\\path2";

    wcout << L"\nThe path " << path2 << L" returns "
          << PathFindNextComponent(path2);
        
    PCWSTR path3 = L"path1\\path2";
 
    wcout << L"\nThe path " << path3 << L" returns "
          << PathFindNextComponent(path3);
 
    wcout << L"\nThe path " << L"c:\\file.txt" << L" returns "
          << PathFindNextComponent(L"c:\\file.txt");
 
    return 0;
}

OUTPUT:
===========
The path c:\path1\path2\file.txt returns path1\path2\file.txt
The path path1\path2\file.txt returns path2\file.txt
The path path2\file.txt returns file.txt
The path file.txt returns a pointer to the terminating null character
The terminating null character returns NULL

The path \path1 returns path1
The path \path1\path2 returns path1\path2
The path path1\path2 returns path2
The path c:\file.txt returns file.txt

Nota

L'intestazione shlwapi.h definisce PathFindNextComponent 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)