博客
关于我
实例41文件流读写
阅读量:179 次
发布时间:2019-02-28

本文共 2097 字,大约阅读时间需要 6 分钟。

FileStream 类

命名空间:

程序集:mscorlib.dll

为文件提供 ,既支持同步读写操作,也支持异步读写操作。

注解

使用  类可对文件系统中的文件进行读取、写入、打开和关闭,还可以操作其他与文件相关的操作系统句柄,包括管道、标准输入和标准输出。 您可以使用 、、和  方法来执行同步操作,或使用 、、和  方法执行异步操作。 使用异步方法来执行占用大量资源的文件操作,而不会阻止主线程。 在 Windows 8.x 应用商店 应用或 桌面 应用中一个耗时的流操作可能阻塞 UI 线程并让您的应用看起来好像不工作时,这种性能的考虑就显得尤为重要了。  缓冲输入和输出以提高性能。

 重要

此类型实现  接口。 在使用完类型后,您应直接或间接释放类型。 若要直接释放类型,请在 try/ 块中调用其 catch 方法。 若要间接释放类型,请使用 using(在 C# 中)或 Using(在 Visual Basic 中)等语言构造。 有关详细信息,请参阅  接口主题中的“使用实现 IDisposable 的对象”一节。

 属性检测文件句柄是否已异步打开。 使用具有 isAsyncuseAsync或 options 参数的构造函数创建  类的实例时,可以指定此值。 如果 true属性,则流将使用重叠的 i/o 以异步方式执行文件操作。 不过,不必 true  属性来调用 、或  方法。 当 false  属性并且调用异步读写操作时,UI 线程仍不会被阻止,但实际的 i/o 操作将以同步方式执行。

 方法支持对文件进行随机访问。  允许将读/写位置移动到文件中的任何位置。 这是通过字节偏移量引用点参数实现的。 字节偏移量是相对于查找引用点的,它可以是基础文件的开头、当前位置或末尾,由  枚举的三个成员表示。

      使用这个类时,需要先定义一个该类的实例,即一个对象,并通过使用这个对象的属性和方法对文件进行读写操作。文件流对象定义形式如下:

    Dim  对象  As FileStream
    对象=NewFileStream (path, mode, access, share, buffersize, isAsync)

    文件流构造函数各参数值的含义如下:

  • path,文件路径名:
  • Mode,FileMode枚举类犁,文件打开方式;
  • Access,FileAccess枚举类型,决定FileStream对象对文件如何访问;
  • Share,FileShare枚举类型,文件共享方式;
  • buffersize,所需缓冲区人小;
  • isAsync,同步或异步输入输出。

    FileStream为的构造函数可被多次重载,在创建新的文件流对象时,可以只给出前面几个参数。

    FileMode枚举类型的值包括:

  • Append,向文件尾添加;
  • Create,创建文件,可町覆盖;
  • CrcateNew,创建新文件;

Open,打开文件:

  • OpenOrCreate,打开文件,如果不存在则创建。

    FileAccess枚举类型的值包括:

  • Read,对文件的访问是读取文件;
  • ReadWrite,读写文件;
  • Write,写文件。

    FileShare枚举类型的值包括:

  • Read,允许其他用户对文件的读取访问;
  • ReadWrite,允许其他用户对文件的读写访问;
  • Write,允许其他用户对文件的写访问。

       定义文件流对象以后,可以通过Read方法实现文件内容的读取,通过Write方法实现文件内容的改写。Read和Write方法都有三个参数,第一个参数为一个数组,表示从文件读出的数据或向文件写入的数组;第二个参数表示读或写的起始位置;第三个参数表示本操作应该处理几个数据。

    文件关闭使用Close方法。

Module Module1

    Sub Main()

        testStream()

        Console.Read()

    End Sub

    Private Sub testStream()

        Dim DataWrite(10) As Byte
        Dim DataRead(10) As Byte
        Dim i As Integer
        For i = 0 To 10
            DataWrite(i) = i * 3
        Next

        Dim testFs As IO.FileStream

        testFs = New IO.FileStream("J:\test\Stream.txt", IO.FileMode.OpenOrCreate, IO.FileAccess.Write)
        testFs.Write(DataWrite, 0, 11)
        testFs.Close()

        testFs = New IO.FileStream("J:\test\Stream.txt", IO.FileMode.Open, IO.FileAccess.Read)

        testFs.Read(DataRead, 0, 11)
        testFs.Close()

        For i = 0 To 10

            Console.WriteLine(DataRead(i))
        Next
    End Sub
End Module
 

转载地址:http://kygn.baihongyu.com/

你可能感兴趣的文章
MySQL中group by 与 order by 一起使用排序问题
查看>>
mysql中having的用法
查看>>
MySQL中interactive_timeout和wait_timeout的区别
查看>>
mysql中int、bigint、smallint 和 tinyint的区别、char和varchar的区别详细介绍
查看>>
mysql中json_extract的使用方法
查看>>
mysql中json_extract的使用方法
查看>>
mysql中kill掉所有锁表的进程
查看>>
mysql中like % %模糊查询
查看>>
MySql中mvcc学习记录
查看>>
mysql中null和空字符串的区别与问题!
查看>>
MySQL中ON DUPLICATE KEY UPDATE的介绍与使用、批量更新、存在即更新不存在则插入
查看>>
MYSQL中TINYINT的取值范围
查看>>
MySQL中UPDATE语句的神奇技巧,让你操作数据库如虎添翼!
查看>>
Mysql中varchar类型数字排序不对踩坑记录
查看>>
MySQL中一条SQL语句到底是如何执行的呢?
查看>>
MySQL中你必须知道的10件事,1.5万字!
查看>>
MySQL中使用IN()查询到底走不走索引?
查看>>
Mysql中使用存储过程插入decimal和时间数据递增的模拟数据
查看>>
MySql中关于geometry类型的数据_空的时候如何插入处理_需用null_空字符串插入会报错_Cannot get geometry object from dat---MySql工作笔记003
查看>>
mysql中出现Incorrect DECIMAL value: '0' for column '' at row -1错误解决方案
查看>>