Process.BeginOutputReadLine 方法
定义
重要
一些信息与预发行产品相关,相应产品在发行之前可能会进行重大修改。 对于此处提供的信息,Microsoft 不作任何明示或暗示的担保。
开始对应用程序的重定向 StandardOutput 流执行异步读取操作。
public:
void BeginOutputReadLine();
public void BeginOutputReadLine();
[System.Runtime.InteropServices.ComVisible(false)]
public void BeginOutputReadLine();
member this.BeginOutputReadLine : unit -> unit
[<System.Runtime.InteropServices.ComVisible(false)>]
member this.BeginOutputReadLine : unit -> unit
Public Sub BeginOutputReadLine ()
- 属性
例外
属性 RedirectStandardOutput 为 false.
-或-
异步读取操作已在流中 StandardOutput 进行。
-或-
该 StandardOutput 流已被同步读取操作使用。
示例
以下示例演示如何对命令的StandardOutputsort重定向流执行异步读取操作。 该 sort 命令是一个控制台应用程序,用于读取和排序文本输入。
该示例为 SortOutputHandler 事件处理程序创建一个事件委托,并将其与事件 OutputDataReceived 相关联。 事件处理程序从重定向 StandardOutput 的流接收文本行,设置文本的格式,并将文本写入屏幕。
// Define the namespaces used by this sample.
using System;
using System.Text;
using System.IO;
using System.Diagnostics;
using System.Threading;
using System.ComponentModel;
namespace ProcessAsyncStreamSamples
{
class SortOutputRedirection
{
// Define static variables shared by class methods.
private static StringBuilder sortOutput = null;
private static int numOutputLines = 0;
public static void SortInputListText()
{
// Initialize the process and its StartInfo properties.
// The sort command is a console application that
// reads and sorts text input.
Process sortProcess = new Process();
sortProcess.StartInfo.FileName = "Sort.exe";
// Set UseShellExecute to false for redirection.
sortProcess.StartInfo.UseShellExecute = false;
// Redirect the standard output of the sort command.
// This stream is read asynchronously using an event handler.
sortProcess.StartInfo.RedirectStandardOutput = true;
sortOutput = new StringBuilder();
// Set our event handler to asynchronously read the sort output.
sortProcess.OutputDataReceived += SortOutputHandler;
// Redirect standard input as well. This stream
// is used synchronously.
sortProcess.StartInfo.RedirectStandardInput = true;
// Start the process.
sortProcess.Start();
// Use a stream writer to synchronously write the sort input.
StreamWriter sortStreamWriter = sortProcess.StandardInput;
// Start the asynchronous read of the sort output stream.
sortProcess.BeginOutputReadLine();
// Prompt the user for input text lines. Write each
// line to the redirected input stream of the sort command.
Console.WriteLine("Ready to sort up to 50 lines of text");
String inputText;
int numInputLines = 0;
do
{
Console.WriteLine("Enter a text line (or press the Enter key to stop):");
inputText = Console.ReadLine();
if (!String.IsNullOrEmpty(inputText))
{
numInputLines++;
sortStreamWriter.WriteLine(inputText);
}
}
while (!String.IsNullOrEmpty(inputText) && (numInputLines < 50));
Console.WriteLine("<end of input stream>");
Console.WriteLine();
// End the input stream to the sort command.
sortStreamWriter.Close();
// Wait for the sort process to write the sorted text lines.
sortProcess.WaitForExit();
if (numOutputLines > 0)
{
// Write the formatted and sorted output to the console.
Console.WriteLine($" Sort results = {numOutputLines} sorted text line(s) ");
Console.WriteLine("----------");
Console.WriteLine(sortOutput);
}
else
{
Console.WriteLine(" No input lines were sorted.");
}
sortProcess.Close();
}
private static void SortOutputHandler(object sendingProcess,
DataReceivedEventArgs outLine)
{
// Collect the sort command output.
if (!String.IsNullOrEmpty(outLine.Data))
{
numOutputLines++;
// Add the text to the collected output.
sortOutput.Append(Environment.NewLine +
$"[{numOutputLines}] - {outLine.Data}");
}
}
}
}
namespace ProcessAsyncStreamSamples
{
class ProcessSampleMain
{
/// The main entry point for the application.
static void Main()
{
try
{
SortOutputRedirection.SortInputListText();
}
catch (InvalidOperationException e)
{
Console.WriteLine("Exception:");
Console.WriteLine(e);
}
}
}
}
// Define the namespaces used by this sample.
open System
open System.Text
open System.Diagnostics
// Define variables shared by class methods.
let mutable sortOutput = StringBuilder()
let mutable numOutputLines = 0;
let sortOutputHandler (sendingProcess: obj) (outLine: DataReceivedEventArgs) =
// Collect the sort command output.
if String.IsNullOrEmpty outLine.Data |> not then
numOutputLines <- numOutputLines + 1
// Add the text to the collected output.
sortOutput.Append(Environment.NewLine + $"[{numOutputLines}] - {outLine.Data}") |> ignore
let sortInputListText () =
// Initialize the process and its StartInfo properties.
// The sort command is a console application that
// reads and sorts text input.
let sortProcess = new Process();
sortProcess.StartInfo.FileName <- "Sort.exe"
// Set UseShellExecute to false for redirection.
sortProcess.StartInfo.UseShellExecute <- false;
// Redirect the standard output of the sort command.
// This stream is read asynchronously using an event handler.
sortProcess.StartInfo.RedirectStandardOutput <- true;
sortOutput <- StringBuilder();
// Set our event handler to asynchronously read the sort output.
sortProcess.OutputDataReceived.AddHandler sortOutputHandler
// Redirect standard input as well. This stream
// is used synchronously.
sortProcess.StartInfo.RedirectStandardInput <- true;
// Start the process.
sortProcess.Start() |> ignore
// Use a stream writer to synchronously write the sort input.
let sortStreamWriter = sortProcess.StandardInput;
// Start the asynchronous read of the sort output stream.
sortProcess.BeginOutputReadLine();
// Prompt the user for input text lines. Write each
// line to the redirected input stream of the sort command.
printfn "Ready to sort up to 50 lines of text"
let mutable inputText = ""
let mutable numInputLines = 0
while String.IsNullOrEmpty inputText do
printfn "Enter a text line (or press the Enter key to stop):"
inputText <- Console.ReadLine()
if String.IsNullOrEmpty inputText |> not then
numInputLines <- numInputLines + 1
sortStreamWriter.WriteLine inputText
printfn "<end of input stream>\n"
// End the input stream to the sort command.
sortStreamWriter.Close()
// Wait for the sort process to write the sorted text lines.
sortProcess.WaitForExit()
if numOutputLines > 0 then
// Write the formatted and sorted output to the console.
printfn $" Sort results = {numOutputLines} sorted text line(s) "
printfn "----------"
printfn $"{sortOutput}"
else
printfn " No input lines were sorted."
sortProcess.Close();
// The main entry point for the application.
do
try
sortInputListText ()
with :? InvalidOperationException as e ->
printfn "Exception:"
printfn $"{e}"
' Define the namespaces used by this sample.
Imports System.Text
Imports System.IO
Imports System.Diagnostics
Imports System.Threading
Imports System.ComponentModel
Namespace ProcessAsyncStreamSamples
Class ProcessAsyncOutputRedirection
' Define static variables shared by class methods.
Private Shared sortOutput As StringBuilder = Nothing
Private Shared numOutputLines As Integer = 0
Public Shared Sub SortInputListText()
' Initialize the process and its StartInfo properties.
' The sort command is a console application that
' reads and sorts text input.
Dim sortProcess As New Process()
sortProcess.StartInfo.FileName = "Sort.exe"
' Set UseShellExecute to false for redirection.
sortProcess.StartInfo.UseShellExecute = False
' Redirect the standard output of the sort command.
' Read the stream asynchronously using an event handler.
sortProcess.StartInfo.RedirectStandardOutput = True
sortOutput = New StringBuilder()
' Set our event handler to asynchronously read the sort output.
AddHandler sortProcess.OutputDataReceived, AddressOf SortOutputHandler
' Redirect standard input as well. This stream
' is used synchronously.
sortProcess.StartInfo.RedirectStandardInput = True
' Start the process.
sortProcess.Start()
' Use a stream writer to synchronously write the sort input.
Dim sortStreamWriter As StreamWriter = sortProcess.StandardInput
' Start the asynchronous read of the sort output stream.
sortProcess.BeginOutputReadLine()
' Prompt the user for input text lines. Write each
' line to the redirected input stream of the sort command.
Console.WriteLine("Ready to sort up to 50 lines of text")
Dim inputText As String
Dim numInputLines As Integer = 0
Do
Console.WriteLine("Enter a text line (or press the Enter key to stop):")
inputText = Console.ReadLine()
If Not String.IsNullOrEmpty(inputText) Then
numInputLines += 1
sortStreamWriter.WriteLine(inputText)
End If
Loop While Not String.IsNullOrEmpty(inputText) AndAlso numInputLines < 50
Console.WriteLine("<end of input stream>")
Console.WriteLine()
' End the input stream to the sort command.
sortStreamWriter.Close()
' Wait for the sort process to write the sorted text lines.
sortProcess.WaitForExit()
If Not String.IsNullOrEmpty(numOutputLines) Then
' Write the formatted and sorted output to the console.
Console.WriteLine($" Sort results = {numOutputLines} sorted text line(s) ")
Console.WriteLine("----------")
Console.WriteLine(sortOutput)
Else
Console.WriteLine(" No input lines were sorted.")
End If
sortProcess.Close()
End Sub
Private Shared Sub SortOutputHandler(sendingProcess As Object,
outLine As DataReceivedEventArgs)
' Collect the sort command output.
If Not String.IsNullOrEmpty(outLine.Data) Then
numOutputLines += 1
' Add the text to the collected output.
sortOutput.Append(Environment.NewLine +
$"[{numOutputLines}] - {outLine.Data}")
End If
End Sub
End Class
End Namespace
Namespace ProcessAsyncStreamSamples
Class ProcessSampleMain
' The main entry point for the application.
Shared Sub Main()
Try
ProcessAsyncOutputRedirection.SortInputListText()
Catch e As InvalidOperationException
Console.WriteLine("Exception:")
Console.WriteLine(e)
End Try
End Sub
End Class 'ProcessSampleMain
End Namespace 'Process_AsyncStream_Sample
注解
StandardOutput流可以同步或异步读取。 方法,例如 Read, ReadLine对 ReadToEnd 进程的输出流执行同步读取操作。 在关联 Process 写入流 StandardOutput 或关闭流之前,这些同步读取操作不会完成。
相比之下, BeginOutputReadLine 在流上 StandardOutput 启动异步读取操作。 此方法为流输出启用指定的事件处理程序,并立即返回到调用方,该调用方可以在流输出定向到事件处理程序时执行其他工作。
按照以下步骤对以下项StandardOutput执行异步读取操作Process:
将 UseShellExecute 设置为
false。将 RedirectStandardOutput 设置为
true。将事件处理程序添加到事件 OutputDataReceived 。 事件处理程序必须与委托签名匹配 System.Diagnostics.DataReceivedEventHandler 。
启动 Process。
调用 BeginOutputReadLine .Process 此调用将启动异步 StandardOutput读取操作。
异步读取操作启动时,每次关联的 Process 将一行文本写入其 StandardOutput 流时,都会调用事件处理程序。
可以通过调用 CancelOutputRead来取消异步读取操作。 读取操作可由调用方或事件处理程序取消。 取消后,可以再次调用 BeginOutputReadLine 以恢复异步读取操作。
注释
不能在重定向流上混合异步和同步读取操作。 在异步或同步模式下打开重定向的流 Process 后,该流上的所有进一步读取操作都必须处于同一模式。 例如,不要跟BeginOutputReadLine在流上ReadLine调用StandardOutput,反之亦然。 但是,可以在不同的模式下读取两个不同的流。 例如,可以调用BeginOutputReadLine并调用ReadLineStandardError流。