Sdílet prostřednictvím


_fullpath, _wfullpath

Vytvoří název zadanou relativní cesta absolutní nebo celou cestu.

char *_fullpath( 
   char *absPath,
   const char *relPath,
   size_t maxLength 
);
wchar_t *_wfullpath( 
   wchar_t *absPath,
   const wchar_t *relPath,
   size_t maxLength 
);

Parametry

  • absPath
    Ukazatel do vyrovnávací paměti, absolutní nebo celou cestu obsahující název nebo hodnotu NULL.

  • relPath
    Název relativní cesty.

  • maxLength
    Maximální délka vyrovnávací paměti název absolutní cesty (absPath).Tato délka je v bajtech pro _fullpath , ale v celé znaky (wchar_t) pro _wfullpath.

Vrácená hodnota

Každá z těchto funkcí vrací ukazatel do vyrovnávací paměti obsahující název absolutní cesty (absPath).Pokud dojde k chybě (například, pokud hodnota předaná relPath obsahuje písmeno jednotky, které není platná nebo nelze nalézt nebo pokud délka názvu vytvořeného absolutní cestu (absPath) je větší než maxLength), vrátí funkce NULL.

Poznámky

_fullpath Rozšiřuje funkce název relativní cesty v relPath jeho plně kvalifikovaný nebo absolutní cestu a ukládá toto jméno absPath*.* Pokud absPath hodnotu NULL, malloc slouží k přidělení vyrovnávací paměti dostatečně dlouhý název cesty.Je odpovědností bez této vyrovnávací paměti volajícího.Relativní cesta Určuje cestu do jiného umístění z aktuálního umístění (například aktuální pracovní adresář: ".").Absolutní cesta je rozšíření název relativní cesty, která uvádí celou cestu, potřebné k dosažení požadovaného umístění z kořenového adresáře systému souborů.Na rozdíl od _makepath, _fullpath lze získat název absolutní cesty relativní cesty (relPath) obsahující ". /"nebo"../ "v jejich názvech.

Chcete-li použít c spuštění rutiny například žádost musí obsahovat záhlaví soubory, které obsahují prohlášení rutiny.Každý soubor záhlaví obsahovat prohlášení odkazy umístění souboru relativní způsobem (z pracovního adresáře aplikace):

#include <stdlib.h>

kdy může být absolutní cestu souboru (skutečné umístění systému souborů):

\\machine\shareName\msvcSrc\crt\headerFiles\stdlib.h

_fullpath automaticky zpracovává argumenty řetězec vícebajtových znaků podle potřeby UZNÁVAJÍCE vícebajtové znakové sekvence podle vícebajtové znakové stránky právě používán._wfullpath je verze celého znaku _fullpath; řetězcové argumenty k _wfullpath jsou celý znak řetězce._wfullpath a _fullpath s výjimkou, že se chovají stejně _wfullpath nezpracovává vícebajtové znakové řetězce.

Pokud _DEBUG a _CRTDBG_MAP_ALLOC jsou definovány, volání na _fullpath a _wfullpath nahrazují volání na _fullpath_dbg a _wfullpath_dbg pro ladění přidělení paměti.Další informace naleznete v _fullpath_dbg, _wfullpath_dbg.

Tato funkce vyvolá obsluhu neplatný parametr popsaným v Ověření parametru, pokud maxlen je menší než 0.Pokud je povoleno spuštění pokračovat, tato funkce nastaví errno na EINVAL a vrátí NULL.

Obecný Text rutinní mapování

Rutina Tchar.h

_UNICODE a _MBCS není definován

_MBCS, definice

_UNICODE, definice

_tfullpath

_fullpath

_fullpath

_wfullpath

Pokud absPath vyrovnávací paměť je NULL, _fullpath volání malloc k přidělení vyrovnávací paměti a ignoruje maxLength argument.Je odpovědností volajícího navrátit této vyrovnávací paměti (pomocí bez) podle potřeby.Pokud relPath argument určuje diskové jednotky, kombinace aktuálního adresáře jednotky cestu.

Požadavky

Function

Požadované záhlaví

_fullpath

<stdlib.h>

_wfullpath

<stdlib.h> nebo <wchar.h>

Další informace o kompatibilitě v tématu Compatibility v úvodu.

Příklad

// crt_fullpath.c
// This program demonstrates how _fullpath
// creates a full path from a partial path.
 
#include <stdio.h>
#include <conio.h>
#include <stdlib.h>
#include <direct.h>

void PrintFullPath( char * partialPath )
{
   char full[_MAX_PATH];
   if( _fullpath( full, partialPath, _MAX_PATH ) != NULL )
      printf( "Full path is: %s\n", full );
   else
      printf( "Invalid path\n" );
}

int main( void )
{
   PrintFullPath( "test" );
   PrintFullPath( "\\test" );
   PrintFullPath( "..\\test" );
}
  

Ekvivalent v rozhraní .NET Framework

System::IO::file:: vytvořit

Viz také

Referenční dokumentace

Zpracování souborů

_getcwd, _wgetcwd

_getdcwd, _wgetdcwd

_makepath, _wmakepath

_splitpath, _wsplitpath