FileStream FileStream FileStream FileStream Constructors

Определение

Перегрузки

FileStream(SafeFileHandle, FileAccess) FileStream(SafeFileHandle, FileAccess) FileStream(SafeFileHandle, FileAccess) FileStream(SafeFileHandle, FileAccess)

Инициализирует новый экземпляр класса FileStream для заданного дескриптора файла, используя указанные разрешения на чтение и запись.Initializes a new instance of the FileStream class for the specified file handle, with the specified read/write permission.

FileStream(String, FileMode, FileSystemRights, FileShare, Int32, FileOptions, FileSecurity) FileStream(String, FileMode, FileSystemRights, FileShare, Int32, FileOptions, FileSecurity) FileStream(String, FileMode, FileSystemRights, FileShare, Int32, FileOptions, FileSecurity)

Инициализирует новый экземпляр класса FileStream заданными путем, режимом создания, правами на доступ и совместное использование, размером буфера, дополнительными параметрами файла, управлением доступом и аудитом безопасности.Initializes a new instance of the FileStream class with the specified path, creation mode, access rights and sharing permission, the buffer size, additional file options, access control and audit security.

FileStream(String, FileMode, FileSystemRights, FileShare, Int32, FileOptions) FileStream(String, FileMode, FileSystemRights, FileShare, Int32, FileOptions) FileStream(String, FileMode, FileSystemRights, FileShare, Int32, FileOptions) FileStream(String, FileMode, FileSystemRights, FileShare, Int32, FileOptions)

Инициализирует новый экземпляр класса FileStream заданным путем, режимом создания, разрешениями на чтение, запись и совместное использование, размером буфера и дополнительными параметрами файла.Initializes a new instance of the FileStream class with the specified path, creation mode, access rights and sharing permission, the buffer size, and additional file options.

FileStream(String, FileMode, FileAccess, FileShare, Int32, Boolean) FileStream(String, FileMode, FileAccess, FileShare, Int32, Boolean) FileStream(String, FileMode, FileAccess, FileShare, Int32, Boolean) FileStream(String, FileMode, FileAccess, FileShare, Int32, Boolean)

Инициализирует новый экземпляр класса FileStream заданным путем, режимом создания, разрешениями на чтение и запись и совместное использование, размером буфера и синхронным или асинхронным состоянием.Initializes a new instance of the FileStream class with the specified path, creation mode, read/write and sharing permission, buffer size, and synchronous or asynchronous state.

FileStream(String, FileMode, FileAccess, FileShare, Int32) FileStream(String, FileMode, FileAccess, FileShare, Int32) FileStream(String, FileMode, FileAccess, FileShare, Int32) FileStream(String, FileMode, FileAccess, FileShare, Int32)

Инициализирует новый экземпляр класса FileStream заданным путем, режимом создания, разрешениями на чтение и запись и на совместное использование, а также размером буфера.Initializes a new instance of the FileStream class with the specified path, creation mode, read/write and sharing permission, and buffer size.

FileStream(IntPtr, FileAccess, Boolean, Int32, Boolean) FileStream(IntPtr, FileAccess, Boolean, Int32, Boolean) FileStream(IntPtr, FileAccess, Boolean, Int32, Boolean) FileStream(IntPtr, FileAccess, Boolean, Int32, Boolean)

Инициализирует новый экземпляр класса FileStream для заданного дескриптора файла, используя указанные разрешения на чтение и запись, владельца экземпляра FileStream, размер буфера и синхронное или асинхронное состояние.Initializes a new instance of the FileStream class for the specified file handle, with the specified read/write permission, FileStream instance ownership, buffer size, and synchronous or asynchronous state.

FileStream(String, FileMode, FileAccess, FileShare) FileStream(String, FileMode, FileAccess, FileShare) FileStream(String, FileMode, FileAccess, FileShare) FileStream(String, FileMode, FileAccess, FileShare)

Инициализирует новый экземпляр класса FileStream заданным путем, режимом создания, разрешением на чтение и запись и разрешением на совместное использование.Initializes a new instance of the FileStream class with the specified path, creation mode, read/write permission, and sharing permission.

FileStream(String, FileMode, FileAccess, FileShare, Int32, FileOptions) FileStream(String, FileMode, FileAccess, FileShare, Int32, FileOptions) FileStream(String, FileMode, FileAccess, FileShare, Int32, FileOptions) FileStream(String, FileMode, FileAccess, FileShare, Int32, FileOptions)

Инициализирует новый экземпляр класса FileStream заданным путем, режимом создания, разрешениями на чтение, запись и совместное использование, доступом для других FileStreams к этому же файлу, размером буфера и дополнительными параметрами файла.Initializes a new instance of the FileStream class with the specified path, creation mode, read/write and sharing permission, the access other FileStreams can have to the same file, the buffer size, and additional file options.

FileStream(SafeFileHandle, FileAccess, Int32, Boolean) FileStream(SafeFileHandle, FileAccess, Int32, Boolean) FileStream(SafeFileHandle, FileAccess, Int32, Boolean) FileStream(SafeFileHandle, FileAccess, Int32, Boolean)

Инициализирует новый экземпляр класса FileStream для заданного дескриптора файла, используя указанные разрешения на чтение и запись, размер буфера и синхронное или асинхронное состояние.Initializes a new instance of the FileStream class for the specified file handle, with the specified read/write permission, buffer size, and synchronous or asynchronous state.

FileStream(String, FileMode, FileAccess) FileStream(String, FileMode, FileAccess) FileStream(String, FileMode, FileAccess) FileStream(String, FileMode, FileAccess)

Инициализирует новый экземпляр класса FileStream заданным путем, режимом создания и разрешением на чтение и запись.Initializes a new instance of the FileStream class with the specified path, creation mode, and read/write permission.

FileStream(IntPtr, FileAccess, Boolean) FileStream(IntPtr, FileAccess, Boolean) FileStream(IntPtr, FileAccess, Boolean) FileStream(IntPtr, FileAccess, Boolean)

Инициализирует новый экземпляр класса FileStream для заданного дескриптора файла, используя указанные разрешения на чтение и запись и владельца экземпляра FileStream.Initializes a new instance of the FileStream class for the specified file handle, with the specified read/write permission and FileStream instance ownership.

FileStream(SafeFileHandle, FileAccess, Int32) FileStream(SafeFileHandle, FileAccess, Int32) FileStream(SafeFileHandle, FileAccess, Int32) FileStream(SafeFileHandle, FileAccess, Int32)

Инициализирует новый экземпляр класса FileStream для заданного дескриптора файла, используя указанные разрешения на чтение и запись и размер буфера.Initializes a new instance of the FileStream class for the specified file handle, with the specified read/write permission, and buffer size.

FileStream(IntPtr, FileAccess, Boolean, Int32) FileStream(IntPtr, FileAccess, Boolean, Int32) FileStream(IntPtr, FileAccess, Boolean, Int32) FileStream(IntPtr, FileAccess, Boolean, Int32)

Инициализирует новый экземпляр класса FileStream для заданного дескриптора файла, используя указанные разрешения на чтение и запись, владельца экземпляра FileStream и размер буфера.Initializes a new instance of the FileStream class for the specified file handle, with the specified read/write permission, FileStream instance ownership, and buffer size.

FileStream(String, FileMode) FileStream(String, FileMode) FileStream(String, FileMode) FileStream(String, FileMode)

Инициализирует новый экземпляр класса FileStream указанным путем и режимом создания.Initializes a new instance of the FileStream class with the specified path and creation mode.

FileStream(IntPtr, FileAccess) FileStream(IntPtr, FileAccess) FileStream(IntPtr, FileAccess) FileStream(IntPtr, FileAccess)

Инициализирует новый экземпляр класса FileStream для заданного дескриптора файла, используя указанные разрешения на чтение и запись.Initializes a new instance of the FileStream class for the specified file handle, with the specified read/write permission.

FileStream(SafeFileHandle, FileAccess) FileStream(SafeFileHandle, FileAccess) FileStream(SafeFileHandle, FileAccess) FileStream(SafeFileHandle, FileAccess)

Инициализирует новый экземпляр класса FileStream для заданного дескриптора файла, используя указанные разрешения на чтение и запись.Initializes a new instance of the FileStream class for the specified file handle, with the specified read/write permission.

public:
 FileStream(Microsoft::Win32::SafeHandles::SafeFileHandle ^ handle, System::IO::FileAccess access);
public FileStream (Microsoft.Win32.SafeHandles.SafeFileHandle handle, System.IO.FileAccess access);
new System.IO.FileStream : Microsoft.Win32.SafeHandles.SafeFileHandle * System.IO.FileAccess -> System.IO.FileStream
Public Sub New (handle As SafeFileHandle, access As FileAccess)

Параметры

handle
SafeFileHandle SafeFileHandle SafeFileHandle SafeFileHandle

Дескриптор для файла, являющегося текущим объектом FileStream, будет инкапсулирован.A file handle for the file that the current FileStream object will encapsulate.

access
FileAccess FileAccess FileAccess FileAccess

Константа, которая задает свойства CanRead и CanWrite объекта FileStream.A constant that sets the CanRead and CanWrite properties of the FileStream object.

Исключения

access не является полем FileAccess.access is not a field of FileAccess.

У вызывающего объекта отсутствует необходимое разрешение.The caller does not have the required permission.

Произошла ошибка ввода-вывода, например ошибка диска.An I/O error, such as a disk error, occurred.

- или --or-

Поток закрыт.The stream has been closed.

Запрошенный access не поддерживается операционной системой для указанного дескриптора файлов, например, когда access равен Write или ReadWrite, а для дескриптора файлов установлен доступ только для чтения.The access requested is not permitted by the operating system for the specified file handle, such as when access is Write or ReadWrite and the file handle is set for read-only access.

Комментарии

Когда Close вызывается метод, маркер также закрывается, а счетчик маркеров файла уменьшается.When Close is called, the handle is also closed and the file's handle count is decremented.

FileStreamПредполагается, что он имеет монопольный контроль над маркером.FileStream assumes that it has exclusive control over the handle. Чтение, запись или поиск в то время FileStream , когда также удерживается маркер, может привести к повреждению данных.Reading, writing, or seeking while a FileStream is also holding a handle could result in data corruption. Для обеспечения безопасности данных вызывайте Flush перед использованием маркера и избегайте вызова любых методов Close , кроме после завершения использования маркера.For data safety, call Flush before using the handle, and avoid calling any methods other than Close after you are done using the handle.

Внимание!

При компиляции набора символов с определенным параметром культуры и получении тех же символов с другим параметром культуры символы могут оказаться неинтерпретируемыми и могут вызвать исключение.When you compile a set of characters with a particular cultural setting and retrieve those same characters with a different cultural setting, the characters might not be interpretable, and could cause an exception to be thrown.

FileShare.Readпо умолчанию для этих FileStream конструкторов FileShare без параметра.FileShare.Read is the default for those FileStream constructors without a FileShare parameter.

Список общих операций с файлами и каталогами см. в разделе Общие задачи ввода-вывода.For a list of common file and directory operations, see Common I/O Tasks.

Безопасность

FileIOPermission
для чтения, записи и добавления в файлы.for reading, writing, and appending to files. Связанные перечисления: Read, Writeи Append.Associated enumerations: Read, Write, and Append.

Дополнительно

FileStream(String, FileMode, FileSystemRights, FileShare, Int32, FileOptions, FileSecurity) FileStream(String, FileMode, FileSystemRights, FileShare, Int32, FileOptions, FileSecurity) FileStream(String, FileMode, FileSystemRights, FileShare, Int32, FileOptions, FileSecurity)

Инициализирует новый экземпляр класса FileStream заданными путем, режимом создания, правами на доступ и совместное использование, размером буфера, дополнительными параметрами файла, управлением доступом и аудитом безопасности.Initializes a new instance of the FileStream class with the specified path, creation mode, access rights and sharing permission, the buffer size, additional file options, access control and audit security.

public:
 FileStream(System::String ^ path, System::IO::FileMode mode, System::Security::AccessControl::FileSystemRights rights, System::IO::FileShare share, int bufferSize, System::IO::FileOptions options, System::Security::AccessControl::FileSecurity ^ fileSecurity);
public FileStream (string path, System.IO.FileMode mode, System.Security.AccessControl.FileSystemRights rights, System.IO.FileShare share, int bufferSize, System.IO.FileOptions options, System.Security.AccessControl.FileSecurity fileSecurity);
new System.IO.FileStream : string * System.IO.FileMode * System.Security.AccessControl.FileSystemRights * System.IO.FileShare * int * System.IO.FileOptions * System.Security.AccessControl.FileSecurity -> System.IO.FileStream

Параметры

path
String String String String

Абсолютный или относительный путь к файлу, который будет инкапсулироваться объектом FileStream.A relative or absolute path for the file that the current FileStream object will encapsulate.

mode
FileMode FileMode FileMode FileMode

Константа, определяющая способ открытия или создания файла.A constant that determines how to open or create the file.

rights
FileSystemRights FileSystemRights FileSystemRights FileSystemRights

Константа, определяющая права доступа, используемые при создании правил доступа и аудита для файла.A constant that determines the access rights to use when creating access and audit rules for the file.

share
FileShare FileShare FileShare FileShare

Константа, определяющая способ совместного использования файла процессами.A constant that determines how the file will be shared by processes.

bufferSize
Int32 Int32 Int32 Int32

Положительное значение Int32 , большее 0, определяющее размер буфера.A positive Int32 value greater than 0 indicating the buffer size. Размер буфера по умолчанию — 4096.The default buffer size is 4096.

options
FileOptions FileOptions FileOptions FileOptions

Константа, задающая дополнительные параметры файла.A constant that specifies additional file options.

fileSecurity
FileSecurity FileSecurity FileSecurity FileSecurity

Константа, определяющая систему безопасности управления доступом и аудита доступа для файла.A constant that determines the access control and audit security for the file.

Исключения

Свойство path имеет значение null.path is null.

path представляет собой пустую строку (""), содержащую только пробел или хотя бы один недопустимый символ.path is an empty string (""), contains only white space, or contains one or more invalid characters.

- или --or- path ссылается на устройство нефайлового типа, например "con:", "com1:", "lpt1:" и т. д., в среде NTFS.path refers to a non-file device, such as "con:", "com1:", "lpt1:", etc. in an NTFS environment.

path ссылается на устройство не файлового типа, например "con:", "com1:", "lpt1:" и т. д., в среде, отличной от NTFS.path refers to a non-file device, such as "con:", "com1:", "lpt1:", etc. in a non-NTFS environment.

ПараметрbufferSize имеет отрицательное значение или равен нулю.bufferSize is negative or zero.

- или --or- mode, access или share содержит недопустимое значение.mode, access, or share contain an invalid value.

Не удается найти файл, например когда mode равно FileMode.Truncate или FileMode.Open, и файл, заданный параметром path, не существует.The file cannot be found, such as when mode is FileMode.Truncate or FileMode.Open, and the file specified by path does not exist. Файл должен уже существовать в этих режимах.The file must already exist in these modes.

Произошла ошибка ввода-вывода, например задание параметра FileMode.CreateNew, когда файл, заданный параметром path, уже существует.An I/O error, such as specifying FileMode.CreateNew when the file specified by path already exists, occurred.

-или--or- Поток закрыт.The stream has been closed.

У вызывающего объекта отсутствует необходимое разрешение.The caller does not have the required permission.

Указан недопустимый путь (например, он ведет на несопоставленный диск).The specified path is invalid, such as being on an unmapped drive.

Запрошенный access не поддерживается операционной системой для указанного path, например когда access равно Write или ReadWrite, а для файла или каталога установлен доступ только для чтения.The access requested is not permitted by the operating system for the specified path, such as when access is Write or ReadWrite and the file or directory is set for read-only access.

- или --or- Для options указан режим Encrypted, но в текущей платформе шифрование файлов не поддерживается.Encrypted is specified for options, but file encryption is not supported on the current platform.

Указанный path, имя файла или оба значения превышают максимальную длину, заданную в системе.The specified path, file name, or both exceed the system-defined maximum length.

Текущая операционная система не является системой Windows NT или более поздней версии.The current operating system is not Windows NT or later.

Примеры

В следующем примере данные записываются в файл, а затем считываются с помощью FileStream объекта.The following example writes data to a file and then reads the data using the FileStream object.

using namespace System;
using namespace System::IO;
using namespace System::Text;
using namespace System::Security::AccessControl;
using namespace System::Security::Principal;

int main()
{
    try
    {
        // Create a file and write data to it.

        // Create an array of bytes.
        array<Byte>^ messageByte =
            Encoding::ASCII->GetBytes("Here is some data.");

        // Specify an access control list (ACL)
        FileSecurity^ fs = gcnew FileSecurity();

        fs->AddAccessRule(
            gcnew FileSystemAccessRule("MYDOMAIN\\MyAccount",
            FileSystemRights::Modify, AccessControlType::Allow));

        // Create a file using the FileStream class.
        FileStream^ fWrite = gcnew FileStream("test.txt",
            FileMode::Create, FileSystemRights::Modify,
            FileShare::None, 8, FileOptions::None, fs);

        // Write the number of bytes to the file.
        fWrite->WriteByte((Byte)messageByte->Length);

        // Write the bytes to the file.
        fWrite->Write(messageByte, 0, messageByte->Length);

        // Close the stream.
        fWrite->Close();

        // Open a file and read the number of bytes.

        FileStream^ fRead = 
            gcnew FileStream("test.txt", FileMode::Open);

        // The first byte is the string length.
        int length = (int)fRead->ReadByte();

        // Create a new byte array for the data.
        array<Byte>^ readBytes = gcnew array<Byte>(length);

        // Read the data from the file.
        fRead->Read(readBytes, 0, readBytes->Length);

        // Close the stream.
        fRead->Close();

        // Display the data.
        Console::WriteLine(Encoding::ASCII->GetString(readBytes));

        Console::WriteLine("Done writing and reading data.");
    }

    catch (IdentityNotMappedException^)
    {
        Console::WriteLine("You need to use your own credentials " +
            " 'MYDOMAIN\\MyAccount'.");
    }

    catch (IOException^ ex)
    {
        Console::WriteLine(ex->Message);
    }
}

using System;
using System.IO;
using System.Text;
using System.Security.AccessControl;

namespace FileSystemExample
{
    class FileStreamExample
    {
        public static void Main()
        {
            try
            {
                // Create a file and write data to it.

                // Create an array of bytes.
                byte[] messageByte = Encoding.ASCII.GetBytes("Here is some data.");

                // Specify an access control list (ACL)
                FileSecurity fs = new FileSecurity();

                fs.AddAccessRule(new FileSystemAccessRule(@"DOMAINNAME\AccountName",
                                                            FileSystemRights.ReadData,
                                                            AccessControlType.Allow));

                // Create a file using the FileStream class.
                FileStream fWrite = new FileStream("test.txt", FileMode.Create, FileSystemRights.Modify, FileShare.None, 8, FileOptions.None, fs);

                // Write the number of bytes to the file.
                fWrite.WriteByte((byte)messageByte.Length);

                // Write the bytes to the file.
                fWrite.Write(messageByte, 0, messageByte.Length);

                // Close the stream.
                fWrite.Close();

                
                // Open a file and read the number of bytes.

                FileStream fRead = new FileStream("test.txt", FileMode.Open);

                // The first byte is the string length.
                int length = (int)fRead.ReadByte();

                // Create a new byte array for the data.
                byte[] readBytes = new byte[length];

                // Read the data from the file.
                fRead.Read(readBytes, 0, readBytes.Length);

                // Close the stream.
                fRead.Close();

                // Display the data.
                Console.WriteLine(Encoding.ASCII.GetString(readBytes));

                Console.WriteLine("Done writing and reading data.");
            }
            catch (Exception e)
            {
                Console.WriteLine(e);
            }

            Console.ReadLine();
        }
    }
}

Imports System
Imports System.IO
Imports System.Text
Imports System.Security.AccessControl



Module FileStreamExample

    Sub Main()
        Try
            ' Create a file and write data to it.
            ' Create an array of bytes.
            Dim messageByte As Byte() = Encoding.ASCII.GetBytes("Here is some data.")

            ' Specify an access control list (ACL)
            Dim fs As New FileSecurity()

            fs.AddAccessRule(New FileSystemAccessRule("DOMAINNAME\AccountName", FileSystemRights.ReadData, AccessControlType.Allow))

            ' Create a file using the FileStream class.
            Dim fWrite As New FileStream("test.txt", FileMode.Create, FileSystemRights.Modify, FileShare.None, 8, FileOptions.None, fs)

            ' Write the number of bytes to the file.
            fWrite.WriteByte(System.Convert.ToByte(messageByte.Length))

            ' Write the bytes to the file.
            fWrite.Write(messageByte, 0, messageByte.Length)

            ' Close the stream.
            fWrite.Close()


            ' Open a file and read the number of bytes.
            Dim fRead As New FileStream("test.txt", FileMode.Open)

            ' The first byte is the string length.
            Dim length As Integer = Fix(fRead.ReadByte())

            ' Create a new byte array for the data.
            Dim readBytes(length) As Byte

            ' Read the data from the file.
            fRead.Read(readBytes, 0, readBytes.Length)

            ' Close the stream.
            fRead.Close()

            ' Display the data.
            Console.WriteLine(Encoding.ASCII.GetString(readBytes))

            Console.WriteLine("Done writing and reading data.")
        Catch e As Exception
            Console.WriteLine(e)
        End Try

        Console.ReadLine()

    End Sub
End Module

Комментарии

.NET Framework не поддерживает прямой доступ к физическим дискам по путям, которые являются именами устройств, например "\\.\PHYSICALDRIVE0".The .NET Framework does not support direct access to physical disks through paths that are device names, such as "\\.\PHYSICALDRIVE0 ".

Используйте этот FileStream конструктор для применения прав доступа в момент создания файла.Use this FileStream constructor to apply access rights at the point of creation of a file. Чтобы получить или изменить права на существующий файл, рассмотрите возможность использования GetAccessControl методов SetAccessControl и.To access or modify rights on an existing file, consider using the GetAccessControl and SetAccessControl methods.

Параметр используется для предоставления доступа к более сложным операциям, которые можно использовать при FileStream создании объекта. fileOptionsThe fileOptions parameter is used to provide access to more advanced operations that can be leveraged when creating a FileStream object.

path Параметр может быть именем файла, включая файл в общей папке UNC.The path parameter can be a file name, including a file on a Universal Naming Convention (UNC) share.

Примечание

pathне обязательно должен быть файлом, хранящимся на диске; Это может быть любая часть системы, которая поддерживает доступ через потоки.path is not required to be a file stored on disk; it can be any part of a system that supports access through streams. Например, в зависимости от системы этот класс может обращаться к физическому устройству.For example, depending on the system, this class can access a physical device.

CanSeekпредназначен true для всех FileStream объектов, инкапсулирующих файлы.CanSeek is true for all FileStream objects that encapsulate files. Если path указывает на устройство, которое не поддерживает поиск CanSeek , свойство в результате FileStream имеет falseзначение.If path indicates a device that does not support seeking, the CanSeek property on the resulting FileStream is false. Дополнительные сведения см. в разделе CanSeek.For additional information, see CanSeek.

Внимание!

При компиляции набора символов с определенным параметром культуры и получении тех же символов с другим параметром культуры символы могут оказаться неинтерпретируемыми и могут вызвать исключение.When you compile a set of characters with a particular cultural setting and retrieve those same characters with a different cultural setting, the characters might not be interpretable, and could cause an exception to be thrown.

Список общих операций с файлами и каталогами см. в разделе Общие задачи ввода-вывода.For a list of common file and directory operations, see Common I/O Tasks.

Безопасность

FileIOPermission
для чтения, записи и добавления в файлы.for reading, writing, and appending to files. Связанные перечисления: Read, Writeи Append.Associated enumerations: Read, Write, and Append.

Дополнительно

FileStream(String, FileMode, FileSystemRights, FileShare, Int32, FileOptions) FileStream(String, FileMode, FileSystemRights, FileShare, Int32, FileOptions) FileStream(String, FileMode, FileSystemRights, FileShare, Int32, FileOptions) FileStream(String, FileMode, FileSystemRights, FileShare, Int32, FileOptions)

Инициализирует новый экземпляр класса FileStream заданным путем, режимом создания, разрешениями на чтение, запись и совместное использование, размером буфера и дополнительными параметрами файла.Initializes a new instance of the FileStream class with the specified path, creation mode, access rights and sharing permission, the buffer size, and additional file options.

public:
 FileStream(System::String ^ path, System::IO::FileMode mode, System::Security::AccessControl::FileSystemRights rights, System::IO::FileShare share, int bufferSize, System::IO::FileOptions options);
public FileStream (string path, System.IO.FileMode mode, System.Security.AccessControl.FileSystemRights rights, System.IO.FileShare share, int bufferSize, System.IO.FileOptions options);
new System.IO.FileStream : string * System.IO.FileMode * System.Security.AccessControl.FileSystemRights * System.IO.FileShare * int * System.IO.FileOptions -> System.IO.FileStream
Public Sub New (path As String, mode As FileMode, rights As FileSystemRights, share As FileShare, bufferSize As Integer, options As FileOptions)

Параметры

path
String String String String

Абсолютный или относительный путь к файлу, который будет инкапсулироваться объектом FileStream.A relative or absolute path for the file that the current FileStream object will encapsulate.

mode
FileMode FileMode FileMode FileMode

Константа, определяющая способ открытия или создания файла.A constant that determines how to open or create the file.

rights
FileSystemRights FileSystemRights FileSystemRights FileSystemRights

Константа, определяющая права доступа, используемые при создании правил доступа и аудита для файла.A constant that determines the access rights to use when creating access and audit rules for the file.

share
FileShare FileShare FileShare FileShare

Константа, определяющая способ совместного использования файла процессами.A constant that determines how the file will be shared by processes.

bufferSize
Int32 Int32 Int32 Int32

Положительное значение Int32 , большее 0, определяющее размер буфера.A positive Int32 value greater than 0 indicating the buffer size. Размер буфера по умолчанию — 4096.The default buffer size is 4096.

options
FileOptions FileOptions FileOptions FileOptions

Константа, задающая дополнительные параметры файла.A constant that specifies additional file options.

Исключения

Свойство path имеет значение null.path is null.

path представляет собой пустую строку (""), содержащую только пробел или хотя бы один недопустимый символ.path is an empty string (""), contains only white space, or contains one or more invalid characters.

-или--or- path ссылается на устройство нефайлового типа, например "con:", "com1:", "lpt1:" и т. д., в среде NTFS.path refers to a non-file device, such as "con:", "com1:", "lpt1:", etc. in an NTFS environment.

path ссылается на устройство не файлового типа, например "con:", "com1:", "lpt1:" и т. д., в среде, отличной от NTFS.path refers to a non-file device, such as "con:", "com1:", "lpt1:", etc. in a non-NTFS environment.

ПараметрbufferSize имеет отрицательное значение или равен нулю.bufferSize is negative or zero.

- или --or- mode, access или share содержит недопустимое значение.mode, access, or share contain an invalid value.

Не удается найти файл, например когда mode равно FileMode.Truncate или FileMode.Open, и файл, заданный параметром path, не существует.The file cannot be found, such as when mode is FileMode.Truncate or FileMode.Open, and the file specified by path does not exist. Файл должен уже существовать в этих режимах.The file must already exist in these modes.

Текущая операционная система не является системой Windows NT или более поздней версии.The current operating system is not Windows NT or later.

Произошла ошибка ввода-вывода, например задание параметра FileMode.CreateNew, когда файл, заданный параметром path, уже существует.An I/O error, such as specifying FileMode.CreateNew when the file specified by path already exists, occurred.

-или--or- Поток закрыт.The stream has been closed.

У вызывающего объекта отсутствует необходимое разрешение.The caller does not have the required permission.

Указан недопустимый путь (например, он ведет на несопоставленный диск).The specified path is invalid, such as being on an unmapped drive.

Запрошенный access не поддерживается операционной системой для указанного path, например когда access равно Write или ReadWrite, а для файла или каталога установлен доступ только для чтения.The access requested is not permitted by the operating system for the specified path, such as when access is Write or ReadWrite and the file or directory is set for read-only access.

-или--or- Для options указан режим Encrypted, но в текущей платформе шифрование файлов не поддерживается.Encrypted is specified for options, but file encryption is not supported on the current platform.

Указанный path, имя файла или оба значения превышают максимальную длину, заданную в системе.The specified path, file name, or both exceed the system-defined maximum length.

Комментарии

.NET Framework не поддерживает прямой доступ к физическим дискам по путям, которые являются именами устройств, например "\\.\PHYSICALDRIVE0".The .NET Framework does not support direct access to physical disks through paths that are device names, such as "\\.\PHYSICALDRIVE0 ".

Используйте этот FileStream конструктор для применения прав доступа в момент создания файла.Use this FileStream constructor to apply access rights at the point of creation of a file. Чтобы получить или изменить права на существующий файл, рассмотрите возможность использования GetAccessControl методов SetAccessControl и.To access or modify rights on an existing file, consider using the GetAccessControl and SetAccessControl methods.

Параметр используется для предоставления доступа к более сложным операциям, которые можно использовать при FileStream создании объекта. fileOptionsThe fileOptions parameter is used to provide access to more advanced operations that can be leveraged when creating a FileStream object.

path Параметр может быть именем файла, включая файл в общей папке UNC.The path parameter can be a file name, including a file on a Universal Naming Convention (UNC) share.

Примечание

pathне обязательно должен быть файлом, хранящимся на диске; Это может быть любая часть системы, которая поддерживает доступ через потоки.path is not required to be a file stored on disk; it can be any part of a system that supports access through streams. Например, в зависимости от системы этот класс может обращаться к физическому устройству.For example, depending on the system, this class can access a physical device.

CanSeekпредназначен true для всех FileStream объектов, инкапсулирующих файлы.CanSeek is true for all FileStream objects that encapsulate files. Если path указывает на устройство, которое не поддерживает поиск CanSeek , свойство в результате FileStream имеет falseзначение.If path indicates a device that does not support seeking, the CanSeek property on the resulting FileStream is false. Дополнительные сведения см. в разделе CanSeek.For additional information, see CanSeek.

Внимание!

При компиляции набора символов с определенным параметром культуры и получении тех же символов с другим параметром культуры символы могут оказаться неинтерпретируемыми и могут вызвать исключение.When you compile a set of characters with a particular cultural setting and retrieve those same characters with a different cultural setting, the characters might not be interpretable, and could cause an exception to be thrown.

Список общих операций с файлами и каталогами см. в разделе Общие задачи ввода-вывода.For a list of common file and directory operations, see Common I/O Tasks.

Безопасность

FileIOPermission
для чтения, записи и добавления в файлы.for reading, writing, and appending to files. Связанные перечисления: Read, Writeи Append.Associated enumerations: Read, Write, and Append.

Дополнительно

FileStream(String, FileMode, FileAccess, FileShare, Int32, Boolean) FileStream(String, FileMode, FileAccess, FileShare, Int32, Boolean) FileStream(String, FileMode, FileAccess, FileShare, Int32, Boolean) FileStream(String, FileMode, FileAccess, FileShare, Int32, Boolean)

Инициализирует новый экземпляр класса FileStream заданным путем, режимом создания, разрешениями на чтение и запись и совместное использование, размером буфера и синхронным или асинхронным состоянием.Initializes a new instance of the FileStream class with the specified path, creation mode, read/write and sharing permission, buffer size, and synchronous or asynchronous state.

public:
 FileStream(System::String ^ path, System::IO::FileMode mode, System::IO::FileAccess access, System::IO::FileShare share, int bufferSize, bool useAsync);
public FileStream (string path, System.IO.FileMode mode, System.IO.FileAccess access, System.IO.FileShare share, int bufferSize, bool useAsync);
new System.IO.FileStream : string * System.IO.FileMode * System.IO.FileAccess * System.IO.FileShare * int * bool -> System.IO.FileStream
Public Sub New (path As String, mode As FileMode, access As FileAccess, share As FileShare, bufferSize As Integer, useAsync As Boolean)

Параметры

path
String String String String

Абсолютный или относительный путь к файлу, который будет инкапсулироваться объектом FileStream.A relative or absolute path for the file that the current FileStream object will encapsulate.

mode
FileMode FileMode FileMode FileMode

Константа, определяющая способ открытия или создания файла.A constant that determines how to open or create the file.

access
FileAccess FileAccess FileAccess FileAccess

Константа, определяющая способ доступа к файлу объекта FileStream.A constant that determines how the file can be accessed by the FileStream object. Также определяет значения, возвращаемые свойствами CanRead и CanWrite объекта FileStream.This also determines the values returned by the CanRead and CanWrite properties of the FileStream object. Свойство CanSeek имеет значение true, если параметр path задает файл на диске.CanSeek is true if path specifies a disk file.

share
FileShare FileShare FileShare FileShare

Константа, определяющая способ совместного использования файла процессами.A constant that determines how the file will be shared by processes.

bufferSize
Int32 Int32 Int32 Int32

Положительное значение Int32 , большее 0, определяющее размер буфера.A positive Int32 value greater than 0 indicating the buffer size. Размер буфера по умолчанию — 4096.The default buffer size is 4096.

useAsync
Boolean Boolean Boolean Boolean

Указывает, использовать ли асинхронный ввод-вывод или синхронный ввод-вывод.Specifies whether to use asynchronous I/O or synchronous I/O. Однако обратите внимание, что базовая операционная система может не поддерживать асинхронный ввод-вывод, поэтому, когда задается значение true, дескриптор может быть открыт синхронно в зависимости от платформы.However, note that the underlying operating system might not support asynchronous I/O, so when specifying true, the handle might be opened synchronously depending on the platform. При асинхронном открытии методы BeginRead(Byte[], Int32, Int32, AsyncCallback, Object) и BeginWrite(Byte[], Int32, Int32, AsyncCallback, Object) выполняются лучше при чтении или записи больших объемов, но они могут работать намного медленнее при чтении или записи маленьких объемов данных.When opened asynchronously, the BeginRead(Byte[], Int32, Int32, AsyncCallback, Object) and BeginWrite(Byte[], Int32, Int32, AsyncCallback, Object) methods perform better on large reads or writes, but they might be much slower for small reads or writes. Если приложение разработано таким образом, чтобы получить преимущества асинхронного ввода-вывода, установите для параметра useAsync значение true.If the application is designed to take advantage of asynchronous I/O, set the useAsync parameter to true. При корректном использовании асинхронного ввода-вывода быстродействие приложения может возрасти вплоть до 10 раз, но использование такого режима ввода-вывода без переработки приложения может во столько же раз ухудшить быстродействие.Using asynchronous I/O correctly can speed up applications by as much as a factor of 10, but using it without redesigning the application for asynchronous I/O can decrease performance by as much as a factor of 10.

Исключения

path представляет собой пустую строку (""), содержащую только пробел или хотя бы один недопустимый символ.path is an empty string (""), contains only white space, or contains one or more invalid characters.

- или --or- path ссылается на устройство нефайлового типа, например "con:", "com1:", "lpt1:" и т. д., в среде NTFS.path refers to a non-file device, such as "con:", "com1:", "lpt1:", etc. in an NTFS environment.

path ссылается на устройство не файлового типа, например "con:", "com1:", "lpt1:" и т. д., в среде, отличной от NTFS.path refers to a non-file device, such as "con:", "com1:", "lpt1:", etc. in a non-NTFS environment.

ПараметрbufferSize имеет отрицательное значение или равен нулю.bufferSize is negative or zero.

- или --or- mode, access или share содержит недопустимое значение.mode, access, or share contain an invalid value.

Не удается найти файл, например когда mode равно FileMode.Truncate или FileMode.Open, и файл, заданный параметром path, не существует.The file cannot be found, such as when mode is FileMode.Truncate or FileMode.Open, and the file specified by path does not exist. Файл должен уже существовать в этих режимах.The file must already exist in these modes.

Произошла ошибка ввода-вывода, например задание параметра FileMode.CreateNew, когда файл, заданный параметром path, уже существует.An I/O error, such as specifying FileMode.CreateNew when the file specified by path already exists, occurred.

- или --or- Система работает под управлением Windows 98 или Windows 98 Second Edition, и для share задано значение FileShare.Delete.The system is running Windows 98 or Windows 98 Second Edition and share is set to FileShare.Delete.

-или--or- Поток закрыт.The stream has been closed.

У вызывающего объекта отсутствует необходимое разрешение.The caller does not have the required permission.

Указан недопустимый путь (например, он ведет на несопоставленный диск).The specified path is invalid, such as being on an unmapped drive.

Запрошенный access не поддерживается операционной системой для указанного path, например когда access равно Write или ReadWrite, а для файла или каталога установлен доступ только для чтения.The access requested is not permitted by the operating system for the specified path, such as when access is Write or ReadWrite and the file or directory is set for read-only access.

Указанный путь, имя файла или оба значения превышают максимальную длину, заданную в системе.The specified path, file name, or both exceed the system-defined maximum length.

Примеры

В следующем примере кода показано, как асинхронно записывать данные в файл, а затем проверить правильность их записи.The following code example shows how to asynchronously write data to a file and then verify that the data was written correctly. Объект создается для передачи сведений из основного потока EndReadCallback в методы и EndWriteCallback. StateA State object is created to pass information from the main thread to the EndReadCallback and EndWriteCallback methods.

using namespace System;
using namespace System::IO;
using namespace System::Threading;

// Maintain state information to be passed to 
// EndWriteCallback and EndReadCallback.
ref class State
{
private:

   // fStream is used to read and write to the file.
   FileStream^ fStream;

   // writeArray stores data that is written to the file.
   array<Byte>^writeArray;

   // readArray stores data that is read from the file.
   array<Byte>^readArray;

   // manualEvent signals the main thread 
   // when verification is complete.
   ManualResetEvent^ manualEvent;

public:
   State( FileStream^ fStream, array<Byte>^writeArray, ManualResetEvent^ manualEvent )
   {
      this->fStream = fStream;
      this->writeArray = writeArray;
      this->manualEvent = manualEvent;
      readArray = gcnew array<Byte>(writeArray->Length);
   }


   property FileStream^ FStream 
   {
      FileStream^ get()
      {
         return fStream;
      }

   }

   property array<Byte>^ WriteArray 
   {
      array<Byte>^ get()
      {
         return writeArray;
      }

   }

   property array<Byte>^ ReadArray 
   {
      array<Byte>^ get()
      {
         return readArray;
      }

   }

   property ManualResetEvent^ ManualEvent 
   {
      ManualResetEvent^ get()
      {
         return manualEvent;
      }

   }

};

ref class FStream
{
private:

   // When BeginRead is finished reading data from the file, the 
   // EndReadCallback method is called to end the asynchronous 
   // read operation and then verify the data.
   static void EndReadCallback( IAsyncResult^ asyncResult )
   {
      State^ tempState = dynamic_cast<State^>(asyncResult->AsyncState);
      int readCount = tempState->FStream->EndRead( asyncResult );
      int i = 0;
      while ( i < readCount )
      {
         if ( tempState->ReadArray[ i ] != tempState->WriteArray[ i++ ] )
         {
            Console::WriteLine( "Error writing data." );
            tempState->FStream->Close();
            return;
         }
      }

      Console::WriteLine( "The data was written to {0} "
      "and verified.", tempState->FStream->Name );
      tempState->FStream->Close();
      
      // Signal the main thread that the verification is finished.
      tempState->ManualEvent->Set();
   }


public:

   // When BeginWrite is finished writing data to the file, the
   // EndWriteCallback method is called to end the asynchronous 
   // write operation and then read back and verify the data.
   static void EndWriteCallback( IAsyncResult^ asyncResult )
   {
      State^ tempState = dynamic_cast<State^>(asyncResult->AsyncState);
      FileStream^ fStream = tempState->FStream;
      fStream->EndWrite( asyncResult );
      
      // Asynchronously read back the written data.
      fStream->Position = 0;
      asyncResult = fStream->BeginRead( tempState->ReadArray, 0, tempState->ReadArray->Length, gcnew AsyncCallback( &FStream::EndReadCallback ), tempState );
      
      // Concurrently do other work, such as 
      // logging the write operation.
   }

};


int main()
{
   
   // Create a synchronization object that gets 
   // signaled when verification is complete.
   ManualResetEvent^ manualEvent = gcnew ManualResetEvent( false );
   
   // Create the data to write to the file.
   array<Byte>^writeArray = gcnew array<Byte>(100000);
   (gcnew Random)->NextBytes( writeArray );
   FileStream^ fStream = gcnew FileStream(  "Test#@@#.dat",FileMode::Create,FileAccess::ReadWrite,FileShare::None,4096,true );
   
   // Check that the FileStream was opened asynchronously.
   Console::WriteLine( "fStream was {0}opened asynchronously.", fStream->IsAsync ? (String^)"" : "not " );
   
   // Asynchronously write to the file.
   IAsyncResult^ asyncResult = fStream->BeginWrite( writeArray, 0, writeArray->Length, gcnew AsyncCallback( &FStream::EndWriteCallback ), gcnew State( fStream,writeArray,manualEvent ) );
   
   // Concurrently do other work and then wait 
   // for the data to be written and verified.
   manualEvent->WaitOne( 5000, false );
}

using System;
using System.IO;
using System.Threading;

class FStream
{
    static void Main()
    {
        // Create a synchronization object that gets 
        // signaled when verification is complete.
        ManualResetEvent manualEvent = new ManualResetEvent(false);

        // Create random data to write to the file.
        byte[] writeArray = new byte[100000];
        new Random().NextBytes(writeArray);

        FileStream fStream = 
            new FileStream("Test#@@#.dat", FileMode.Create, 
            FileAccess.ReadWrite, FileShare.None, 4096, true);

        // Check that the FileStream was opened asynchronously.
        Console.WriteLine("fStream was {0}opened asynchronously.",
            fStream.IsAsync ? "" : "not ");

        // Asynchronously write to the file.
        IAsyncResult asyncResult = fStream.BeginWrite(
            writeArray, 0, writeArray.Length, 
            new AsyncCallback(EndWriteCallback), 
            new State(fStream, writeArray, manualEvent));

        // Concurrently do other work and then wait 
        // for the data to be written and verified.
        manualEvent.WaitOne(5000, false);
    }

    // When BeginWrite is finished writing data to the file, the
    // EndWriteCallback method is called to end the asynchronous 
    // write operation and then read back and verify the data.
    static void EndWriteCallback(IAsyncResult asyncResult)
    {
        State tempState = (State)asyncResult.AsyncState;
        FileStream fStream = tempState.FStream;
        fStream.EndWrite(asyncResult);

        // Asynchronously read back the written data.
        fStream.Position = 0;
        asyncResult = fStream.BeginRead(
            tempState.ReadArray, 0 , tempState.ReadArray.Length, 
            new AsyncCallback(EndReadCallback), tempState);

        // Concurrently do other work, such as 
        // logging the write operation.
    }

    // When BeginRead is finished reading data from the file, the 
    // EndReadCallback method is called to end the asynchronous 
    // read operation and then verify the data.
    static void EndReadCallback(IAsyncResult asyncResult)
    {
        State tempState = (State)asyncResult.AsyncState;
        int readCount = tempState.FStream.EndRead(asyncResult);

        int i = 0;
        while(i < readCount)
        {
            if(tempState.ReadArray[i] != tempState.WriteArray[i++])
            {
                Console.WriteLine("Error writing data.");
                tempState.FStream.Close();
                return;
            }
        }
        Console.WriteLine("The data was written to {0} and verified.",
            tempState.FStream.Name);
        tempState.FStream.Close();

        // Signal the main thread that the verification is finished.
        tempState.ManualEvent.Set();
    }

    // Maintain state information to be passed to 
    // EndWriteCallback and EndReadCallback.
    class State
    {
        // fStream is used to read and write to the file.
        FileStream fStream;

        // writeArray stores data that is written to the file.
        byte[] writeArray;

        // readArray stores data that is read from the file.
        byte[] readArray;

        // manualEvent signals the main thread 
        // when verification is complete.
        ManualResetEvent manualEvent;

        public State(FileStream fStream, byte[] writeArray, 
            ManualResetEvent manualEvent)
        {
            this.fStream   = fStream;
            this.writeArray = writeArray;
            this.manualEvent = manualEvent;
            readArray = new byte[writeArray.Length];
        }

        public FileStream FStream
        { get{ return fStream; } }

        public byte[] WriteArray
        { get{ return writeArray; } }

        public byte[] ReadArray
        { get{ return readArray; } }

        public ManualResetEvent ManualEvent
        { get{ return manualEvent; } }
    }
}
Imports System
Imports System.IO
Imports System.Threading

Class FStream

    Shared Sub Main()

        ' Create a synchronization object that gets 
        ' signaled when verification is complete.
        Dim manualEvent As New ManualResetEvent(False)

        ' Create random data to write to the file.
        Dim writeArray(100000) As Byte
        Dim randomGenerator As New Random()
        randomGenerator.NextBytes(writeArray)

        Dim fStream As New FileStream("Test#@@#.dat", _
            FileMode.Create, FileAccess.ReadWrite, _
            FileShare.None, 4096, True)

        ' Check that the FileStream was opened asynchronously.
        If fStream.IsAsync = True
            Console.WriteLine("fStream was opened asynchronously.")
        Else
            Console.WriteLine("fStream was not opened asynchronously.")
        End If

        ' Asynchronously write to the file.
        Dim asyncResult As IAsyncResult = fStream.BeginWrite( _
            writeArray, 0, writeArray.Length, _
            AddressOf EndWriteCallback , _
            New State(fStream, writeArray, manualEvent))

        ' Concurrently do other work and then wait
        ' for the data to be written and verified.
        manualEvent.WaitOne(5000, False)
    End Sub

    ' When BeginWrite is finished writing data to the file, the
    ' EndWriteCallback method is called to end the asynchronous 
    ' write operation and then read back and verify the data.
    Private Shared Sub EndWriteCallback(asyncResult As IAsyncResult)
        Dim tempState As State = _
            DirectCast(asyncResult.AsyncState, State)
        Dim fStream As FileStream = tempState.FStream
        fStream.EndWrite(asyncResult)

        ' Asynchronously read back the written data.
        fStream.Position = 0
        asyncResult = fStream.BeginRead( _ 
            tempState.ReadArray, 0 , tempState.ReadArray.Length, _
            AddressOf EndReadCallback, tempState)

        ' Concurrently do other work, such as 
        ' logging the write operation.
    End Sub

    ' When BeginRead is finished reading data from the file, the 
    ' EndReadCallback method is called to end the asynchronous 
    ' read operation and then verify the data.
   Private Shared Sub EndReadCallback(asyncResult As IAsyncResult)
        Dim tempState As State = _
            DirectCast(asyncResult.AsyncState, State)
        Dim readCount As Integer = _
            tempState.FStream.EndRead(asyncResult)

        Dim i As Integer = 0
        While(i < readCount)
            If(tempState.ReadArray(i) <> tempState.WriteArray(i))
                Console.WriteLine("Error writing data.")
                tempState.FStream.Close()
                Return
            End If
            i += 1
        End While

        Console.WriteLine("The data was written to {0} and " & _
            "verified.", tempState.FStream.Name)
        tempState.FStream.Close()

        ' Signal the main thread that the verification is finished.
        tempState.ManualEvent.Set()
    End Sub

    ' Maintain state information to be passed to 
    ' EndWriteCallback and EndReadCallback.
    Private Class State

        ' fStreamValue is used to read and write to the file.
        Dim fStreamValue As FileStream

        ' writeArrayValue stores data that is written to the file.
        Dim writeArrayValue As Byte()

        ' readArrayValue stores data that is read from the file.
        Dim readArrayValue As Byte()

        ' manualEvent signals the main thread 
        ' when verification is complete.
        Dim manualEventValue As ManualResetEvent 

        Sub New(aStream As FileStream, anArray As Byte(), _
            manualEvent As ManualResetEvent)

            fStreamValue     = aStream
            writeArrayValue  = anArray
            manualEventValue = manualEvent
            readArrayValue   = New Byte(anArray.Length - 1){}
        End Sub    

            Public ReadOnly Property FStream() As FileStream
                Get
                    Return fStreamValue
                End Get
            End Property

            Public ReadOnly Property WriteArray() As Byte()
                Get
                    Return writeArrayValue
                End Get
            End Property

            Public ReadOnly Property ReadArray() As Byte()
                Get
                    Return readArrayValue
                End Get
            End Property

            Public ReadOnly Property ManualEvent() As ManualResetEvent
                Get
                    Return manualEventValue
                End Get
            End Property
    End Class 
   
End Class

Комментарии

.NET Framework не поддерживает прямой доступ к физическим дискам по путям, которые являются именами устройств, например "\\.\PHYSICALDRIVE0".The .NET Framework does not support direct access to physical disks through paths that are device names, such as "\\.\PHYSICALDRIVE0 ".

path Параметр может быть именем файла, включая файл в общей папке UNC.The path parameter can be a file name, including a file on a Universal Naming Convention (UNC) share.

Примечание

pathне обязательно должен быть файлом, хранящимся на диске; Это может быть любая часть системы, которая поддерживает доступ через потоки.path is not required to be a file stored on disk; it can be any part of a system that supports access through streams. Например, в зависимости от системы этот класс может обращаться к физическому устройству.For example, depending on the system, this class can access a physical device.

CanSeekпредназначен true для всех FileStream объектов, инкапсулирующих файлы.CanSeek is true for all FileStream objects that encapsulate files. Если path указывает на устройство, которое не поддерживает поиск CanSeek , свойство в результате FileStream имеет falseзначение.If path indicates a device that does not support seeking, the CanSeek property on the resulting FileStream is false. Дополнительные сведения см. в разделе CanSeek.For additional information, see CanSeek.

Внимание!

При компиляции набора символов с определенным параметром культуры и получении тех же символов с другим параметром культуры символы могут оказаться неинтерпретируемыми и могут вызвать исключение.When you compile a set of characters with a particular cultural setting and retrieve those same characters with a different cultural setting, the characters might not be interpretable, and could cause an exception to be thrown.

Список общих операций с файлами и каталогами см. в разделе Общие задачи ввода-вывода.For a list of common file and directory operations, see Common I/O Tasks.

Безопасность

FileIOPermission
для чтения, записи и добавления в файлы.for reading, writing, and appending to files. Связанные перечисления: Read, Writeи Append.Associated enumerations: Read, Write, and Append.

Дополнительно

FileStream(String, FileMode, FileAccess, FileShare, Int32) FileStream(String, FileMode, FileAccess, FileShare, Int32) FileStream(String, FileMode, FileAccess, FileShare, Int32) FileStream(String, FileMode, FileAccess, FileShare, Int32)

Инициализирует новый экземпляр класса FileStream заданным путем, режимом создания, разрешениями на чтение и запись и на совместное использование, а также размером буфера.Initializes a new instance of the FileStream class with the specified path, creation mode, read/write and sharing permission, and buffer size.

public:
 FileStream(System::String ^ path, System::IO::FileMode mode, System::IO::FileAccess access, System::IO::FileShare share, int bufferSize);
public FileStream (string path, System.IO.FileMode mode, System.IO.FileAccess access, System.IO.FileShare share, int bufferSize);
new System.IO.FileStream : string * System.IO.FileMode * System.IO.FileAccess * System.IO.FileShare * int -> System.IO.FileStream
Public Sub New (path As String, mode As FileMode, access As FileAccess, share As FileShare, bufferSize As Integer)

Параметры

path
String String String String

Абсолютный или относительный путь к файлу, который будет инкапсулироваться объектом FileStream.A relative or absolute path for the file that the current FileStream object will encapsulate.

mode
FileMode FileMode FileMode FileMode

Константа, определяющая способ открытия или создания файла.A constant that determines how to open or create the file.

access
FileAccess FileAccess FileAccess FileAccess

Константа, определяющая способ доступа к файлу объекта FileStream.A constant that determines how the file can be accessed by the FileStream object. Также определяет значения, возвращаемые свойствами CanRead и CanWrite объекта FileStream.This also determines the values returned by the CanRead and CanWrite properties of the FileStream object. Свойство CanSeek имеет значение true, если параметр path задает файл на диске.CanSeek is true if path specifies a disk file.

share
FileShare FileShare FileShare FileShare

Константа, определяющая способ совместного использования файла процессами.A constant that determines how the file will be shared by processes.

bufferSize
Int32 Int32 Int32 Int32

Положительное значение Int32 , большее 0, определяющее размер буфера.A positive Int32 value greater than 0 indicating the buffer size. Размер буфера по умолчанию — 4096.The default buffer size is 4096.

Исключения

Свойство path имеет значение null.path is null.

path представляет собой пустую строку (""), содержащую только пробел или хотя бы один недопустимый символ.path is an empty string (""), contains only white space, or contains one or more invalid characters.

-или--or- path ссылается на устройство нефайлового типа, например "con:", "com1:", "lpt1:" и т. д., в среде NTFS.path refers to a non-file device, such as "con:", "com1:", "lpt1:", etc. in an NTFS environment.

path ссылается на устройство не файлового типа, например "con:", "com1:", "lpt1:" и т. д., в среде, отличной от NTFS.path refers to a non-file device, such as "con:", "com1:", "lpt1:", etc. in a non-NTFS environment.

ПараметрbufferSize имеет отрицательное значение или равен нулю.bufferSize is negative or zero.

- или --or- mode, access или share содержит недопустимое значение.mode, access, or share contain an invalid value.

Не удается найти файл, например когда mode равно FileMode.Truncate или FileMode.Open, и файл, заданный параметром path, не существует.The file cannot be found, such as when mode is FileMode.Truncate or FileMode.Open, and the file specified by path does not exist. Файл должен уже существовать в этих режимах.The file must already exist in these modes.

Произошла ошибка ввода-вывода, например задание параметра FileMode.CreateNew, когда файл, заданный параметром path, уже существует.An I/O error, such as specifying FileMode.CreateNew when the file specified by path already exists, occurred.

- или --or- Система работает под управлением Windows 98 или Windows 98 Second Edition, и для share задано значение FileShare.Delete.The system is running Windows 98 or Windows 98 Second Edition and share is set to FileShare.Delete.

-или--or- Поток закрыт.The stream has been closed.

У вызывающего объекта отсутствует необходимое разрешение.The caller does not have the required permission.

Указан недопустимый путь (например, он ведет на несопоставленный диск).The specified path is invalid, such as being on an unmapped drive.

Запрошенный access не поддерживается операционной системой для указанного path, например когда access равно Write или ReadWrite, а для файла или каталога установлен доступ только для чтения.The access requested is not permitted by the operating system for the specified path, such as when access is Write or ReadWrite and the file or directory is set for read-only access.

Указанный путь, имя файла или оба значения превышают максимальную длину, заданную в системе.The specified path, file name, or both exceed the system-defined maximum length.

Комментарии

.NET Framework не поддерживает прямой доступ к физическим дискам по путям, которые являются именами устройств, например "\\.\PHYSICALDRIVE0".The .NET Framework does not support direct access to physical disks through paths that are device names, such as "\\.\PHYSICALDRIVE0 ".

path Параметр может быть именем файла, включая файл в общей папке UNC.The path parameter can be a file name, including a file on a Universal Naming Convention (UNC) share.

Примечание

pathне обязательно должен быть файлом, хранящимся на диске; Это может быть любая часть системы, которая поддерживает доступ через потоки.path is not required to be a file stored on disk; it can be any part of a system that supports access through streams. Например, в зависимости от системы этот класс может обращаться к физическому устройству.For example, depending on the system, this class can access a physical device.

CanSeekпредназначен true для всех FileStream объектов, инкапсулирующих файлы.CanSeek is true for all FileStream objects that encapsulate files. Если path указывает на устройство, которое не поддерживает поиск CanSeek , свойство в результате FileStream имеет falseзначение.If path indicates a device that does not support seeking, the CanSeek property on the resulting FileStream is false. Дополнительные сведения см. в разделе CanSeek.For additional information, see CanSeek.

Внимание!

При компиляции набора символов с определенным параметром культуры и получении тех же символов с другим параметром культуры символы могут оказаться неинтерпретируемыми и могут вызвать исключение.When you compile a set of characters with a particular cultural setting and retrieve those same characters with a different cultural setting, the characters might not be interpretable, and could cause an exception to be thrown.

Список общих операций с файлами и каталогами см. в разделе Общие задачи ввода-вывода.For a list of common file and directory operations, see Common I/O Tasks.

Безопасность

FileIOPermission
для чтения, записи и добавления в файлы.for reading, writing, and appending to files. Связанные перечисления: Read, Writeи Append.Associated enumerations: Read, Write, and Append.

Дополнительно

FileStream(IntPtr, FileAccess, Boolean, Int32, Boolean) FileStream(IntPtr, FileAccess, Boolean, Int32, Boolean) FileStream(IntPtr, FileAccess, Boolean, Int32, Boolean) FileStream(IntPtr, FileAccess, Boolean, Int32, Boolean)

Предупреждение

Этот API устарел.

Инициализирует новый экземпляр класса FileStream для заданного дескриптора файла, используя указанные разрешения на чтение и запись, владельца экземпляра FileStream, размер буфера и синхронное или асинхронное состояние.Initializes a new instance of the FileStream class for the specified file handle, with the specified read/write permission, FileStream instance ownership, buffer size, and synchronous or asynchronous state.

public:
 FileStream(IntPtr handle, System::IO::FileAccess access, bool ownsHandle, int bufferSize, bool isAsync);
[System.Obsolete("Use FileStream(SafeFileHandle handle, FileAccess access, int bufferSize, bool isAsync) instead")]
[System.Obsolete("This constructor has been deprecated.  Please use new FileStream(SafeFileHandle handle, FileAccess access, int bufferSize, bool isAsync) instead, and optionally make a new SafeFileHandle with ownsHandle=false if needed.  http://go.microsoft.com/fwlink/?linkid=14202")]
[System.Obsolete("This constructor has been deprecated.  Please use new FileStream(SafeFileHandle handle, FileAccess access, int bufferSize, bool isAsync) instead, and optionally make a new SafeFileHandle with ownsHandle=false if needed.  https://go.microsoft.com/fwlink/?linkid=14202")]
public FileStream (IntPtr handle, System.IO.FileAccess access, bool ownsHandle, int bufferSize, bool isAsync);
new System.IO.FileStream : nativeint * System.IO.FileAccess * bool * int * bool -> System.IO.FileStream
Public Sub New (handle As IntPtr, access As FileAccess, ownsHandle As Boolean, bufferSize As Integer, isAsync As Boolean)

Параметры

handle
IntPtr IntPtr IntPtr IntPtr

Дескриптор файла для файла, который будет инкапсулироваться с помощью объекта FileStream.A file handle for the file that this FileStream object will encapsulate.

access
FileAccess FileAccess FileAccess FileAccess

Константа, которая задает свойства CanRead и CanWrite объекта FileStream.A constant that sets the CanRead and CanWrite properties of the FileStream object.

ownsHandle
Boolean Boolean Boolean Boolean

Значение true, если владельцем дескриптора файла будет этот экземпляр FileStream; в противном случае — значение false.true if the file handle will be owned by this FileStream instance; otherwise, false.

bufferSize
Int32 Int32 Int32 Int32

Положительное значение Int32, большее 0, определяющее размер буфера.A positive Int32 value greater than 0 indicating the buffer size. Размер буфера по умолчанию — 4096.The default buffer size is 4096.

isAsync
Boolean Boolean Boolean Boolean

Значение true, если этот дескриптор был открыт асинхронно (т. е. в режиме перекрывающегося ввода-вывода); в противном случае — значение false.true if the handle was opened asynchronously (that is, in overlapped I/O mode); otherwise, false.

Исключения

Значение access меньше FileAccess.Read или больше FileAccess.ReadWrite, либо bufferSize не больше 0.access is less than FileAccess.Read or greater than FileAccess.ReadWrite or bufferSize is less than or equal to 0.

Дескриптор недействителен.The handle is invalid.

Произошла ошибка ввода-вывода, например ошибка диска.An I/O error, such as a disk error, occurred.

- или --or-

Поток закрыт.The stream has been closed.

У вызывающего объекта отсутствует необходимое разрешение.The caller does not have the required permission.

Запрошенный access не поддерживается операционной системой для указанного дескриптора файлов, например, когда access равен Write или ReadWrite, а для дескриптора файлов установлен доступ только для чтения.The access requested is not permitted by the operating system for the specified file handle, such as when access is Write or ReadWrite and the file handle is set for read-only access.

Комментарии

FileStream Объекту предоставляется указанный доступ к файлу.The FileStream object is given the specified access to the file. Владельцем маркера будет, как указано.The ownership of the handle will be as specified. Если он FileStream владеет маркером, вызов Close метода также закрывает этот обработчик.If this FileStream owns the handle, a call to the Close method will also close the handle. В частности, счетчик маркеров файла уменьшается.In particular, the file's handle count is decremented. FileStream Объекту задается указанный размер буфера.The FileStream object is given the specified buffer size.

FileStreamПредполагается, что он имеет монопольный контроль над маркером.FileStream assumes that it has exclusive control over the handle. Чтение, запись или поиск в то время FileStream , когда также удерживается маркер, может привести к повреждению данных.Reading, writing, or seeking while a FileStream is also holding a handle could result in data corruption. Для обеспечения безопасности данных вызывайте Flush перед использованием маркера и избегайте вызова любых методов Close , кроме после завершения использования маркера.For data safety, call Flush before using the handle, and avoid calling any methods other than Close after you are done using the handle. Кроме того, перед вызовом этого FileStream конструктора необходимо выполнить чтение и запись в этот обработчик.Alternately, read and write to the handle before calling this FileStream constructor.

FileShare.Readпо умолчанию для этих FileStream конструкторов FileShare без параметра.FileShare.Read is the default for those FileStream constructors without a FileShare parameter.

Внимание!

При компиляции набора символов с определенным параметром культуры и получении тех же символов с другим параметром культуры символы могут оказаться неинтерпретируемыми и могут вызвать исключение.When you compile a set of characters with a particular cultural setting and retrieve those same characters with a different cultural setting, the characters might not be interpretable, and could cause an exception to be thrown.

Список общих операций с файлами и каталогами см. в разделе Общие задачи ввода-вывода.For a list of common file and directory operations, see Common I/O Tasks.

Безопасность

SecurityPermission
для доступа к неуправляемому коду.for access to unmanaged code. Связанное перечисление: UnmanagedCode.Associated enumeration: UnmanagedCode.

Дополнительно

FileStream(String, FileMode, FileAccess, FileShare) FileStream(String, FileMode, FileAccess, FileShare) FileStream(String, FileMode, FileAccess, FileShare) FileStream(String, FileMode, FileAccess, FileShare)

Инициализирует новый экземпляр класса FileStream заданным путем, режимом создания, разрешением на чтение и запись и разрешением на совместное использование.Initializes a new instance of the FileStream class with the specified path, creation mode, read/write permission, and sharing permission.

public:
 FileStream(System::String ^ path, System::IO::FileMode mode, System::IO::FileAccess access, System::IO::FileShare share);
public FileStream (string path, System.IO.FileMode mode, System.IO.FileAccess access, System.IO.FileShare share);
new System.IO.FileStream : string * System.IO.FileMode * System.IO.FileAccess * System.IO.FileShare -> System.IO.FileStream
Public Sub New (path As String, mode As FileMode, access As FileAccess, share As FileShare)

Параметры

path
String String String String

Абсолютный или относительный путь к файлу, который будет инкапсулироваться объектом FileStream.A relative or absolute path for the file that the current FileStream object will encapsulate.

mode
FileMode FileMode FileMode FileMode

Константа, определяющая способ открытия или создания файла.A constant that determines how to open or create the file.

access
FileAccess FileAccess FileAccess FileAccess

Константа, определяющая способ доступа к файлу объекта FileStream.A constant that determines how the file can be accessed by the FileStream object. Также определяет значения, возвращаемые свойствами CanRead и CanWrite объекта FileStream.This also determines the values returned by the CanRead and CanWrite properties of the FileStream object. Свойство CanSeek имеет значение true, если параметр path задает файл на диске.CanSeek is true if path specifies a disk file.

share
FileShare FileShare FileShare FileShare

Константа, определяющая способ совместного использования файла процессами.A constant that determines how the file will be shared by processes.

Исключения

Свойство path имеет значение null.path is null.

path представляет собой пустую строку (""), содержащую только пробел или хотя бы один недопустимый символ.path is an empty string (""), contains only white space, or contains one or more invalid characters.

- или --or- path ссылается на устройство нефайлового типа, например "con:", "com1:", "lpt1:" и т. д., в среде NTFS.path refers to a non-file device, such as "con:", "com1:", "lpt1:", etc. in an NTFS environment.

path ссылается на устройство не файлового типа, например "con:", "com1:", "lpt1:" и т. д., в среде, отличной от NTFS.path refers to a non-file device, such as "con:", "com1:", "lpt1:", etc. in a non-NTFS environment.

Не удается найти файл, например когда mode равно FileMode.Truncate или FileMode.Open, и файл, заданный параметром path, не существует.The file cannot be found, such as when mode is FileMode.Truncate or FileMode.Open, and the file specified by path does not exist. Файл должен уже существовать в этих режимах.The file must already exist in these modes.

Произошла ошибка ввода-вывода, например задание параметра FileMode.CreateNew, когда файл, заданный параметром path, уже существует.An I/O error, such as specifying FileMode.CreateNew when the file specified by path already exists, occurred.

- или --or- Система работает под управлением Windows 98 или Windows 98 Second Edition, и для share задано значение FileShare.Delete.The system is running Windows 98 or Windows 98 Second Edition and share is set to FileShare.Delete.

-или--or- Поток закрыт.The stream has been closed.

У вызывающего объекта отсутствует необходимое разрешение.The caller does not have the required permission.

Указан недопустимый путь (например, он ведет на несопоставленный диск).The specified path is invalid, such as being on an unmapped drive.

Запрошенный access не поддерживается операционной системой для указанного path, например когда access равно Write или ReadWrite, а для файла или каталога установлен доступ только для чтения.The access requested is not permitted by the operating system for the specified path, such as when access is Write or ReadWrite and the file or directory is set for read-only access.

Указанный путь, имя файла или оба значения превышают максимальную длину, заданную в системе.The specified path, file name, or both exceed the system-defined maximum length.

Параметр mode содержит недопустимое значение.mode contains an invalid value.

Примеры

Этот пример кода является частью большого примера, Lock приведенного для метода.This code example is part of a larger example provided for the Lock method.

FileStream^ fileStream = gcnew FileStream( "Test#@@#.dat",FileMode::OpenOrCreate,FileAccess::ReadWrite,FileShare::ReadWrite );

using(FileStream fileStream = new FileStream(
    "Test#@@#.dat", FileMode.OpenOrCreate, 
    FileAccess.ReadWrite, FileShare.ReadWrite))
Dim aFileStream As New FileStream( _
    "Test#@@#.dat", FileMode.OpenOrCreate, _
    FileAccess.ReadWrite, FileShare.ReadWrite)

Комментарии

.NET Framework не поддерживает прямой доступ к физическим дискам по путям, которые являются именами устройств, например "\\.\PHYSICALDRIVE0".The .NET Framework does not support direct access to physical disks through paths that are device names, such as "\\.\PHYSICALDRIVE0 ".

path Параметр может быть именем файла, включая файл в общей папке UNC.The path parameter can be a file name, including a file on a Universal Naming Convention (UNC) share.

Конструктор получает доступ на чтение и запись к файлу, и он открывает общий доступ на чтение (т. е. запросы на открытие файла для записи этим или другим процессом завершатся ошибкой до тех пор, пока FileStream объект не будет закрыт, но попытки чтения будут успешными).The constructor is given read/write access to the file, and it is opened sharing Read access (that is, requests to open the file for writing by this or another process will fail until the FileStream object has been closed, but read attempts will succeed). Размер буфера задается как размер по умолчанию 4096 байт (4 КБ).The buffer size is set to the default size of 4096 bytes (4 KB).

Примечание

pathне обязательно должен быть файлом, хранящимся на диске; Это может быть любая часть системы, которая поддерживает доступ через потоки.path is not required to be a file stored on disk; it can be any part of a system that supports access through streams. Например, в зависимости от системы этот класс может обращаться к физическому устройству.For example, depending on the system, this class can access a physical device.

CanSeekпредназначен true для всех FileStream объектов, инкапсулирующих файлы.CanSeek is true for all FileStream objects that encapsulate files. Если path указывает на устройство, которое не поддерживает поиск CanSeek , свойство в результате FileStream имеет falseзначение.If path indicates a device that does not support seeking, the CanSeek property on the resulting FileStream is false. Дополнительные сведения см. в разделе CanSeek.For additional information, see CanSeek.

Внимание!

При компиляции набора символов с определенным параметром культуры и получении тех же символов с другим параметром культуры символы могут оказаться неинтерпретируемыми и могут вызвать исключение.When you compile a set of characters with a particular cultural setting and retrieve those same characters with a different cultural setting, the characters might not be interpretable, and could cause an exception to be thrown.

Список общих операций с файлами и каталогами см. в разделе Общие задачи ввода-вывода.For a list of common file and directory operations, see Common I/O Tasks.

Безопасность

FileIOPermission
для чтения, записи и добавления в файлы.for reading, writing, and appending to files. Связанные перечисления: Read, Writeи Append.Associated enumerations: Read, Write, and Append.

Дополнительно

FileStream(String, FileMode, FileAccess, FileShare, Int32, FileOptions) FileStream(String, FileMode, FileAccess, FileShare, Int32, FileOptions) FileStream(String, FileMode, FileAccess, FileShare, Int32, FileOptions) FileStream(String, FileMode, FileAccess, FileShare, Int32, FileOptions)

Инициализирует новый экземпляр класса FileStream заданным путем, режимом создания, разрешениями на чтение, запись и совместное использование, доступом для других FileStreams к этому же файлу, размером буфера и дополнительными параметрами файла.Initializes a new instance of the FileStream class with the specified path, creation mode, read/write and sharing permission, the access other FileStreams can have to the same file, the buffer size, and additional file options.

public:
 FileStream(System::String ^ path, System::IO::FileMode mode, System::IO::FileAccess access, System::IO::FileShare share, int bufferSize, System::IO::FileOptions options);
public FileStream (string path, System.IO.FileMode mode, System.IO.FileAccess access, System.IO.FileShare share, int bufferSize, System.IO.FileOptions options);
new System.IO.FileStream : string * System.IO.FileMode * System.IO.FileAccess * System.IO.FileShare * int * System.IO.FileOptions -> System.IO.FileStream
Public Sub New (path As String, mode As FileMode, access As FileAccess, share As FileShare, bufferSize As Integer, options As FileOptions)

Параметры

path
String String String String

Абсолютный или относительный путь к файлу, который будет инкапсулироваться объектом FileStream.A relative or absolute path for the file that the current FileStream object will encapsulate.

mode
FileMode FileMode FileMode FileMode

Константа, определяющая способ открытия или создания файла.A constant that determines how to open or create the file.

access
FileAccess FileAccess FileAccess FileAccess

Константа, определяющая способ доступа к файлу объекта FileStream.A constant that determines how the file can be accessed by the FileStream object. Также определяет значения, возвращаемые свойствами CanRead и CanWrite объекта FileStream.This also determines the values returned by the CanRead and CanWrite properties of the FileStream object. Свойство CanSeek имеет значение true, если параметр path задает файл на диске.CanSeek is true if path specifies a disk file.

share
FileShare FileShare FileShare FileShare

Константа, определяющая способ совместного использования файла процессами.A constant that determines how the file will be shared by processes.

bufferSize
Int32 Int32 Int32 Int32

Положительное значение Int32 , большее 0, определяющее размер буфера.A positive Int32 value greater than 0 indicating the buffer size. Размер буфера по умолчанию — 4096.The default buffer size is 4096.

options
FileOptions FileOptions FileOptions FileOptions

Значение, задающее дополнительные параметры файла.A value that specifies additional file options.

Исключения

Свойство path имеет значение null.path is null.

path представляет собой пустую строку (""), содержащую только пробел или хотя бы один недопустимый символ.path is an empty string (""), contains only white space, or contains one or more invalid characters.

- или --or- path ссылается на устройство нефайлового типа, например "con:", "com1:", "lpt1:" и т. д., в среде NTFS.path refers to a non-file device, such as "con:", "com1:", "lpt1:", etc. in an NTFS environment.

path ссылается на устройство не файлового типа, например "con:", "com1:", "lpt1:" и т. д., в среде, отличной от NTFS.path refers to a non-file device, such as "con:", "com1:", "lpt1:", etc. in a non-NTFS environment.

ПараметрbufferSize имеет отрицательное значение или равен нулю.bufferSize is negative or zero.

- или --or- mode, access или share содержит недопустимое значение.mode, access, or share contain an invalid value.

Не удается найти файл, например когда mode равно FileMode.Truncate или FileMode.Open, и файл, заданный параметром path, не существует.The file cannot be found, such as when mode is FileMode.Truncate or FileMode.Open, and the file specified by path does not exist. Файл должен уже существовать в этих режимах.The file must already exist in these modes.

Произошла ошибка ввода-вывода, например задание параметра FileMode.CreateNew, когда файл, заданный параметром path, уже существует.An I/O error, such as specifying FileMode.CreateNew when the file specified by path already exists, occurred.

-или--or- Поток закрыт.The stream has been closed.

У вызывающего объекта отсутствует необходимое разрешение.The caller does not have the required permission.

Указан недопустимый путь (например, он ведет на несопоставленный диск).The specified path is invalid, such as being on an unmapped drive.

Запрошенный access не поддерживается операционной системой для указанного path, например когда access равно Write или ReadWrite, а для файла или каталога установлен доступ только для чтения.The access requested is not permitted by the operating system for the specified path, such as when access is Write or ReadWrite and the file or directory is set for read-only access.

-или--or- Для options указан режим Encrypted, но в текущей платформе шифрование файлов не поддерживается.Encrypted is specified for options, but file encryption is not supported on the current platform.

Указанный путь, имя файла или оба значения превышают максимальную длину, заданную в системе.The specified path, file name, or both exceed the system-defined maximum length.

Примеры

В следующем примере данные записываются в файл, а затем считываются с помощью FileStream объекта.The following example writes data to a file and then reads the data using the FileStream object.

#using <System.dll>

using namespace System;
using namespace System::IO;
using namespace System::Text;
using namespace System::Security::AccessControl;

int main()
{
    try
    {
        // Create a file and write data to it.

        // Create an array of bytes.
        array<Byte>^ messageByte =
            Encoding::ASCII->GetBytes("Here is some data.");

        // Create a file using the FileStream class.
        FileStream^ fWrite = gcnew FileStream("test.txt", FileMode::Create,
            FileAccess::ReadWrite, FileShare::None, 8, FileOptions::None);

        // Write the number of bytes to the file.
        fWrite->WriteByte((Byte)messageByte->Length);

        // Write the bytes to the file.
        fWrite->Write(messageByte, 0, messageByte->Length);

        // Close the stream.
        fWrite->Close();


        // Open a file and read the number of bytes.

        FileStream^ fRead = gcnew FileStream("test.txt", 
            FileMode::Open);

        // The first byte is the string length.
        int length = (int)fRead->ReadByte();

        // Create a new byte array for the data.
        array<Byte>^ readBytes = gcnew array<Byte>(length);

        // Read the data from the file.
        fRead->Read(readBytes, 0, readBytes->Length);

        // Close the stream.
        fRead->Close();

        // Display the data.
        Console::WriteLine(Encoding::ASCII->GetString(readBytes));

        Console::WriteLine("Done writing and reading data.");
    }
    catch (IOException^ ex)
    {
        Console::WriteLine(ex->Message);
    }
}
using System;
using System.IO;
using System.Text;
using System.Security.AccessControl;

namespace FileSystemExample
{
    class FileStreamExample
    {
        public static void Main()
        {
            try
            {
                // Create a file and write data to it.

                // Create an array of bytes.
                byte[] messageByte = Encoding.ASCII.GetBytes("Here is some data.");

                // Create a file using the FileStream class.
                FileStream fWrite = new FileStream("test.txt", FileMode.Create, FileAccess.ReadWrite, FileShare.None, 8, FileOptions.None);

                // Write the number of bytes to the file.
                fWrite.WriteByte((byte)messageByte.Length);

                // Write the bytes to the file.
                fWrite.Write(messageByte, 0, messageByte.Length);

                // Close the stream.
                fWrite.Close();

                
                // Open a file and read the number of bytes.

                FileStream fRead = new FileStream("test.txt", FileMode.Open);

                // The first byte is the string length.
                int length = (int)fRead.ReadByte();

                // Create a new byte array for the data.
                byte[] readBytes = new byte[length];

                // Read the data from the file.
                fRead.Read(readBytes, 0, readBytes.Length);

                // Close the stream.
                fRead.Close();

                // Display the data.
                Console.WriteLine(Encoding.ASCII.GetString(readBytes));

                Console.WriteLine("Done writing and reading data.");
            }
            catch (Exception e)
            {
                Console.WriteLine(e);
            }

            Console.ReadLine();
        }
    }
}

Imports System
Imports System.IO
Imports System.Text
Imports System.Security.AccessControl



Module FileStreamExample

    Sub Main()
        Try
            ' Create a file and write data to it.
            ' Create an array of bytes.
            Dim messageByte As Byte() = Encoding.ASCII.GetBytes("Here is some data.")

            ' Create a file using the FileStream class.
            Dim fWrite As New FileStream("test.txt", FileMode.Create, FileAccess.ReadWrite, FileShare.None, 8, FileOptions.None)

            ' Write the number of bytes to the file.
            fWrite.WriteByte(System.Convert.ToByte(messageByte.Length))

            ' Write the bytes to the file.
            fWrite.Write(messageByte, 0, messageByte.Length)

            ' Close the stream.
            fWrite.Close()


            ' Open a file and read the number of bytes.
            Dim fRead As New FileStream("test.txt", FileMode.Open)

            ' The first byte is the string length.
            Dim length As Integer = Fix(fRead.ReadByte())

            ' Create a new byte array for the data.
            Dim readBytes(length) As Byte

            ' Read the data from the file.
            fRead.Read(readBytes, 0, readBytes.Length)

            ' Close the stream.
            fRead.Close()

            ' Display the data.
            Console.WriteLine(Encoding.ASCII.GetString(readBytes))

            Console.WriteLine("Done writing and reading data.")
        Catch e As Exception
            Console.WriteLine(e)
        End Try

        Console.ReadLine()

    End Sub
End Module

Комментарии

.NET Framework не поддерживает прямой доступ к физическим дискам по путям, которые являются именами устройств, например "\\.\PHYSICALDRIVE0".The .NET Framework does not support direct access to physical disks through paths that are device names, such as "\\.\PHYSICALDRIVE0 ".

Параметр используется для предоставления доступа к более сложным операциям, которые можно использовать при FileStream создании объекта. fileOptionsThe fileOptions parameter is used to provide access to more advanced operations that can be leveraged when creating a FileStream object.

path Параметр может быть именем файла, включая файл в общей папке UNC.The path parameter can be a file name, including a file on a Universal Naming Convention (UNC) share.

Примечание

pathне обязательно должен быть файлом, хранящимся на диске; Это может быть любая часть системы, которая поддерживает доступ через потоки.path is not required to be a file stored on disk; it can be any part of a system that supports access through streams. Например, в зависимости от системы этот класс может обращаться к физическому устройству.For example, depending on the system, this class can access a physical device.

CanSeekпредназначен true для всех FileStream объектов, инкапсулирующих файлы.CanSeek is true for all FileStream objects that encapsulate files. Если path указывает на устройство, которое не поддерживает поиск CanSeek , свойство в результате FileStream имеет falseзначение.If path indicates a device that does not support seeking, the CanSeek property on the resulting FileStream is false. Дополнительные сведения см. в разделе CanSeek.For additional information, see CanSeek.

Внимание!

При компиляции набора символов с определенным параметром культуры и получении тех же символов с другим параметром культуры символы могут оказаться неинтерпретируемыми и могут вызвать исключение.When you compile a set of characters with a particular cultural setting and retrieve those same characters with a different cultural setting, the characters might not be interpretable, and could cause an exception to be thrown.

Список общих операций с файлами и каталогами см. в разделе Общие задачи ввода-вывода.For a list of common file and directory operations, see Common I/O Tasks.

Безопасность

FileIOPermission
для чтения, записи и добавления в файлы.for reading, writing, and appending to files. Связанные перечисления: Read, Writeи Append.Associated enumerations: Read, Write, and Append.

Дополнительно

FileStream(SafeFileHandle, FileAccess, Int32, Boolean) FileStream(SafeFileHandle, FileAccess, Int32, Boolean) FileStream(SafeFileHandle, FileAccess, Int32, Boolean) FileStream(SafeFileHandle, FileAccess, Int32, Boolean)

Инициализирует новый экземпляр класса FileStream для заданного дескриптора файла, используя указанные разрешения на чтение и запись, размер буфера и синхронное или асинхронное состояние.Initializes a new instance of the FileStream class for the specified file handle, with the specified read/write permission, buffer size, and synchronous or asynchronous state.

public:
 FileStream(Microsoft::Win32::SafeHandles::SafeFileHandle ^ handle, System::IO::FileAccess access, int bufferSize, bool isAsync);
public FileStream (Microsoft.Win32.SafeHandles.SafeFileHandle handle, System.IO.FileAccess access, int bufferSize, bool isAsync);
new System.IO.FileStream : Microsoft.Win32.SafeHandles.SafeFileHandle * System.IO.FileAccess * int * bool -> System.IO.FileStream
Public Sub New (handle As SafeFileHandle, access As FileAccess, bufferSize As Integer, isAsync As Boolean)

Параметры

handle
SafeFileHandle SafeFileHandle SafeFileHandle SafeFileHandle

Дескриптор файла для файла, который будет инкапсулироваться с помощью объекта FileStream.A file handle for the file that this FileStream object will encapsulate.

access
FileAccess FileAccess FileAccess FileAccess

Константа, которая задает свойства CanRead и CanWrite объекта FileStream.A constant that sets the CanRead and CanWrite properties of the FileStream object.

bufferSize
Int32 Int32 Int32 Int32

Положительное значение Int32, большее 0, определяющее размер буфера.A positive Int32 value greater than 0 indicating the buffer size. Размер буфера по умолчанию — 4096.The default buffer size is 4096.

isAsync
Boolean Boolean Boolean Boolean

Значение true, если этот дескриптор был открыт асинхронно (т. е. в режиме перекрывающегося ввода-вывода); в противном случае — значение false.true if the handle was opened asynchronously (that is, in overlapped I/O mode); otherwise, false.

Исключения

Параметр handle является недопустимым дескриптором.The handle parameter is an invalid handle.

-или--or- Параметр handle является синхронным дескриптором, но был использован асинхронно.The handle parameter is a synchronous handle and it was used asynchronously.

Параметр bufferSize имеет отрицательное значение.The bufferSize parameter is negative.

Произошла ошибка ввода-вывода, например ошибка диска.An I/O error, such as a disk error, occurred.

- или --or-

Поток закрыт.The stream has been closed.

У вызывающего объекта отсутствует необходимое разрешение.The caller does not have the required permission.

Запрошенный access не поддерживается операционной системой для указанного дескриптора файлов, например, когда access равен Write или ReadWrite, а для дескриптора файлов установлен доступ только для чтения.The access requested is not permitted by the operating system for the specified file handle, such as when access is Write or ReadWrite and the file handle is set for read-only access.

Комментарии

Задайте isAsync дляtrue параметра значение, чтобы асинхронно открыть этот файл.You set the isAsync parameter to true to open the file handle asynchronously. Если параметр имеет trueзначение, поток использует перекрывающиеся операции ввода-вывода для асинхронного выполнения операций с файлами.When the parameter is true, the stream utilizes overlapped I/O to perform file operations asynchronously. Однако параметр не true обязательно должен ReadAsyncвызывать метод, WriteAsyncили CopyToAsync .However, the parameter does not have to be true to call the ReadAsync, WriteAsync, or CopyToAsync method. Если параметр имеет false значение и вызываются асинхронные операции чтения и записи, то поток пользовательского интерфейса по-прежнему не блокируется, но фактическая операция ввода-вывода выполняется синхронно. isAsyncWhen the isAsync parameter is false and you call the asynchronous read and write operations, the UI thread is still not blocked, but the actual I/O operation is performed synchronously.

FileStreamПредполагается, что он имеет монопольный контроль над маркером.FileStream assumes that it has exclusive control over the handle. Чтение, запись или поиск в то время FileStream , когда также удерживается маркер, может привести к повреждению данных.Reading, writing, or seeking while a FileStream is also holding a handle could result in data corruption. Для обеспечения безопасности данных вызывайте Flush перед использованием маркера и избегайте вызова любых методов Close , кроме после завершения использования маркера.For data safety, call Flush before using the handle, and avoid calling any methods other than Close after you are done using the handle. Кроме того, перед вызовом этого FileStream конструктора необходимо выполнить чтение и запись в этот обработчик.Alternately, read and write to the handle before calling this FileStream constructor.

FileShare.Readпо умолчанию для этих FileStream конструкторов FileShare без параметра.FileShare.Read is the default for those FileStream constructors without a FileShare parameter.

Внимание!

При компиляции набора символов с определенным параметром культуры и получении тех же символов с другим параметром культуры символы могут оказаться неинтерпретируемыми и могут вызвать исключение.When you compile a set of characters with a particular cultural setting and retrieve those same characters with a different cultural setting, the characters might not be interpretable, and could cause an exception to be thrown.

Список общих операций с файлами и каталогами см. в разделе Общие задачи ввода-вывода.For a list of common file and directory operations, see Common I/O Tasks.

Безопасность

FileIOPermission
для чтения, записи и добавления в файлы.for reading, writing, and appending to files. Связанные перечисления: Read, Writeи Append.Associated enumerations: Read, Write, and Append.

SecurityPermission
разрешение на вызов неуправляемого кода.for permission to call unmanaged code. Связанные перечисления:UnmanagedCodeAssociated enumerations: UnmanagedCode

Дополнительно

FileStream(String, FileMode, FileAccess) FileStream(String, FileMode, FileAccess) FileStream(String, FileMode, FileAccess) FileStream(String, FileMode, FileAccess)

Инициализирует новый экземпляр класса FileStream заданным путем, режимом создания и разрешением на чтение и запись.Initializes a new instance of the FileStream class with the specified path, creation mode, and read/write permission.

public:
 FileStream(System::String ^ path, System::IO::FileMode mode, System::IO::FileAccess access);
public FileStream (string path, System.IO.FileMode mode, System.IO.FileAccess access);
new System.IO.FileStream : string * System.IO.FileMode * System.IO.FileAccess -> System.IO.FileStream
Public Sub New (path As String, mode As FileMode, access As FileAccess)

Параметры

path
String String String String

Абсолютный или относительный путь к файлу, который будет инкапсулироваться объектом FileStream.A relative or absolute path for the file that the current FileStream object will encapsulate.

mode
FileMode FileMode FileMode FileMode

Константа, определяющая способ открытия или создания файла.A constant that determines how to open or create the file.

access
FileAccess FileAccess FileAccess FileAccess

Константа, определяющая способ доступа к файлу объекта FileStream.A constant that determines how the file can be accessed by the FileStream object. Также определяет значения, возвращаемые свойствами CanRead и CanWrite объекта FileStream.This also determines the values returned by the CanRead and CanWrite properties of the FileStream object. Свойство CanSeek имеет значение true, если параметр path задает файл на диске.CanSeek is true if path specifies a disk file.

Исключения

Свойство path имеет значение null.path is null.

path представляет собой пустую строку (""), содержащую только пробел или хотя бы один недопустимый символ.path is an empty string (""), contains only white space, or contains one or more invalid characters.

- или --or- path ссылается на устройство нефайлового типа, например "con:", "com1:", "lpt1:" и т. д., в среде NTFS.path refers to a non-file device, such as "con:", "com1:", "lpt1:", etc. in an NTFS environment.

path ссылается на устройство не файлового типа, например "con:", "com1:", "lpt1:" и т. д., в среде, отличной от NTFS.path refers to a non-file device, such as "con:", "com1:", "lpt1:", etc. in a non-NTFS environment.

Не удается найти файл, например когда mode равно FileMode.Truncate или FileMode.Open, и файл, заданный параметром path, не существует.The file cannot be found, such as when mode is FileMode.Truncate or FileMode.Open, and the file specified by path does not exist. Файл должен уже существовать в этих режимах.The file must already exist in these modes.

Произошла ошибка ввода-вывода, например задание параметра FileMode.CreateNew, когда файл, заданный параметром path, уже существует.An I/O error, such as specifying FileMode.CreateNew when the file specified by path already exists, occurred.

- или --or- Поток закрыт.The stream has been closed.

У вызывающего объекта отсутствует необходимое разрешение.The caller does not have the required permission.

Указан недопустимый путь (например, он ведет на несопоставленный диск).The specified path is invalid, such as being on an unmapped drive.

Запрошенный access не поддерживается операционной системой для указанного path, например когда access равно Write или ReadWrite, а для файла или каталога установлен доступ только для чтения.The access requested is not permitted by the operating system for the specified path, such as when access is Write or ReadWrite and the file or directory is set for read-only access.

Указанный путь, имя файла или оба значения превышают максимальную длину, заданную в системе.The specified path, file name, or both exceed the system-defined maximum length.

Параметр mode содержит недопустимое значение.mode contains an invalid value.

Комментарии

.NET Framework не поддерживает прямой доступ к физическим дискам по путям, которые являются именами устройств, например "\\.\PHYSICALDRIVE0".The .NET Framework does not support direct access to physical disks through paths that are device names, such as "\\.\PHYSICALDRIVE0 ".

path Параметр может быть именем файла, включая файл в общей папке UNC.The path parameter can be a file name, including a file on a Universal Naming Convention (UNC) share.

Конструктор получает доступ на чтение и запись к файлу, и он открывает общий доступ на чтение (т. е. запросы на открытие файла для записи этим или другим процессом завершатся ошибкой до тех пор, пока FileStream объект не будет закрыт, но попытки чтения будут успешными).The constructor is given read/write access to the file, and it is opened sharing Read access (that is, requests to open the file for writing by this or another process will fail until the FileStream object has been closed, but read attempts will succeed). Размер буфера задается как размер по умолчанию 4096 байт (4 КБ).The buffer size is set to the default size of 4096 bytes (4 KB).

Примечание

pathне обязательно должен быть файлом, хранящимся на диске; Это может быть любая часть системы, которая поддерживает доступ через потоки.path is not required to be a file stored on disk; it can be any part of a system that supports access through streams. Например, в зависимости от системы этот класс может обращаться к физическому устройству.For example, depending on the system, this class can access a physical device.

CanSeekпредназначен true для всех FileStream объектов, инкапсулирующих файлы.CanSeek is true for all FileStream objects that encapsulate files. Если path указывает на устройство, которое не поддерживает поиск CanSeek , свойство в результате FileStream имеет falseзначение.If path indicates a device that does not support seeking, the CanSeek property on the resulting FileStream is false. Дополнительные сведения см. в разделе CanSeek.For additional information, see CanSeek.

FileShare.Readпо умолчанию для этих FileStream конструкторов FileShare без параметра.FileShare.Read is the default for those FileStream constructors without a FileShare parameter.

Внимание!

При компиляции набора символов с определенным параметром культуры и получении тех же символов с другим параметром культуры символы могут оказаться неинтерпретируемыми и могут вызвать исключение.When you compile a set of characters with a particular cultural setting and retrieve those same characters with a different cultural setting, the characters might not be interpretable, and could cause an exception to be thrown.

Список общих операций с файлами и каталогами см. в разделе Общие задачи ввода-вывода.For a list of common file and directory operations, see Common I/O Tasks.

Безопасность

FileIOPermission
для чтения, записи и добавления в файлы.for reading, writing, and appending to files. Связанные перечисления: Read, Writeи Append.Associated enumerations: Read, Write, and Append.

Дополнительно

FileStream(IntPtr, FileAccess, Boolean) FileStream(IntPtr, FileAccess, Boolean) FileStream(IntPtr, FileAccess, Boolean) FileStream(IntPtr, FileAccess, Boolean)

Предупреждение

Этот API устарел.

Инициализирует новый экземпляр класса FileStream для заданного дескриптора файла, используя указанные разрешения на чтение и запись и владельца экземпляра FileStream.Initializes a new instance of the FileStream class for the specified file handle, with the specified read/write permission and FileStream instance ownership.

public:
 FileStream(IntPtr handle, System::IO::FileAccess access, bool ownsHandle);
[System.Obsolete("Use FileStream(SafeFileHandle handle, FileAccess access) instead")]
[System.Obsolete("This constructor has been deprecated.  Please use new FileStream(SafeFileHandle handle, FileAccess access) instead, and optionally make a new SafeFileHandle with ownsHandle=false if needed.  http://go.microsoft.com/fwlink/?linkid=14202")]
[System.Obsolete("This constructor has been deprecated.  Please use new FileStream(SafeFileHandle handle, FileAccess access) instead, and optionally make a new SafeFileHandle with ownsHandle=false if needed.  https://go.microsoft.com/fwlink/?linkid=14202")]
public FileStream (IntPtr handle, System.IO.FileAccess access, bool ownsHandle);
new System.IO.FileStream : nativeint * System.IO.FileAccess * bool -> System.IO.FileStream
Public Sub New (handle As IntPtr, access As FileAccess, ownsHandle As Boolean)

Параметры

handle
IntPtr IntPtr IntPtr IntPtr

Дескриптор для файла, являющегося текущим объектом FileStream, будет инкапсулирован.A file handle for the file that the current FileStream object will encapsulate.

access
FileAccess FileAccess FileAccess FileAccess

Константа, которая задает свойства CanRead и CanWrite объекта FileStream.A constant that sets the CanRead and CanWrite properties of the FileStream object.

ownsHandle
Boolean Boolean Boolean Boolean

Значение true, если владельцем дескриптора файла будет этот экземпляр FileStream; в противном случае — значение false.true if the file handle will be owned by this FileStream instance; otherwise, false.

Исключения

access не является полем FileAccess.access is not a field of FileAccess.

У вызывающего объекта отсутствует необходимое разрешение.The caller does not have the required permission.

Произошла ошибка ввода-вывода, например ошибка диска.An I/O error, such as a disk error, occurred.

- или --or-

Поток закрыт.The stream has been closed.

Запрошенный access не поддерживается операционной системой для указанного дескриптора файлов, например, когда access равен Write или ReadWrite, а для дескриптора файлов установлен доступ только для чтения.The access requested is not permitted by the operating system for the specified file handle, such as when access is Write or ReadWrite and the file handle is set for read-only access.

Комментарии

FileStream Объекту предоставляется указанный доступ к файлу.The FileStream object is given the specified access to the file. Владельцем маркера будет, как указано.The ownership of the handle will be as specified. Если этот процесс владеет маркером, вызов Close метода также закроет этот маркер, а счетчик маркеров файла будет уменьшен.If this process owns the handle, a call to the Close method will also close the handle and the file's handle count is decremented. FileStream Объекту задается размер буфера по умолчанию 4096 байт.The FileStream object is given the default buffer size of 4096 bytes.

FileStreamПредполагается, что он имеет монопольный контроль над маркером.FileStream assumes that it has exclusive control over the handle. Чтение, запись или поиск в то время FileStream , когда также удерживается маркер, может привести к повреждению данных.Reading, writing, or seeking while a FileStream is also holding a handle could result in data corruption. Для обеспечения безопасности данных вызовите Flush перед использованием маркера и избегайте вызова методов, отличных от Close , после завершения использования маркера.For data safety, call Flush before using the handle, and avoid calling methods other than Close after you are done using the handle.

FileShare.Readпо умолчанию для этих FileStream конструкторов FileShare без параметра.FileShare.Read is the default for those FileStream constructors without a FileShare parameter.

Внимание!

При компиляции набора символов с определенным параметром культуры и получении тех же символов с другим параметром культуры символы могут оказаться неинтерпретируемыми и могут вызвать исключение.When you compile a set of characters with a particular cultural setting and retrieve those same characters with a different cultural setting, the characters might not be interpretable, and could cause an exception to be thrown.

Список общих операций с файлами и каталогами см. в разделе Общие задачи ввода-вывода.For a list of common file and directory operations, see Common I/O Tasks.

Безопасность

FileIOPermission
для чтения, записи и добавления в файлы.for reading, writing, and appending to files. Связанные перечисления: Read, Writeи Append.Associated enumerations: Read, Write, and Append.

Дополнительно

FileStream(SafeFileHandle, FileAccess, Int32) FileStream(SafeFileHandle, FileAccess, Int32) FileStream(SafeFileHandle, FileAccess, Int32) FileStream(SafeFileHandle, FileAccess, Int32)

Инициализирует новый экземпляр класса FileStream для заданного дескриптора файла, используя указанные разрешения на чтение и запись и размер буфера.Initializes a new instance of the FileStream class for the specified file handle, with the specified read/write permission, and buffer size.

public:
 FileStream(Microsoft::Win32::SafeHandles::SafeFileHandle ^ handle, System::IO::FileAccess access, int bufferSize);
public FileStream (Microsoft.Win32.SafeHandles.SafeFileHandle handle, System.IO.FileAccess access, int bufferSize);
new System.IO.FileStream : Microsoft.Win32.SafeHandles.SafeFileHandle * System.IO.FileAccess * int -> System.IO.FileStream
Public Sub New (handle As SafeFileHandle, access As FileAccess, bufferSize As Integer)

Параметры

handle
SafeFileHandle SafeFileHandle SafeFileHandle SafeFileHandle

Дескриптор для файла, являющегося текущим объектом FileStream, будет инкапсулирован.A file handle for the file that the current FileStream object will encapsulate.

access
FileAccess FileAccess FileAccess FileAccess

Константа FileAccess, которая задает свойства CanRead и CanWrite объекта FileStream.A FileAccess constant that sets the CanRead and CanWrite properties of the FileStream object.

bufferSize
Int32 Int32 Int32 Int32

Положительное значение Int32, большее 0, определяющее размер буфера.A positive Int32 value greater than 0 indicating the buffer size. Размер буфера по умолчанию — 4096.The default buffer size is 4096.

Исключения

Параметр handle является недопустимым дескриптором.The handle parameter is an invalid handle.

-или--or- Параметр handle является синхронным дескриптором, но был использован асинхронно.The handle parameter is a synchronous handle and it was used asynchronously.

Параметр bufferSize имеет отрицательное значение.The bufferSize parameter is negative.

Произошла ошибка ввода-вывода, например ошибка диска.An I/O error, such as a disk error, occurred.

- или --or-

Поток закрыт.The stream has been closed.

У вызывающего объекта отсутствует необходимое разрешение.The caller does not have the required permission.

Запрошенный access не поддерживается операционной системой для указанного дескриптора файлов, например, когда access равен Write или ReadWrite, а для дескриптора файлов установлен доступ только для чтения.The access requested is not permitted by the operating system for the specified file handle, such as when access is Write or ReadWrite and the file handle is set for read-only access.

Комментарии

FileStreamПредполагается, что он имеет монопольный контроль над маркером.FileStream assumes that it has exclusive control over the handle. Чтение, запись или поиск в то время FileStream , когда также удерживается маркер, может привести к повреждению данных.Reading, writing, or seeking while a FileStream is also holding a handle could result in data corruption. Для обеспечения безопасности данных вызывайте Flush перед использованием маркера и избегайте вызова любых методов Close , кроме после завершения использования маркера.For data safety, call Flush before using the handle, and avoid calling any methods other than Close after you are done using the handle. Кроме того, перед вызовом этого FileStream конструктора необходимо выполнить чтение и запись в этот обработчик.Alternately, read and write to the handle before calling this FileStream constructor.

FileShare.Readпо умолчанию для этих FileStream конструкторов FileShare без параметра.FileShare.Read is the default for those FileStream constructors without a FileShare parameter.

Внимание!

При компиляции набора символов с определенным параметром культуры и получении тех же символов с другим параметром культуры символы могут оказаться неинтерпретируемыми и могут вызвать исключение.When you compile a set of characters with a particular cultural setting and retrieve those same characters with a different cultural setting, the characters might not be interpretable, and could cause an exception to be thrown.

Список общих операций с файлами и каталогами см. в разделе Общие задачи ввода-вывода.For a list of common file and directory operations, see Common I/O Tasks.

Безопасность

FileIOPermission
для чтения, записи и добавления в файлы.for reading, writing, and appending to files. Связанные перечисления: Read, Writeи Append.Associated enumerations: Read, Write, and Append.

SecurityPermission
разрешение на вызов неуправляемого кода.for permission to call unmanaged code. Связанные перечисления:UnmanagedCodeAssociated enumerations: UnmanagedCode

Дополнительно

FileStream(IntPtr, FileAccess, Boolean, Int32) FileStream(IntPtr, FileAccess, Boolean, Int32) FileStream(IntPtr, FileAccess, Boolean, Int32) FileStream(IntPtr, FileAccess, Boolean, Int32)

Предупреждение

Этот API устарел.

Инициализирует новый экземпляр класса FileStream для заданного дескриптора файла, используя указанные разрешения на чтение и запись, владельца экземпляра FileStream и размер буфера.Initializes a new instance of the FileStream class for the specified file handle, with the specified read/write permission, FileStream instance ownership, and buffer size.

public:
 FileStream(IntPtr handle, System::IO::FileAccess access, bool ownsHandle, int bufferSize);
[System.Obsolete("Use FileStream(SafeFileHandle handle, FileAccess access, int bufferSize) instead")]
[System.Obsolete("This constructor has been deprecated.  Please use new FileStream(SafeFileHandle handle, FileAccess access, int bufferSize) instead, and optionally make a new SafeFileHandle with ownsHandle=false if needed.  http://go.microsoft.com/fwlink/?linkid=14202")]
[System.Obsolete("This constructor has been deprecated.  Please use new FileStream(SafeFileHandle handle, FileAccess access, int bufferSize) instead, and optionally make a new SafeFileHandle with ownsHandle=false if needed.  https://go.microsoft.com/fwlink/?linkid=14202")]
public FileStream (IntPtr handle, System.IO.FileAccess access, bool ownsHandle, int bufferSize);
new System.IO.FileStream : nativeint * System.IO.FileAccess * bool * int -> System.IO.FileStream
Public Sub New (handle As IntPtr, access As FileAccess, ownsHandle As Boolean, bufferSize As Integer)

Параметры

handle
IntPtr IntPtr IntPtr IntPtr

Дескриптор файла для файла, который будет инкапсулироваться с помощью объекта FileStream.A file handle for the file that this FileStream object will encapsulate.

access
FileAccess FileAccess FileAccess FileAccess

Константа, которая задает свойства CanRead и CanWrite объекта FileStream.A constant that sets the CanRead and CanWrite properties of the FileStream object.

ownsHandle
Boolean Boolean Boolean Boolean

Значение true, если владельцем дескриптора файла будет этот экземпляр FileStream; в противном случае — значение false.true if the file handle will be owned by this FileStream instance; otherwise, false.

bufferSize
Int32 Int32 Int32 Int32

Положительное значение Int32, большее 0, определяющее размер буфера.A positive Int32 value greater than 0 indicating the buffer size. Размер буфера по умолчанию — 4096.The default buffer size is 4096.

Исключения

bufferSize является отрицательным значением.bufferSize is negative.

Произошла ошибка ввода-вывода, например ошибка диска.An I/O error, such as a disk error, occurred.

-или--or-

Поток закрыт.The stream has been closed.

У вызывающего объекта отсутствует необходимое разрешение.The caller does not have the required permission.

Запрошенный access не поддерживается операционной системой для указанного дескриптора файлов, например, когда access равен Write или ReadWrite, а для дескриптора файлов установлен доступ только для чтения.The access requested is not permitted by the operating system for the specified file handle, such as when access is Write or ReadWrite and the file handle is set for read-only access.

Комментарии

FileStream Объекту предоставляется указанный доступ к файлу.The FileStream object is given the specified access to the file. Владельцем маркера будет, как указано.The ownership of the handle will be as specified. Если он FileStream владеет маркером, вызов Close метода также закрывает этот обработчик.If this FileStream owns the handle, a call to the Close method will also close the handle. В частности, счетчик маркеров файла уменьшается.In particular, the file's handle count is decremented. FileStream Объекту задается указанный размер буфера.The FileStream object is given the specified buffer size.

FileStreamПредполагается, что он имеет монопольный контроль над маркером.FileStream assumes that it has exclusive control over the handle. Чтение, запись или поиск в то время FileStream , когда также удерживается маркер, может привести к повреждению данных.Reading, writing, or seeking while a FileStream is also holding a handle could result in data corruption. Для обеспечения безопасности данных вызывайте Flush перед использованием маркера и избегайте вызова любых методов Close , кроме после завершения использования маркера.For data safety, call Flush before using the handle, and avoid calling any methods other than Close after you are done using the handle. Кроме того, перед вызовом этого FileStream конструктора необходимо выполнить чтение и запись в этот обработчик.Alternately, read and write to the handle before calling this FileStream constructor.

FileShare.Readпо умолчанию для этих FileStream конструкторов FileShare без параметра.FileShare.Read is the default for those FileStream constructors without a FileShare parameter.

Внимание!

При компиляции набора символов с определенным параметром культуры и получении тех же символов с другим параметром культуры символы могут оказаться неинтерпретируемыми и могут вызвать исключение.When you compile a set of characters with a particular cultural setting and retrieve those same characters with a different cultural setting, the characters might not be interpretable, and could cause an exception to be thrown.

Список общих операций с файлами и каталогами см. в разделе Общие задачи ввода-вывода.For a list of common file and directory operations, see Common I/O Tasks.

Безопасность

FileIOPermission
для чтения, записи и добавления в файлы.for reading, writing, and appending to files. Связанные перечисления: Read, Writeи Append.Associated enumerations: Read, Write, and Append.

Дополнительно

FileStream(String, FileMode) FileStream(String, FileMode) FileStream(String, FileMode) FileStream(String, FileMode)

Инициализирует новый экземпляр класса FileStream указанным путем и режимом создания.Initializes a new instance of the FileStream class with the specified path and creation mode.

public:
 FileStream(System::String ^ path, System::IO::FileMode mode);
public FileStream (string path, System.IO.FileMode mode);
new System.IO.FileStream : string * System.IO.FileMode -> System.IO.FileStream
Public Sub New (path As String, mode As FileMode)

Параметры

path
String String String String

Абсолютный или относительный путь к файлу, который будет инкапсулироваться объектом FileStream.A relative or absolute path for the file that the current FileStream object will encapsulate.

mode
FileMode FileMode FileMode FileMode

Константа, определяющая способ открытия или создания файла.A constant that determines how to open or create the file.

Исключения

path представляет собой пустую строку (""), содержащую только пробел или хотя бы один недопустимый символ.path is an empty string (""), contains only white space, or contains one or more invalid characters.

-или--or- path ссылается на устройство нефайлового типа, например "con:", "com1:", "lpt1:" и т. д., в среде NTFS.path refers to a non-file device, such as "con:", "com1:", "lpt1:", etc. in an NTFS environment.

path ссылается на устройство не файлового типа, например "con:", "com1:", "lpt1:" и т. д., в среде, отличной от NTFS.path refers to a non-file device, such as "con:", "com1:", "lpt1:", etc. in a non-NTFS environment.

У вызывающего объекта отсутствует необходимое разрешение.The caller does not have the required permission.

Не удается найти файл, например когда mode равно FileMode.Truncate или FileMode.Open, и файл, заданный параметром path, не существует.The file cannot be found, such as when mode is FileMode.Truncate or FileMode.Open, and the file specified by path does not exist. Файл должен уже существовать в этих режимах.The file must already exist in these modes.

Параметр path указывает файл, доступный только для чтения.path specifies a file that is read-only.

Произошла ошибка ввода-вывода, например задание параметра FileMode.CreateNew, когда файл, заданный параметром path, уже существует.An I/O error, such as specifying FileMode.CreateNew when the file specified by path already exists, occurred.

- или --or- Поток закрыт.The stream has been closed.

Указан недопустимый путь (например, он ведет на несопоставленный диск).The specified path is invalid, such as being on an unmapped drive.

Указанный путь, имя файла или оба значения превышают максимальную длину, заданную в системе.The specified path, file name, or both exceed the system-defined maximum length.

Параметр mode содержит недопустимое значение.mode contains an invalid value.

Примеры

В следующем примере кода показано, как записать данные в файл, байт по байтам, а затем проверить, правильно ли записаны данные.The following code example shows how to write data to a file, byte by byte, and then verify that the data was written correctly.

using namespace System;
using namespace System::IO;
int main()
{
   String^ fileName =  "Test@##@.dat";
   
   // Create random data to write to the file.
   array<Byte>^dataArray = gcnew array<Byte>(100000);
   (gcnew Random)->NextBytes( dataArray );
   FileStream^ fileStream = gcnew FileStream( fileName,FileMode::Create );
   try
   {
      
      // Write the data to the file, byte by byte.
      for ( int i = 0; i < dataArray->Length; i++ )
      {
         fileStream->WriteByte( dataArray[ i ] );

      }
      
      // Set the stream position to the beginning of the file.
      fileStream->Seek( 0, SeekOrigin::Begin );
      
      // Read and verify the data.
      for ( int i = 0; i < fileStream->Length; i++ )
      {
         if ( dataArray[ i ] != fileStream->ReadByte() )
         {
            Console::WriteLine( "Error writing data." );
            return  -1;
         }

      }
      Console::WriteLine( "The data was written to {0} "
      "and verified.", fileStream->Name );
   }
   finally
   {
      fileStream->Close();
   }

}

using System;
using System.IO;

class FStream
{
    static void Main()
    {
        const string fileName = "Test#@@#.dat";

        // Create random data to write to the file.
        byte[] dataArray = new byte[100000];
        new Random().NextBytes(dataArray);

        using(FileStream  
            fileStream = new FileStream(fileName, FileMode.Create))
        {
            // Write the data to the file, byte by byte.
            for(int i = 0; i < dataArray.Length; i++)
            {
                fileStream.WriteByte(dataArray[i]);
            }

            // Set the stream position to the beginning of the file.
            fileStream.Seek(0, SeekOrigin.Begin);

            // Read and verify the data.
            for(int i = 0; i < fileStream.Length; i++)
            {
                if(dataArray[i] != fileStream.ReadByte())
                {
                    Console.WriteLine("Error writing data.");
                    return;
                }
            }
            Console.WriteLine("The data was written to {0} " +
                "and verified.", fileStream.Name);
        }
    }
}
Imports Microsoft.VisualBasic
Imports System
Imports System.IO
Imports System.Text

Class FStream

    Shared Sub Main()

        Const fileName As String = "Test#@@#.dat"

        ' Create random data to write to the file.
        Dim dataArray(100000) As Byte
        Dim randomGenerator As New Random()
        randomGenerator.NextBytes(dataArray)

        Dim fileStream As FileStream = _
            new FileStream(fileName, FileMode.Create)
        Try

            ' Write the data to the file, byte by byte.
            For i As Integer = 0 To dataArray.Length - 1
                fileStream.WriteByte(dataArray(i))
            Next i

            ' Set the stream position to the beginning of the stream.
            fileStream.Seek(0, SeekOrigin.Begin)

            ' Read and verify the data.
            For i As Integer = 0 To _
                CType(fileStream.Length, Integer) - 1

                If dataArray(i) <> fileStream.ReadByte() Then
                    Console.WriteLine("Error writing data.")
                    Return
                End If
            Next i
            Console.WriteLine("The data was written to {0} " & _
                "and verified.", fileStream.Name)
        Finally
            fileStream.Close()
        End Try
    
    End Sub
End Class

Комментарии

.NET Framework не поддерживает прямой доступ к физическим дискам по путям, которые являются именами устройств, например "\\.\PHYSICALDRIVE0".The .NET Framework does not support direct access to physical disks through paths that are device names, such as "\\.\PHYSICALDRIVE0 ".

path Параметр может быть именем файла, включая файл в общей папке UNC.The path parameter can be a file name, including a file on a Universal Naming Convention (UNC) share.

Конструктор получает доступ на чтение и запись к файлу, и он открывает общий доступ на чтение (т. е. запросы на открытие файла для записи этим или другим процессом завершатся ошибкой до тех пор, пока FileStream объект не будет закрыт, но попытки чтения будут успешными).The constructor is given read/write access to the file, and it is opened sharing Read access (that is, requests to open the file for writing by this or another process will fail until the FileStream object has been closed, but read attempts will succeed).

Этот конструктор нельзя использовать для открытия файлов, предназначенных только для чтения. Вместо этого необходимо использовать конструктор, принимающий FileAccess параметр со значением. FileAccess.ReadYou cannot use this constructor to open read-only files; instead, you must use a constructor that accepts a FileAccess parameter with the value set to FileAccess.Read.

Размер буфера задается как размер по умолчанию 4096 байт (4 КБ).The buffer size is set to the default size of 4096 bytes (4 KB).

Примечание

pathне обязательно должен быть файлом, хранящимся на диске; Это может быть любая часть системы, которая поддерживает доступ через потоки.path is not required to be a file stored on disk; it can be any part of a system that supports access through streams. Например, в зависимости от системы этот класс может обращаться к физическому устройству.For example, depending on the system, this class can access a physical device.

CanSeekпредназначен true для всех FileStream объектов, инкапсулирующих файлы.CanSeek is true for all FileStream objects that encapsulate files. Если path указывает на устройство, которое не поддерживает поиск CanSeek , свойство в результате FileStream имеет falseзначение.If path indicates a device that does not support seeking, the CanSeek property on the resulting FileStream is false. Дополнительные сведения см. в разделе CanSeek.For additional information, see CanSeek.

FileShare.Readпо умолчанию для этих FileStream конструкторов FileShare без параметра.FileShare.Read is the default for those FileStream constructors without a FileShare parameter.

Для конструкторов без FileAccess параметра, mode если параметр имеет значение Append, Write то доступ по умолчанию является.For constructors without a FileAccess parameter, if the mode parameter is set to Append, Write is the default access. В противном случае для ReadWriteдоступа устанавливается значение.Otherwise, the access is set to ReadWrite.

Внимание!

При компиляции набора символов с определенным параметром культуры и получении тех же символов с другим параметром культуры символы могут оказаться неинтерпретируемыми и могут вызвать исключение.When you compile a set of characters with a particular cultural setting and retrieve those same characters with a different cultural setting, the characters might not be interpretable, and could cause an exception to be thrown.

Список общих операций с файлами и каталогами см. в разделе Общие задачи ввода-вывода.For a list of common file and directory operations, see Common I/O Tasks.

Безопасность

FileIOPermission
для чтения, записи и добавления в файлы.for reading, writing, and appending to files. Связанные перечисления: Read, Writeи Append.Associated enumerations: Read, Write, and Append.

Дополнительно

FileStream(IntPtr, FileAccess) FileStream(IntPtr, FileAccess) FileStream(IntPtr, FileAccess) FileStream(IntPtr, FileAccess)

Предупреждение

Этот API устарел.

Инициализирует новый экземпляр класса FileStream для заданного дескриптора файла, используя указанные разрешения на чтение и запись.Initializes a new instance of the FileStream class for the specified file handle, with the specified read/write permission.

public:
 FileStream(IntPtr handle, System::IO::FileAccess access);
[System.Obsolete("Use FileStream(SafeFileHandle handle, FileAccess access) instead")]
[System.Obsolete("This constructor has been deprecated.  Please use new FileStream(SafeFileHandle handle, FileAccess access) instead.  http://go.microsoft.com/fwlink/?linkid=14202")]
[System.Obsolete("This constructor has been deprecated.  Please use new FileStream(SafeFileHandle handle, FileAccess access) instead.  https://go.microsoft.com/fwlink/?linkid=14202")]
public FileStream (IntPtr handle, System.IO.FileAccess access);
new System.IO.FileStream : nativeint * System.IO.FileAccess -> System.IO.FileStream
Public Sub New (handle As IntPtr, access As FileAccess)

Параметры

handle
IntPtr IntPtr IntPtr IntPtr

Дескриптор для файла, являющегося текущим объектом FileStream, будет инкапсулирован.A file handle for the file that the current FileStream object will encapsulate.

access
FileAccess FileAccess FileAccess FileAccess

Константа, которая задает свойства CanRead и CanWrite объекта FileStream.A constant that sets the CanRead and CanWrite properties of the FileStream object.

Исключения

access не является полем FileAccess.access is not a field of FileAccess.

У вызывающего объекта отсутствует необходимое разрешение.The caller does not have the required permission.

Произошла ошибка ввода-вывода, например ошибка диска.An I/O error, such as a disk error, occurred.

-или--or-

Поток закрыт.The stream has been closed.

Запрошенный access не поддерживается операционной системой для указанного дескриптора файлов, например, когда access равен Write или ReadWrite, а для дескриптора файлов установлен доступ только для чтения.The access requested is not permitted by the operating system for the specified file handle, such as when access is Write or ReadWrite and the file handle is set for read-only access.

Комментарии

Когда Close вызывается метод, маркер также закрывается, а счетчик маркеров файла уменьшается.When Close is called, the handle is also closed and the file's handle count is decremented.

FileStreamПредполагается, что он имеет монопольный контроль над маркером.FileStream assumes that it has exclusive control over the handle. Чтение, запись или поиск в то время FileStream , когда также удерживается маркер, может привести к повреждению данных.Reading, writing, or seeking while a FileStream is also holding a handle could result in data corruption. Для обеспечения безопасности данных вызывайте Flush перед использованием маркера и избегайте вызова любых методов Close , кроме после завершения использования маркера.For data safety, call Flush before using the handle, and avoid calling any methods other than Close after you are done using the handle.

Внимание!

При компиляции набора символов с определенным параметром культуры и получении тех же символов с другим параметром культуры символы могут оказаться неинтерпретируемыми и могут вызвать исключение.When you compile a set of characters with a particular cultural setting and retrieve those same characters with a different cultural setting, the characters might not be interpretable, and could cause an exception to be thrown.

FileShare.Readпо умолчанию для этих FileStream конструкторов FileShare без параметра.FileShare.Read is the default for those FileStream constructors without a FileShare parameter.

Список общих операций с файлами и каталогами см. в разделе Общие задачи ввода-вывода.For a list of common file and directory operations, see Common I/O Tasks.

Безопасность

FileIOPermission
для чтения, записи и добавления в файлы.for reading, writing, and appending to files. Связанные перечисления: Read, Writeи Append.Associated enumerations: Read, Write, and Append.

Дополнительно

Применяется к