这可能是一个非常简单的面向对象编程问题。我要做的是获取 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# 时,我遇到了诸如此类的问题。编译器在断言处说“使用未分配的变量”。但是,我以为我在上面的代码块中分配了一个值。我究竟做错了什么?