2

这可能是一个非常简单的面向对象编程问题。我要做的是获取 2 个空对象,使用查询从数据库中提取数据,用查询返回的数据填充空对象,然后对它们进行断言。请看下面的代码:

        object test1;
        object test2;

        using (SqlConnection dbconnection = new SqlConnection(expconnstr))
        {
            dbconnection.Open();

            var expcommand = new SqlCommand(expectedquery, dbconnection);
            var actcommand = new SqlCommand(actualquery, dbconnection);

            using (SqlDataReader expreader = expcommand.ExecuteReader())
            {
                if (expreader.Read())
                {                        
                    test1 = expreader.GetValue(0);
                    expreader.Close();
                }
            }

            using (SqlDataReader actreader = actcommand.ExecuteReader())
            {
                if (actreader.Read())
                {
                    test2 = actreader.GetValue(0);
                    actreader.Close();
                }
            }
        }
        Assert.AreSame(test1, test2);

我按照相同的模式在 VB 中编写了一个非常相似的测试方法,并且 VB 代码执行得很好。但是,在从 VB 过渡到 C# 时,我遇到了诸如此类的问题。编译器在断言处说“使用未分配的变量”。但是,我以为我在上面的代码块中分配了一个值。我究竟做错了什么?

4

2 回答 2

2

存在actreader.Read()返回 false 的可能性,因此test2可能永远不会被分配和编译器错误。

您可以通过将test1&test2初始设置为null

object test1 = null;
object test2 = null;
于 2012-06-25T23:24:22.273 回答
1

您正在将值分配给if块内的变量。由于局部变量未使用默认值进行初始化,因此无法保证在您执行Assert语句时该变量已被赋值。

正在发生以下一项或多项情况:

  • expreader.Read()正在返回false
  • actreader.Read()正在返回false
于 2012-06-25T23:25:27.903 回答