WindowsRuntimeStreamExtensions.AsStreamForRead Método

Definição

Sobrecargas

Name Description
AsStreamForRead(IInputStream)

Converte um fluxo de entrada no Windows Runtime num fluxo gerido nas aplicações .NET for Windows Store.

AsStreamForRead(IInputStream, Int32)

Converte um fluxo de entrada no Windows Runtime num fluxo gerido no .NET para aplicações da Loja Windows 8.x usando o tamanho do buffer especificado.

AsStreamForRead(IInputStream)

Importante

Esta API não está em conformidade com CLS.

Converte um fluxo de entrada no Windows Runtime num fluxo gerido nas aplicações .NET for Windows Store.

public:
[System::Runtime::CompilerServices::Extension]
 static System::IO::Stream ^ AsStreamForRead(Windows::Storage::Streams::IInputStream ^ windowsRuntimeStream);
[System.CLSCompliant(false)]
public static System.IO.Stream AsStreamForRead(this Windows.Storage.Streams.IInputStream windowsRuntimeStream);
[<System.CLSCompliant(false)>]
static member AsStreamForRead : Windows.Storage.Streams.IInputStream -> System.IO.Stream
<Extension()>
Public Function AsStreamForRead (windowsRuntimeStream As IInputStream) As Stream

Parâmetros

windowsRuntimeStream
Windows.Storage.Streams.IInputStream

O objeto Windows Runtime Windows.Storage.Streams.IInputStream a converter.

Devoluções

O riacho convertido.

Atributos

Exceções

windowsRuntimeStream é null.

Exemplos

O exemplo seguinte mostra como usar os métodos AsStreamForWrite e AsStreamForRead para converter um fluxo gerido para e a partir de um fluxo no Windows Runtime.

using System;
using System.IO;
using Windows.Storage;
using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls;

namespace ExampleApplication
{
    public sealed partial class BlankPage : Page
    {
        public BlankPage()
        {
            this.InitializeComponent();
        }

        private async void CreateButton_Click(object sender, RoutedEventArgs e)
        {
            StorageFile newFile = await ApplicationData.Current.LocalFolder.CreateFileAsync("testfile.txt");
            var streamNewFile = await newFile.OpenAsync(FileAccessMode.ReadWrite);

            using (var outputNewFile = streamNewFile.GetOutputStreamAt(0))
            {
                using (StreamWriter writer = new StreamWriter(outputNewFile.AsStreamForWrite()))
                {
                    await writer.WriteLineAsync("content for new file");
                    await writer.WriteLineAsync(UserText.Text);
                }
            }
        }

        private async void VerifyButton_Click(object sender, RoutedEventArgs e)
        {
            StorageFile openedFile = await ApplicationData.Current.LocalFolder.GetFileAsync("testfile.txt");
            var streamOpenedFile = await openedFile.OpenAsync(FileAccessMode.Read);

            using (var inputOpenedFile = streamOpenedFile.GetInputStreamAt(0))
            {
                using (StreamReader reader = new StreamReader(inputOpenedFile.AsStreamForRead()))
                {
                    Results.Text = await reader.ReadToEndAsync();
                }
            }
        }
    }
}
Imports System.IO
Imports Windows.Storage

NotInheritable Public Class BlankPage
    Inherits Page

    Private Async Sub CreateButton_Click(sender As Object, e As RoutedEventArgs)
        Dim newFile As StorageFile = Await ApplicationData.Current.LocalFolder.CreateFileAsync("testfile.txt")
        Dim streamNewFile = Await newFile.OpenAsync(FileAccessMode.ReadWrite)

        Using outputNewFile = streamNewFile.GetOutputStreamAt(0)
            Using writer As StreamWriter = New StreamWriter(outputNewFile.AsStreamForWrite())
                Await writer.WriteLineAsync("content for new file")
                Await writer.WriteLineAsync(UserText.Text)
            End Using
        End Using
    End Sub

    Private Async Sub VerifyButton_Click(sender As Object, e As RoutedEventArgs)
        Dim openedFile As StorageFile = Await ApplicationData.Current.LocalFolder.GetFileAsync("testfile.txt")
        Dim streamOpenedFile = Await openedFile.OpenAsync(FileAccessMode.Read)

        Using inputOpenedFile = streamOpenedFile.GetInputStreamAt(0)

            Using reader As StreamReader = New StreamReader(inputOpenedFile.AsStreamForRead())
                Results.Text = Await reader.ReadToEndAsync()
            End Using
        End Using
    End Sub
End Class

Aqui está o código XAML associado ao exemplo anterior.

<Page
    x:Class="ExampleApplication.BlankPage"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    xmlns:local="using:ExampleApplication"
    xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
    xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
    mc:Ignorable="d">

    <StackPanel Background="{StaticResource ApplicationPageBackgroundBrush}" VerticalAlignment="Center" HorizontalAlignment="Center">
        <TextBlock Text="Provide text to write to file:"></TextBlock>
        <TextBox Name="UserText" Width="400"></TextBox>
        <Button Name="CreateButton" Content="Create File" Click="CreateButton_Click"></Button>
        <Button Name="VerifyButton" Content="Verify Contents" Click="VerifyButton_Click"></Button>
        <TextBlock Name="Results"></TextBlock>
    </StackPanel>
</Page>

Observações

Note

Em Visual Basic e C#, pode chamar este método como método de instância em qualquer objeto do tipo Stream. Quando usar a sintaxe do método de instância para chamar este método, omita o primeiro parâmetro. Para mais informações, consulte Métodos de Extensão (Visual Basic) ou Métodos de Extensão (Guia de Programação C#).

Um tamanho padrão de buffer de 16.384 bytes é usado ao converter o fluxo. Para especificar um tamanho de buffer diferente, use a AsStreamForRead(IInputStream, Int32) sobrecarga.

Aplica-se a

AsStreamForRead(IInputStream, Int32)

Importante

Esta API não está em conformidade com CLS.

Converte um fluxo de entrada no Windows Runtime num fluxo gerido no .NET para aplicações da Loja Windows 8.x usando o tamanho do buffer especificado.

public:
[System::Runtime::CompilerServices::Extension]
 static System::IO::Stream ^ AsStreamForRead(Windows::Storage::Streams::IInputStream ^ windowsRuntimeStream, int bufferSize);
[System.CLSCompliant(false)]
public static System.IO.Stream AsStreamForRead(this Windows.Storage.Streams.IInputStream windowsRuntimeStream, int bufferSize);
[<System.CLSCompliant(false)>]
static member AsStreamForRead : Windows.Storage.Streams.IInputStream * int -> System.IO.Stream
<Extension()>
Public Function AsStreamForRead (windowsRuntimeStream As IInputStream, bufferSize As Integer) As Stream

Parâmetros

windowsRuntimeStream
Windows.Storage.Streams.IInputStream

O objeto Windows Runtime Windows.Storage.Streams.IInputStream a converter.

bufferSize
Int32

O tamanho, em bytes, do buffer. Este valor não pode ser negativo, mas pode ser 0 (zero) para desativar o buffering.

Devoluções

O riacho convertido.

Atributos

Exceções

windowsRuntimeStream é null.

bufferSize é negativo.

Observações

Note

Em Visual Basic e C#, pode chamar este método como método de instância em qualquer objeto do tipo Stream. Quando usar a sintaxe do método de instância para chamar este método, omita o primeiro parâmetro. Para mais informações, consulte Métodos de Extensão (Visual Basic) ou Métodos de Extensão (Guia de Programação C#).

Utiliza-se este método para especificar o tamanho do buffer ao converter o fluxo. Para usar o tamanho padrão do buffer de 16.384 bytes, use a AsStreamForRead(IInputStream) sobrecarga.

Na maioria das situações, o buffering melhora o desempenho das operações de fluxo. Podes desativar o buffering definindo bufferSize para zero, mas só deves fazê-lo quando tiveres a certeza de que desativar o buffering é apropriado para a tua situação.

Aplica-se a