Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/csharp/321.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# 索引超出了修剪文本处的数组边界_C#_Arrays_Indexoutofboundsexception - Fatal编程技术网

C# 索引超出了修剪文本处的数组边界

C# 索引超出了修剪文本处的数组边界,c#,arrays,indexoutofboundsexception,C#,Arrays,Indexoutofboundsexception,我创建了一个连接到数据库的Windows窗体应用程序,用户在其中输入特定值。我现在面临的问题是,我创建了一个搜索引擎,它的工作方式很有魅力。但是,用户总是会按姓名和姓氏进行搜索,我想把这个搜索做得更准确一些。它是有效的,但当我只输入姓名或姓氏时,我想显示一个按摩盒,表明他们没有正确输入。所以我写了这个,但如果我只键入一个单词,它就会崩溃并显示这个错误:索引超出了数组的界限。谢谢 private void button1_Click(object sender, EventArgs e) {

我创建了一个连接到数据库的Windows窗体应用程序,用户在其中输入特定值。我现在面临的问题是,我创建了一个搜索引擎,它的工作方式很有魅力。但是,用户总是会按姓名和姓氏进行搜索,我想把这个搜索做得更准确一些。它是有效的,但当我只输入姓名或姓氏时,我想显示一个按摩盒,表明他们没有正确输入。所以我写了这个,但如果我只键入一个单词,它就会崩溃并显示这个错误:索引超出了数组的界限。谢谢

private void button1_Click(object sender, EventArgs e)
{
    if (textBox1.Text.Length != 0)
    {
        var numePrenume = textBox1.Text.Trim().Split(' ');
        var nume = numePrenume[0];
        var prenume = numePrenume[1];

    if (nume.Length > 0 || prenume.Length > 0)
    {
        var connString = @"Data Source=C:\Users\Andrei\Documents\Visual Studio 2010\Projects\Stellwag\Stellwag\Angajati.sdf";
        using (var conn = new SqlCeConnection(connString))
        {
        }
    }

    //some code
}

如果只键入一个单词,则此行将导致异常:

var prenume = numePrenume[1];
因为它不存在

在尝试访问该数组元素之前,需要添加一些边界检查,例如

if(numePrenume.Length == 2)
{
    var prenume = numePrenume[1];
}

您可以通过验证Textbox.Text进行尝试,如果需要同时填充姓名和姓氏,则可以返回验证错误。 这可以通过以下方式完成:

if(numePrenume.Lenght()==0)
{
   MessageBox.Show("");
}

 return;

希望有帮助:)

检查数组长度可以解决您的问题:

 if (textBox1.Text.Length != 0)
            {

                var numePrenume = textBox1.Text.Trim().Split(' ');
                if (numePrenume.Length >= 1)
                {
                    var nume = numePrenume[0];
                    var prenume = numePrenume[1];

                    if (nume.Length > 0 || prenume.Length > 0)
                    {
                        var connString = @"Data Source=C:\Users\Andrei\Documents\Visual Studio 2010\Projects\Stellwag\Stellwag\Angajati.sdf";
                        using (var conn = new SqlCeConnection(connString))
                        {
                        }
                    }
                }
                else
                    // some code here
            }

您需要检查split函数是否返回多个元素。像这样简单地更新代码可以解决您的问题:

private void button1_Click(object sender, EventArgs e)
{
    if (textBox1.Text.Length != 0)
    {
        var numePrenume = textBox1.Text.Trim().Split(' ');
        var nume = numePrenume[0];

        if(numePrenume.Length >= 1) 
        {
            var prenume = numePrenume[1];
        }

        if (nume.Length > 0 || prenume.Length > 0)
        {
            var connString = @"Data Source=C:\Users\Andrei\Documents\Visual Studio 2010\Projects\Stellwag\Stellwag\Angajati.sdf";
            using (var conn = new SqlCeConnection(connString))
            {
            }
        }
        //some code
    }

您需要检查
Split()
返回的数组的
长度。此外,如果用户在名称部分之间键入多个空格,最好添加
StringSplitOptions。删除mptyentries
,以避免获取两个以上的部分

考虑这个例子:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace ConsoleApplication2
{
    class Program
    {
        static void Main(string[] args)
        {
            var name = "   name  ";

            var nameParts = name.Trim().Split(new []{' '}, StringSplitOptions.RemoveEmptyEntries);

            if (nameParts.Length < 2)
            {
                Console.WriteLine("You've only entered one name");
            }
            else
            {
                Console.WriteLine("First part: {0}", nameParts[0]);
                Console.WriteLine("Second part: {0}", nameParts[1]);
            }
        }
    }
}
使用系统;
使用System.Collections.Generic;
使用System.Linq;
使用系统文本;
使用System.Threading.Tasks;
命名空间控制台应用程序2
{
班级计划
{
静态void Main(字符串[]参数)
{
var name=“name”;
var nameParts=name.Trim().Split(新[]{''},StringSplitOptions.RemoveEmptyEntries);
如果(名称零件长度<2)
{
WriteLine(“您只输入了一个名称”);
}
其他的
{
WriteLine(“第一部分:{0}”,nameParts[0]);
WriteLine(“第二部分:{0}”,nameParts[1]);
}
}
}
}

您需要检查
numePrenume.Length
是否大于1。如果小于1,则向用户显示一些消息

private void button1_Click(object sender, EventArgs e)
{
    if (textBox1.Text.Length != 0)
    {
        var numePrenume = textBox1.Text.Trim().Split(' ');
        if(numePrenume.Length > 1)
        {
            var nume = numePrenume[0];
            var prenume = numePrenume[1];

            if (nume.Length > 0 || prenume.Length > 0)
            {
                var connString = @"Data Source=C:\Users\Andrei\Documents\Visual Studio 2010\Projects\Stellwag\Stellwag\Angajati.sdf";
                using (var conn = new SqlCeConnection(connString))
                {
                }
            }
                    //some code
         }
         else
         {
              Console.Writeline("You need to input both Name and Surname");
         }
    }
}

您需要检查拆分(“”)是否有两个名称。如果它只包含一个元素,那么它不能提供numePrenume[1]

未测试代码:

private void button1_Click(object sender, EventArgs e)
{
    if (textBox1.Text.Length != 0)
    {
        var numePrenume = textBox1.Text.Trim().Split(' ');

        if(numePrenume.Count()>1)
        {
            var nume = numePrenume[0];
            var prenume = numePrenume[1];

            var connString = @"Data Source=C:\Users\Andrei\Documents\Visual Studio 2010\Projects\Stellwag\Stellwag\Angajati.sdf";
            using (var conn = new SqlCeConnection(connString))
            {
            }
        }

        //some code
    }

}

确切地说,
textBox1.Text
是什么?你曾经调试过你的代码并看到过吗?如果它有一个单词,那么这个
分割
当然不会作为第二个值返回。这就是为什么没有
numePrenume[1]
项的原因。也可以读到:当然可以。textBox1.Text是在指定id的文本中输入用于搜索的文本,但很明显,拆分只返回一个字符串,因此numePrenume的索引值仅为0。我知道。。我理解为什么会崩溃,为什么会显示错误。但我真的不知道如何解决它。还是一样的错误。事件,如果它看起来应该工作。Damnat崩溃发生在哪一行这里的关键是
Length
检查代码中的
nameParts
,或者
numePrenume
if(numePrenume.Length<2){//Do something!}其他{//连接到数据库…}
明白了。但是真的不明白为什么它不起作用。如果用户输入一个名称,numePrenume将只包含一个项目
numePrenume[1]
将尝试获取超出数组边界的项#2。