public ref class FileInfo sealed : System::IO::FileSystemInfo
public sealed class FileInfo : System.IO.FileSystemInfo
[System.Serializable]
public sealed class FileInfo : System.IO.FileSystemInfo
[System.Serializable]
[System.Runtime.InteropServices.ComVisible(true)]
public sealed class FileInfo : System.IO.FileSystemInfo
type FileInfo = class
    inherit FileSystemInfo
[<System.Serializable>]
type FileInfo = class
    inherit FileSystemInfo
[<System.Serializable>]
[<System.Runtime.InteropServices.ComVisible(true)>]
type FileInfo = class
    inherit FileSystemInfo
Public NotInheritable Class FileInfo
Inherits FileSystemInfo
FileInfo

以下示例演示 类的一些main成员 FileInfo

首次检索属性时, FileInfo 调用 Refresh 方法并缓存有关文件的信息。 在后续调用中,必须调用 Refresh 以获取信息的最新副本。

using namespace System; using namespace System::IO; int main() String^ path = Path::GetTempFileName(); FileInfo^ fi1 = gcnew FileInfo( path ); //Create a file to write to. StreamWriter^ sw = fi1->CreateText(); sw->WriteLine( "Hello" ); sw->WriteLine( "And" ); sw->WriteLine( "Welcome" ); finally if ( sw ) delete (IDisposable^)sw; //Open the file to read from. StreamReader^ sr = fi1->OpenText(); String^ s = ""; while ( s = sr->ReadLine() ) Console::WriteLine( s ); finally if ( sr ) delete (IDisposable^)sr; String^ path2 = Path::GetTempFileName(); FileInfo^ fi2 = gcnew FileInfo( path2 ); //Ensure that the target does not exist. fi2->Delete(); //Copy the file. fi1->CopyTo( path2 ); Console::WriteLine( "{0} was copied to {1}.", path, path2 ); //Delete the newly created file. fi2->Delete(); Console::WriteLine( "{0} was successfully deleted.", path2 ); catch ( Exception^ e ) Console::WriteLine( "The process failed: {0}", e ); using System; using System.IO; class Test public static void Main() string path = Path.GetTempFileName(); var fi1 = new FileInfo(path); // Create a file to write to. using (StreamWriter sw = fi1.CreateText()) sw.WriteLine("Hello"); sw.WriteLine("And"); sw.WriteLine("Welcome"); // Open the file to read from. using (StreamReader sr = fi1.OpenText()) var s = ""; while ((s = sr.ReadLine()) != null) Console.WriteLine(s); string path2 = Path.GetTempFileName(); var fi2 = new FileInfo(path2); // Ensure that the target does not exist. fi2.Delete(); // Copy the file. fi1.CopyTo(path2); Console.WriteLine($"{path} was copied to {path2}."); // Delete the newly created file. fi2.Delete(); Console.WriteLine($"{path2} was successfully deleted."); catch (Exception e) Console.WriteLine($"The process failed: {e.ToString()}"); Imports System.IO Public Class Test Public Shared Sub Main() Dim path1 As String = Path.GetTempFileName() Dim path2 As String = Path.GetTempFileName() Dim fi As New FileInfo(path1) ' Create a file to write to. Using sw As StreamWriter = fi.CreateText() sw.WriteLine("Hello") sw.WriteLine("And") sw.WriteLine("Welcome") End Using ' Open the file to read from. Using sr As StreamReader = fi.OpenText() Do While sr.Peek() >= 0 Console.WriteLine(sr.ReadLine()) End Using Dim fi2 As New FileInfo(path2) ' Ensure that the target does not exist. fi2.Delete() ' Copy the file. fi.CopyTo(path2) Console.WriteLine($"{path1} was copied to {path2}.") ' Delete the newly created file. fi2.Delete() Console.WriteLine($"{path2} was successfully deleted.") Catch e As Exception Console.WriteLine($"The process failed: {e.ToString()}.") End Try End Sub End Class

此示例生成类似于以下内容的输出。

Hello  
Welcome  
C:\Users\userName\AppData\Local\Temp\tmp70AB.tmp was copied to C:\Users\userName\AppData\Local\Temp\tmp70CB.tmp.  
C:\Users\userName\AppData\Local\Temp\tmp70CB.tmp was successfully deleted.  
	

FileInfo将 类用于典型的操作,例如复制、移动、重命名、创建、打开、删除和追加到文件。

如果对同一个文件执行多个操作,则使用FileInfo实例方法而不是类的相应静态方法File可能更有效,因为并不总是需要安全检查。

创建或打开文件时, FileInfo 许多方法返回其他 I/O 类型。 可以使用这些其他类型进一步操作文件。 有关详细信息,请参阅特定FileInfo成员,例如 Open、、OpenReadOpenTextCreateTextCreate

默认情况下,向所有用户授予对新文件的完整读/写访问权限。

下表描述了用于自定义各种 FileInfo 方法行为的枚举。

在接受路径作为输入字符串的成员中,该路径的格式必须正常,否则将引发异常。 例如,如果路径是完全限定的,但以空格开头,则不会在 类的方法中剪裁该路径。 因此,路径格式不正确,并引发异常。 同样,路径或路径组合不能完全限定两次。 例如,“c:\temp c:\windows”在大多数情况下也会引发异常。 使用接受路径字符串的方法时,请确保路径格式良好。

在接受路径的成员中,路径可以引用文件或仅引用目录。 指定的路径还可以引用服务器和共享名称的相对路径或通用命名约定 (UNC) 路径。 例如,以下所有路径都是可接受的路径:

  • C# 中的“c:\\MyDir\\MyFile.txt”或 Visual Basic 中的“c:\MyDir\MyFile.txt”。

  • C# 中的“c:\\MyDir”或 Visual Basic 中的“c:\MyDir”。

  • C# 中的“MyDir\\MySubdir”或 Visual Basic 中的“MyDir\MySubDir”。

  • C# 中的“\\MyServer\\MyShare”或 Visual Basic 中的“\\MyServer\MyShare”。

    FileInfo 提供以下属性,使你能够检索有关文件的信息。 有关如何使用每个属性的示例,请参阅属性页。

  • 属性 Directory 检索表示文件的父目录的 对象。

  • 属性 DirectoryName 检索文件的父目录的完整路径。

  • 属性 Exists 先检查文件是否存在,然后再对其进行操作。

  • 属性 IsReadOnly 检索或设置一个值,该值指定是否可以修改文件。

  • 检索 Length 文件的大小。

  • 检索 Name 文件的名称。

  •