In the Windows API, the maximum length for a path is MAX_PATH, which is defined as 260 characters. A local path is structured in the following order: drive letter, colon, backslash, name components separated by backslashes, and a terminating null character. For example, the maximum path on drive D is "D:\some 256-character path string<NUL>
" where "<NUL>
" represents the invisible terminating null character for the current system codepage. (The characters < > are used here for visual clarity and cannot be part of a valid path string.) [MSDN]
The Unicode versions of several functions permit a maximum path length of approximately 32,000 characters composed of components up to 255 characters in length. To specify that kind of path, use the "\\?\"
prefix. The maximum path of 32,000 characters is approximate, because the "\\?\"
prefix can be expanded to a longer string, and the expansion applies to the total length.
For example, "\\?\D:\<path>"
. To specify such a UNC path, use the "\\?\UNC\"
prefix. For example, "\\?\UNC\<server>\<share>"
. These prefixes are not used as part of the path itself. They indicate that the path should be passed to the system with minimal modification, which means that you cannot use forward slashes to represent path separators, or a period to represent the current directory. Also, you cannot use the "\\?\"
prefix with a relative path. Relative paths are limited to MAX_PATH characters.
The shell and the file system may have different requirements. It is possible to create a path with the API that the shell UI cannot handle.
C# syntax:
[DllImport("kernel32.dll", CharSet=CharSet.Auto, SetLastError=true)]
public static extern bool DeleteFile(string path);
For more information on the class, see System Namespace - MSDN
Excerpts from:
Filesystem Paths: How Long is Too Long? - Coding Horror
DeleteFile function (Windows) - MSDN