FileStream Constructor (IntPtr, FileAccess, Boolean)


The .NET API Reference documentation has a new home. Visit the .NET API Browser on to see the new experience.

Note: This API is now obsolete.

Initializes a new instance of the FileStream class for the specified file handle, with the specified read/write permission and FileStream instance ownership.

Namespace:   System.IO
Assembly:  mscorlib (in mscorlib.dll)

[<ObsoleteAttribute("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.")>]
new : 
        handle:nativeint *
        access:FileAccess *
        ownsHandle:bool -> FileStream


Type: System.IntPtr

A file handle for the file that the current FileStream object will encapsulate.

Type: System.IO.FileAccess

A constant that sets the CanRead and CanWrite properties of the FileStream object.

Type: System.Boolean

true if the file handle will be owned by this FileStream instance; otherwise, false.

Exception Condition

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.


The stream has been closed.


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.

The FileStream object is given the specified access to the file. The ownership of the handle will be as specified. 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. The FileStream object is given the default buffer size of 4096 bytes.

FileStream assumes that it has exclusive control over the handle. Reading, writing, or seeking while a FileStream is also holding a handle could result in data corruption. 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 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.


for reading, writing, and appending to files. Associated enumerations: FileIOPermissionAccess.Read, FileIOPermissionAccess.Write, and FileIOPermissionAccess.Append.

.NET Framework
Available since 1.1
Return to top