1

我在使用下面的代码时遇到问题......当我运行它时,代码永远不会退出。我已经尝试调试了大约一个小时,但我完全不知道问题出在哪里。输出调试();本质上就像 Console.WriteLine();

//Iterate through all lines to find sections
            using (StringReader lineReader = new StringReader(Program))
            {
                int i = 0;
                string line = string.Empty;
                while (line != null)
                {
                    line = lineReader.ReadLine();
                    if (line != string.Empty)
                    {
                        //If the program is exiting (doExit == true), then break the lööp bröther
                    if (doExit)
                            break;

                        //Iterate through all characters in the line
                        foreach (char Character in line)
                    {
                        i++;
                        OutputDebug(i.ToString());
                        if (isOnSameLineAsSectionStart)
                        {
                            sectionName += Character;
                        }
                        else if (Character == ':' && sectionName == string.Empty)
                        {
                            isOnSameLineAsSectionStart = true;
                        }
                        else if (Character == ':' && !isOnSameLineAsSectionStart && sectionName != string.Empty)
                        {
                            OutputDebug("End of section \"" + sectionName + "\" found");
                            OutputDebug(linesInSection.Count() + " lines found total in " + sectionName + "\" during section search");
                            try
                            {
                                sections.Add(sectionName, linesInSection);
                            }
                            catch (Exception)
                            {
                                OutputError("Two/Multiple sections with the same names exist. Ignoring the latest section with the same name");
                            }
                            linesInSection = new List<string>();
                            sectionName = string.Empty;
                            isOnSameLineAsSectionStart = true;
                        }
                    }
                    if (!isOnSameLineAsSectionStart && sectionName != string.Empty)
                    {
                        linesInSection.Add(line);
                    }
                    if (isOnSameLineAsSectionStart && sectionName != string.Empty)
                    {
                        OutputDebug("Start of section \"" + sectionName + "\" found");
                    }
                    if (isOnSameLineAsSectionStart == true)
                    {
                        isOnSameLineAsSectionStart = false;
                    }
                }
                lineReader.Close();
                OutputDebug("In StringReader!" + i);
            }

提前致谢!

4

3 回答 3

3

您可以使用下面的方法:

while ((line = reader.ReadLine()) != null)
{
    foreach (char Character in line)
    {
        i++;
        OutputDebug(i.ToString());
    }
}
于 2018-12-14T19:33:04.843 回答
1

好吧,如果你想逐行输出所有字符。您可以将它们拆分为字符串数组:

var lines = Regex.Split(input, "\r\n|\r|\n")这里提取。

稍后,使用 foreach 而不是 while 语句,您应该可以解决问题:

foreach(string line in lines)

还将字符串与空值进行比较......看起来不太好。为什么不使用(内置)string.IsNullOrEmpty(line)方法来检查当前行是否为空?

如果你想使用你的方法,你应该这样做:

while (!string.IsNullOrEmpty(line = reader.ReadLine()))
{
    // Your code...
}

希望这可以帮助!

于 2018-12-14T19:32:26.450 回答
1

由于我们仅限于这个片段,我们只能做出假设。

lineReader.ReadLine();

如果这是一个阻塞调用,那么只要没有输入,代码就永远不会退出。

如果这是一个解锁调用,则意味着即使没有提供输入,它也会返回一些内容。如果在这种情况下返回值是空字符串,那么您将处于无限循环中。

我相信关键功能在ReadLine这里。

于 2018-12-14T20:01:58.520 回答