StreamReader.ReadAsync Method (Char(), Int32, Int32)
Reads a specified maximum number of characters from the current stream asynchronously and writes the data to a buffer, beginning at the specified index.
Assembly: mscorlib (in mscorlib.dll)
<ComVisibleAttribute(False)> <HostProtectionAttribute(SecurityAction.LinkDemand, ExternalThreading := True)> Public Overrides Function ReadAsync ( buffer As Char(), index As Integer, count As Integer ) As Task(Of Integer)
When this method returns, contains the specified character array with the values between index and (index + count - 1) replaced by the characters read from the current source.
The position in buffer at which to begin writing.
The maximum number of characters to read. If the end of the stream is reached before the specified number of characters is written into the buffer, the current method returns.
Return ValueType: System.Threading.Tasks.Task(Of Int32)
A task that represents the asynchronous read operation. The value of the TResult parameter contains the total number of bytes read into the buffer. The result value can be less than the number of bytes requested if the number of bytes currently available is less than the requested number, or it can be 0 (zero) if the end of the stream has been reached.
buffer is null.
index or count is negative.
The sum of index and count is larger than the buffer length.
The stream has been disposed.
The reader is currently in use by a previous read operation.
The task completes after either the number of characters specified by the count parameter are read or the end of the stream is reached.
The following example shows how to read all the characters in a file by using the StringBuilder class.method. It checks whether each character is a letter, digit, or white space before adding the character to an instance of the
Imports System.Text Imports System.IO Class MainWindow Private Async Sub Button_Click_1(sender As Object, e As RoutedEventArgs) Dim filename As String = "C:\Example\existingfile.txt" Dim result() As Char Dim builder As StringBuilder = New StringBuilder() Using reader As StreamReader = File.OpenText(filename) ReDim result(reader.BaseStream.Length) Await reader.ReadAsync(result, 0, reader.BaseStream.Length) End Using For Each c As Char In result If (Char.IsLetterOrDigit(c) Or Char.IsWhiteSpace(c)) Then builder.Append(c) End If Next FileOutput.Text = builder.ToString() End Sub End Class
Available since 8
Available since 4.5
Portable Class Library
Supported in: portable .NET platforms
Windows Phone Silverlight
Available since 8.0
Available since 8.1