TextReader.ReadAsync Metoda

Definicja

Przeciążenia

ReadAsync(Char[], Int32, Int32)

Odczytuje określoną maksymalną liczbę znaków z bieżącego czytnika tekstu asynchronicznie i zapisuje dane w buforze, rozpoczynając od określonego indeksu.Reads a specified maximum number of characters from the current text reader asynchronously and writes the data to a buffer, beginning at the specified index.

ReadAsync(Memory<Char>, CancellationToken)

Asynchronicznie odczytuje znaki z bieżącego strumienia do bloku pamięci.Asynchronously reads the characters from the current stream into a memory block.

ReadAsync(Char[], Int32, Int32)

Odczytuje określoną maksymalną liczbę znaków z bieżącego czytnika tekstu asynchronicznie i zapisuje dane w buforze, rozpoczynając od określonego indeksu.Reads a specified maximum number of characters from the current text reader asynchronously and writes the data to a buffer, beginning at the specified index.

public:
 virtual System::Threading::Tasks::Task<int> ^ ReadAsync(cli::array <char> ^ buffer, int index, int count);
public virtual System.Threading.Tasks.Task<int> ReadAsync (char[] buffer, int index, int count);
[System.Runtime.InteropServices.ComVisible(false)]
public virtual System.Threading.Tasks.Task<int> ReadAsync (char[] buffer, int index, int count);
abstract member ReadAsync : char[] * int * int -> System.Threading.Tasks.Task<int>
override this.ReadAsync : char[] * int * int -> System.Threading.Tasks.Task<int>
[<System.Runtime.InteropServices.ComVisible(false)>]
abstract member ReadAsync : char[] * int * int -> System.Threading.Tasks.Task<int>
override this.ReadAsync : char[] * int * int -> System.Threading.Tasks.Task<int>
Public Overridable Function ReadAsync (buffer As Char(), index As Integer, count As Integer) As Task(Of Integer)

Parametry

buffer
Char[]

Gdy ta metoda zwraca, zawiera określoną tablicę znaków z wartościami między index i ( index + count -1) zastąpione przez znaki odczytane z bieżącego źródła.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.

index
Int32

Położenie, w buffer którym rozpocznie się zapisywanie.The position in buffer at which to begin writing.

count
Int32

Maksymalna liczba znaków do odczytania.The maximum number of characters to read. Jeśli koniec tekstu zostanie osiągnięty przed przeczytaniem określonej liczby znaków do buforu, bieżąca metoda zwraca.If the end of the text is reached before the specified number of characters is read into the buffer, the current method returns.

Zwraca

Task<Int32>

Zadanie, które reprezentuje asynchroniczną operację odczytu.A task that represents the asynchronous read operation. Wartość TResult parametru zawiera łączną liczbę bajtów odczytywanych w buforze.The value of the TResult parameter contains the total number of bytes read into the buffer. Wartość wynikowa może być mniejsza niż liczba żądanych bajtów, jeśli liczba aktualnie dostępnych bajtów jest mniejsza niż żądana liczba, lub może być równa 0 (zero), jeśli osiągnięto koniec tekstu.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 text has been reached.

Atrybuty

Wyjątki

buffer to null.buffer is null.

index lub count jest ujemna.index or count is negative.

Suma index i count jest większa niż długość buforu.The sum of index and count is larger than the buffer length.

Czytnik tekstu został usunięty.The text reader has been disposed.

Czytnik jest obecnie używany przez poprzednią operację odczytu.The reader is currently in use by a previous read operation.

Uwagi

Zadanie kończy się po odczytaniu liczby znaków określonej przez count parametr lub osiągnięciu końca pliku.The task completes after either the number of characters specified by the count parameter are read or the end of the file is reached.

TextReaderKlasa jest klasą abstrakcyjną.The TextReader class is an abstract class. W związku z tym, nie tworzy się obiektu w kodzie.Therefore, you do not instantiate it in your code. Przykład użycia ReadAsync metody można znaleźć w StreamReader.ReadAsync metodzie.For an example of using the ReadAsync method, see the StreamReader.ReadAsync method.

Zobacz też

Dotyczy

ReadAsync(Memory<Char>, CancellationToken)

Asynchronicznie odczytuje znaki z bieżącego strumienia do bloku pamięci.Asynchronously reads the characters from the current stream into a memory block.

public virtual System.Threading.Tasks.ValueTask<int> ReadAsync (Memory<char> buffer, System.Threading.CancellationToken cancellationToken = default);
abstract member ReadAsync : Memory<char> * System.Threading.CancellationToken -> System.Threading.Tasks.ValueTask<int>
override this.ReadAsync : Memory<char> * System.Threading.CancellationToken -> System.Threading.Tasks.ValueTask<int>
Public Overridable Function ReadAsync (buffer As Memory(Of Char), Optional cancellationToken As CancellationToken = Nothing) As ValueTask(Of Integer)

Parametry

buffer
Memory<Char>

Gdy ta metoda zwraca, zawiera określony blok pamięci znaków zastępowanych przez znaki odczytywane z bieżącego źródła.When this method returns, contains the specified memory block of characters replaced by the characters read from the current source.

cancellationToken
CancellationToken

Token do monitorowania żądań anulowania.The token to monitor for cancellation requests. Wartość domyślna to None.The default value is None.

Zwraca

ValueTask<Int32>

Zadanie wartości, które reprezentuje asynchroniczną operację odczytu.A value task that represents the asynchronous read operation. Wartość parametru typu zawiera liczbę znaków, które zostały odczytane lub 0, jeśli na końcu strumienia i żadne dane nie zostały odczytane.The value of the type parameter contains the number of characters that have been read, or 0 if at the end of the stream and no data was read. Liczba będzie mniejsza lub równa buffer długości, w zależności od tego, czy dane są dostępne w strumieniu.The number will be less than or equal to the buffer length, depending on whether the data is available within the stream.

Dotyczy