当前位置: 首页>>代码示例>>C#>>正文


C# StreamReader.ReadAsync方法代码示例

本文整理汇总了C#中System.IO.StreamReader.ReadAsync方法的典型用法代码示例。如果您正苦于以下问题:C# StreamReader.ReadAsync方法的具体用法?C# StreamReader.ReadAsync怎么用?C# StreamReader.ReadAsync使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在System.IO.StreamReader的用法示例。


在下文中一共展示了StreamReader.ReadAsync方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: logFromStream

        private async Task logFromStream(Stream stream, CancellationToken token, string category, Func<bool> isComplete)
        {
            char[] buffer = new char[128];

            using (var sr = new StreamReader(stream))
            {
                while (true)
                {
                    token.ThrowIfCancellationRequested();

                    var outBytesRead = await sr.ReadAsync(buffer, 0, buffer.Length);

                    if (outBytesRead == 0)
                    {
                        if (isComplete())
                            break;
                        else
                            await Task.Delay(100);
                    }
                    else
                    {
                        var outText = new string(buffer, 0, outBytesRead);

                        if (!string.IsNullOrEmpty(outText))
                            this.newLogEntry(outText, category, true, true);
                    }
                }
            }
        }
开发者ID:modulexcite,项目名称:ec2manager,代码行数:29,代码来源:Logger.cs

示例2: ReadAsync

 public override async Task ReadAsync(StreamReader reader)
 {
     var buffer = new char[valorFixo.Length];
     var read = await reader.ReadAsync(buffer, 0, buffer.Length);
     if (read != buffer.Length || new string(buffer) != valorFixo)
         throw new LeituraException($"O valor fixo '{valorFixo}' não foi encontrado.");
 }
开发者ID:Zhdat,项目名称:ExportaDepositos,代码行数:7,代码来源:Fixo.cs

示例3: ReadBlockAsync

 private async Task<DataBlock> ReadBlockAsync(StreamReader reader, DataBlock target)
 {
     var readBytes = await reader.ReadAsync(target.Data, 0, BufferSize);
     if (readBytes != BufferSize)
     {
         target.ResizeData(readBytes);
     }
     return target;
 }
开发者ID:JaegerJens,项目名称:FileIndexService,代码行数:9,代码来源:BlockReader.cs

示例4: Create

        public static async Task<IHttpPost> Create(StreamReader reader, int postContentLength)
        {
            char[] rawEncoded = new char[postContentLength];
            
            int readBytes = await reader.ReadAsync(rawEncoded, 0, rawEncoded.Length);

            byte[] raw = Encoding.UTF8.GetBytes(rawEncoded, 0, readBytes);
            
            return new HttpPost(raw, readBytes);
        }
开发者ID:rancohen1,项目名称:uHttpSharp,代码行数:10,代码来源:HttpHeaders.cs

示例5: CreateListener

        public static async void CreateListener(Action<string> action, TcpClient tcpClient)
        {
            var networkStream = tcpClient.GetStream();
            var r = new StreamReader(networkStream);
            var buffer = new char[1];
            while (true)
            {
                if (r.EndOfStream)
                {
                    Task.Delay(500);
                    continue;
                }

                await r.ReadAsync(buffer, 0, buffer.Length);
                action(new string(buffer));
            }
        }
开发者ID:skalinets,项目名称:EchoServer,代码行数:17,代码来源:TcpHelper.cs

示例6: ReadStreamAsync

        /// <summary>
        /// Utility method that fills a StringBuilder
        /// </summary>
        /// <param name="data">Stream containing document data.</param>
        /// <returns>Content of the stream as a string.</returns>
        public static async Task<string> ReadStreamAsync(Stream data, int blockSize=4096)
        {
            var buffer = new char[blockSize];
            var builder = new StringBuilder();

            using (var reader = new StreamReader(data))
            {
                while (!reader.EndOfStream)
                {
                    // StreamReader.ReadAsync() returns number of *chars* read, not number of bytes, in 
                    // spite of what the API docs say. I read the code (MW 2015.11.06)
                    var charsRead = await reader.ReadAsync(buffer, 0, blockSize).ConfigureAwait(false);
                    builder.Append(buffer, 0, charsRead);
                }
            }

            return builder.ToString();
        }
开发者ID:matsaleh13,项目名称:bs-meter,代码行数:23,代码来源:StreamUtils.cs

示例7: AnalyzeAsync

        /// <summary>
        /// Asynchronous method to analyze the data stream.
        /// </summary>
        /// <param name="data">Data stream to analyze.</param>
        /// <param name="blockSize">Max number of characters to read at a time.</param>
        /// <returns>Result of the analysis.</returns>
        public async Task<IAnalyzerResult> AnalyzeAsync(Stream data, int blockSize = 1024)
        {
            var result = new CharacterAnalyzerResult();
            var buffer = new char[blockSize];

            using (var reader = new StreamReader(data))
            {
                var lastCharType = CharacterType.Invalid;

                while (!reader.EndOfStream)
                {
                    var count = await reader.ReadAsync(buffer, 0, blockSize).ConfigureAwait(false);

                    lastCharType = AnalyzeBuffer(buffer, count, result, lastCharType);
                }   
            }

            return result;
        }
开发者ID:matsaleh13,项目名称:bs-meter,代码行数:25,代码来源:CharacterAnalyzer.cs

示例8: WaitForPrompt

        private static async Task<bool> WaitForPrompt(StreamReader reader, string prompt)
        {
            var buffer = new char[1024];
            int read;
            var readString = string.Empty;

            while ((read = await reader.ReadAsync(buffer, 0, buffer.Length)) > 0)
            {
                readString += new string(buffer, 0, read);

                if (readString.TrimEnd().EndsWith(prompt))
                {
                    Console.Write(readString);
                    return true;
                }
            }

            Console.Write(readString);
            return false;
        }
开发者ID:Lawo,项目名称:ember-plus-sharp,代码行数:20,代码来源:TelnetStreamTest.cs

示例9: HandleClientAccessPolicy

        public static async Task HandleClientAccessPolicy(TcpClient client, string policyResponse)
        {
            using (var clientStream = client.GetStream())
            {
                string request = string.Empty;

                var reader = new StreamReader(clientStream);
                var charArray = new char[2048];
                var length = await reader.ReadAsync(charArray, 0, 2048);
                request = new String(charArray, 0, length);

                if (request == PolicyRequest)
                {
                    var writer = new StreamWriter(clientStream, Encoding.UTF8);
                    writer.AutoFlush = true;
                    await writer.WriteAsync(policyResponse);
                }
            }

            client.Close();
        }
开发者ID:vgrigoriu,项目名称:Redis.SilverlightClient,代码行数:21,代码来源:PolicyHandler.cs

示例10: ReadStreamToEnd

        static async Task ReadStreamToEnd(StreamReader stream, IObserver<string> observable) {
            try {
                var readBuffer = new char[1];
                var lineBuffer = new StringBuilder();
                while ((await stream.ReadAsync(readBuffer, 0, 1).ConfigureAwait(false)) > 0) {
                    var c = readBuffer[0];
                    lineBuffer.Append(c);
                    // This does not account for unterminated lines.... like 'verifying download...'
                    // We would be able to do this by sending the data also byte by byte to the receivers, but for little gain.
                    if (c != '\r' && c != '\n')
                        continue;
                    observable.OnNext(lineBuffer.ToString());
                    lineBuffer.Clear();
                }

                if (lineBuffer.Length > 0)
                    observable.OnNext(lineBuffer.ToString());
            } finally {
                observable.OnCompleted();
            }
        }
开发者ID:MaHuJa,项目名称:withSIX.Desktop,代码行数:21,代码来源:ReactiveProcess.cs

示例11: TryReadTextFileAsync

        public async Task<TryResult<string>> TryReadTextFileAsync(string path, CancellationToken cancellationToken)
        {
            var contentStringBuilder = new StringBuilder();
            var operationSucceeded = await TryReadFileCommonAsync(path, async stream =>
            {
                using (var reader = new StreamReader(stream))
                {
                    var buffer = new char[BufferSize];

                    while (reader.Peek() > 0)
                    {
                        if (cancellationToken.IsCancellationRequested)
                            return false;

                        var charsRead = await reader.ReadAsync(buffer, 0, BufferSize);

                        contentStringBuilder.Append(buffer, 0, charsRead);
                    }
                    return true;
                };
            }).ConfigureAwait(false);

            return TryResult.Create(operationSucceeded, operationSucceeded ? contentStringBuilder.ToString() : string.Empty);
        }
开发者ID:jokvist,项目名称:MvvmCross-Plugins,代码行数:24,代码来源:MvxFileStoreBase.cs

示例12: LoadFileAsync

        private async Task<Document> LoadFileAsync(ILoader loader, string path, CancellationToken cancellationToken)
        {
            try
            {
                using (var file = new FileStream(path, FileMode.Open, FileAccess.Read, FileShare.Read, 4096, true))
                using (var reader = new StreamReader(file))
                {
                    var count = 0;
                    var buffer = new char[4096];
                    while ((count = await reader.ReadAsync(buffer, 0, buffer.Length).ConfigureAwait(false)) > 0)
                    {
                        // Check for cancellation
                        cancellationToken.ThrowIfCancellationRequested();

                        // Add the data to the document
                        if (!loader.AddData(buffer, count))
                        {
                            throw new IOException("The data could not be added to the loader.");
                        }
                    }

                    return loader.ConvertToDocument();
                }
            }
            catch
            {
                loader.Release();
                throw;
            }
        }
开发者ID:Liquidize,项目名称:RMMVResourceManager,代码行数:30,代码来源:PreviewForm.cs

示例13: Procesar

        /// <summary>
        /// Lee el archivo en pedazos de 4096 bytes, y llena el diccionario indicando
        /// que letras existen en el archivo y cuantas veces aparece cada una de ellas.
        /// </summary>
        /// <returns>
        /// Retorna una tarea ya que es un proceso que puede ejecutarse en otro 
        /// hilo para no bloquear la UI.
        /// </returns>
        public async Task<DocumentoProcesado> Procesar()
        {
            var palabras = new SortedDictionary<string, int>();
            var letras = new SortedDictionary<char, int>();
            var signos = new SortedDictionary<char, int>();
            var simbolos = new SortedDictionary<char, int>();

            int palabrasCantidad = 0;
            int letrasCantidad = 0;
            int signosCantidad = 0;
            int simbolosCantidad = 0;

            int bytesLeidos = 0;

            // Se asume que todos los archivos tendrán encoding de UTF8
            // a menos que el sistema pueda detectarlo por el order de bytes.
            using (var reader = new StreamReader(rutaArchivo, Encoding.UTF8, detectEncodingFromByteOrderMarks: true, bufferSize: bufferSize))
            {
                var letrasPalabra = new List<char>();
                var buffer = new char[bufferSize];
                var count = 0;

                do
                {
                    // se lee un fragmento de 4096 bytes del archivo
                    count = await reader.ReadAsync(buffer, 0, bufferSize);


                    // Se analiza cada una de esas 4096 letras leídas
                    // y si no se encuentran en el diccionario aún se
                    // agregan con valor de uno,
                    // pero si la letra ya existe en el diccionario,
                    // solo se incrementa en uno su valor.
                    for (int i = 0; i < count; i++)
                    {
                        var caracter = buffer[i];

                        if (char.IsLetter(caracter))
                        {
                            letrasCantidad++;

                            var c = char.ToLowerInvariant(caracter);

                            letrasPalabra.Add(c);

                            if (letras.ContainsKey(c))
                            {
                                letras[c]++;
                            }
                            else
                            {
                                letras.Add(c, 1);
                            }
                        }
                        else if (letrasPalabra.Count > 0)
                        {

                            if (letrasPalabra.Count <= 5)
                            {
                                palabrasCantidad++;

                                var palabra = new string(letrasPalabra.ToArray()).ToLowerInvariant();

                                if (palabras.ContainsKey(palabra))
                                {
                                    palabras[palabra]++;
                                }
                                else
                                {
                                    palabras.Add(palabra, 1);
                                }
                            }

                            letrasPalabra.Clear();

                        }

                        if (char.IsPunctuation(caracter))
                        {
                            signosCantidad++;

                            if (signos.ContainsKey(caracter))
                            {
                                signos[caracter]++;
                            }
                            else
                            {
                                signos.Add(caracter, 1);
                            }
                        }

                        if (char.IsSymbol(caracter))
//.........这里部分代码省略.........
开发者ID:umggt,项目名称:lang-detector,代码行数:101,代码来源:Parser.cs

示例14: clientThread

        /*
        *METHOD		    :	clientThread
        *
        *DESCRIPTION	:	Method to listen to a spesific users pipe
         *                  Is creates the connection, listens for a command
         *                  then acts acordingly based on that command
        *
        *PARAMETERS		:	object sender:  Opject relaying information on where the even call came from
        *                   EventArgs e:    Object that contains data about the event
        *  
        *RETURNS		:	void
        *
        */
        private async void clientThread(object clientPipeName)
        {
            string serverName = "";
            string pipeName = (string)clientPipeName;
            
            NamedPipeClientStream client;
            NamedPipeServerStream server;
            StreamReader input;
            StreamWriter output;

            DAL dal = new DAL();
            string userName = "";

            //set up pipe security
            PipeSecurity ps = new PipeSecurity();
            System.Security.Principal.SecurityIdentifier sid = new System.Security.Principal.SecurityIdentifier(System.Security.Principal.WellKnownSidType.WorldSid, null);
            PipeAccessRule par = new PipeAccessRule(sid, PipeAccessRights.ReadWrite, System.Security.AccessControl.AccessControlType.Allow);
            ps.AddAccessRule(par);

            Logger.Log("Client thread started");

            //wait for user to connect
            server = new NamedPipeServerStream(clientPipeName + "service", PipeDirection.InOut, 1, PipeTransmissionMode.Byte, PipeOptions.Asynchronous, 5000, 5000, ps);
            server.WaitForConnection();
            input = new StreamReader(server);

            Logger.Log("Client connected to pipe: " + clientPipeName);

            //get the name of the computer to connect back to
            serverName = input.ReadLine();

            //connect back
            try
            {
                client = new NamedPipeClientStream(serverName, clientPipeName + "User");
                client.Connect(30);
                output = new StreamWriter(client);

                Logger.Log("User thread connected to pipe: " + clientPipeName);

                //start loop to watch the pipe 
                while (!Done)
                {
                    //async read from pipe
                    char[] temp = new char[5000];
                    await input.ReadAsync(temp, 0, 5000);
                    //move data from pipe to a string (padded with somthing, not sure what)
                    string userCommand = new string(temp);
                    //all commands end in a period. if there is no period then the user left
                    if (!userCommand.Contains("."))
                    {
                        Logger.Log("Pipe: " + clientPipeName + "userLeft");
                        //close connection
                        output.Dispose();
                        input.Dispose();
                        //remove from repo
                        clients.DeleteClient((string)clientPipeName);
                        break;
                    }
                    //if the command is valid
                    //remove the period and all padded data
                    userCommand = userCommand.Remove(userCommand.IndexOf('.'));

                    Logger.Log("Pipe: " + clientPipeName + " Got Command: " + userCommand);
                    //select the command entered
                    if (userCommand == "NewUser")
                    {
                        Logger.Log("Pipe: " + clientPipeName + "in newUser command code");
                        //read in user name
                        userName = input.ReadLine();
                        //add to database
                        output.WriteLine("OK");
                        output.Flush();
                        //if user not in database add
                        dal.OpenConnection();
                        bool isUserTaken = dal.IsNameInDatabase(userName);
                        dal.CloseConnection();
                        if (isUserTaken == false)
                        {
                            dal.OpenConnection();
                            dal.StoreUserName(userName);
                            dal.InitializeUserInLeaderboard(userName, 1);
                            dal.CloseConnection();
                        }
                    }
                    else if (userCommand == "GetQuestion")
                    {
//.........这里部分代码省略.........
开发者ID:brandond12,项目名称:Trivia-Game,代码行数:101,代码来源:TriviaGameDatabaseService.cs

示例15: ProcessConnection

        /// <summary>
        /// Handle an incoming SMTP connection, from connection to completion.
        /// </summary>
        /// <param name="parameters">SmtpProxyConnectionArguments object containing all parameters for this connection.</param>
        private async void ProcessConnection(object parameters)
        {
            // Cast the passed-in parameters back to their original objects.
            SmtpProxyConnectionArguments arguments = (SmtpProxyConnectionArguments)parameters;

            // The overall number of bytes transmitted on this connection.
            ulong bytesTransmitted = 0;

            TcpClient client = null;
            Stream clientStream = null;
            StreamReader clientStreamReader = null;
            StreamWriter clientStreamWriter = null;

            string ip = "";

            try
            {
                client = arguments.TcpClient;
                clientStream = client.GetStream();

                // Placeholder variables to be populated throughout the client session.
                NetworkCredential credential = arguments.RemoteServerCredential;
                string fromAddress = "";
                string identity = "";
                List<string> toList = new List<string>();
                bool sending = false, inPlainAuth = false, inLoginAuth = false;

                // A byte array to streamline bit shuffling.
                char[] buffer = new char[Constants.SMALLBUFFERSIZE];

                // Capture the client's IP information.
                PropertyInfo pi = clientStream.GetType().GetProperty("Socket", BindingFlags.NonPublic | BindingFlags.Instance);
                ip = ((Socket)pi.GetValue(clientStream, null)).RemoteEndPoint.ToString();
                if (ip.IndexOf(":") > -1)
                    ip = ip.Substring(0, ip.IndexOf(":"));

                // If the IP address range filter contains the localhost entry 0.0.0.0, check if the client IP is a local address and update it to 0.0.0.0 if so.
                if (arguments.AcceptedIPs.IndexOf("0.0.0.0") > -1)
                {
                    if (ip == "127.0.0.1")
                        ip = "0.0.0.0";
                    else
                    {
                        IPHostEntry hostEntry = Dns.GetHostEntry(Dns.GetHostName());
                        foreach (IPAddress hostIP in hostEntry.AddressList)
                        {
                            if (hostIP.ToString() == ip)
                            {
                                ip = "0.0.0.0";
                                break;
                            }
                        }
                    }
                }

                clientStreamReader = new StreamReader(clientStream);
                clientStreamWriter = new StreamWriter(clientStream);
                clientStreamWriter.AutoFlush = true;

                // Validate that the IP address is within an accepted range.
                if (!ProxyFunctions.ValidateIP(arguments.AcceptedIPs, ip))
                {
                    ProxyFunctions.Log(LogWriter, SessionId, arguments.ConnectionId, "Connection rejected from {" + ip + "} due to its IP address.", Proxy.LogLevel.Warning, LogLevel);

                    await Functions.SendStreamStringAsync(clientStreamWriter, "500 IP address [" + ip + "] rejected.\r\n");
                    ProxyFunctions.Log(LogWriter, SessionId, arguments.ConnectionId, "S: 500 IP address [" + ip + "] rejected.", Proxy.LogLevel.Raw, LogLevel);

                    if (clientStream != null)
                        clientStream.Dispose();
                    if (client != null)
                        client.Close();

                    return;
                }

                ProxyFunctions.Log(LogWriter, SessionId, arguments.ConnectionId, "New connection established from {" + ip + "}.", Proxy.LogLevel.Information, LogLevel);

                // Send our welcome message.
                await Functions.SendStreamStringAsync(clientStreamWriter, "220 " + WelcomeMessage + "\r\n");
                ProxyFunctions.Log(LogWriter, SessionId, arguments.ConnectionId, "220 " + WelcomeMessage, Proxy.LogLevel.Raw, LogLevel);

                // Instantiate an SmtpClient for sending messages to the remote server.
                using (OpaqueMail.Net.SmtpClient smtpClient = new OpaqueMail.Net.SmtpClient(arguments.RemoteServerHostName, arguments.RemoteServerPort))
                {
                    smtpClient.EnableSsl = arguments.RemoteServerEnableSsl;
                    smtpClient.Credentials = arguments.RemoteServerCredential;

                    if (arguments.SmimeValidCertificates != null)
                        smtpClient.SmimeValidCertificates = arguments.SmimeValidCertificates;

                    // Loop through each received command.
                    string command = "";
                    bool stillReceiving = true;
                    while (Started && stillReceiving)
                    {
                        int bytesRead = await clientStreamReader.ReadAsync(buffer, 0, Constants.SMALLBUFFERSIZE);
//.........这里部分代码省略.........
开发者ID:KiransHub,项目名称:OpaqueMail,代码行数:101,代码来源:SmtpProxy.cs


注:本文中的System.IO.StreamReader.ReadAsync方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。