У меня есть вариант ответа на вопрос. Я знаю все о вызовах с ref или нашими параметрами и о том, как это влияет на переменные и их значения. У меня была эта проблема с DataTable, и я хочу знать, почему таблица данных отличается от простой целочисленной переменной.
У меня есть физический ответ о том, как решить проблему, но я хочу знать, почему она работает так, как она работает.
Если вы используете простые переменные, это делает то, что я ожидал
int mVar1 = 1;
int mVar2 =1;
mVar2 = mVar1;
mVar2 = 5;
Console.WriteLine(mVar1.ToString());
Console.WriteLine(mVar2.ToString());
отображает
1,5
в консоли.
НО, если вы делаете то же самое с DataTable, он делает ссылку на первый набор данных вместо нового значения:
DataTable mVar3 = new DataTable();
DataTable mVar4 = new DataTable();
// Create DataColumn objects of data types.
DataColumn colString = new DataColumn("StringCol");
colString.DataType = System.Type.GetType("System.String");
mVar3.Columns.Add(colString);
// Create DataColumn objects of data types.
DataColumn colString2 = new DataColumn("StringCol123");
colString2.DataType = System.Type.GetType("System.String");
mVar4.Columns.Add(colString2);
foreach (DataColumn tCol in mVar3.Columns)
{
Console.WriteLine(tCol.ColumnName);
}
foreach (DataColumn tCol in mVar4.Columns)
{
Console.WriteLine(tCol.ColumnName);
}
mVar4 = mVar3;
//change mVar4 somehow and see if mVar3 changes
foreach (DataColumn tCol in mVar4.Columns)
{
tCol.ColumnName = "Test";
}
foreach (DataColumn tCol in mVar3.Columns)
{
Console.WriteLine(tCol.ColumnName);
}
foreach (DataColumn tCol in mVar4.Columns)
{
Console.WriteLine(tCol.ColumnName);
}
На консоли отображаются:
StringCol
StringCol123
Тестовое задание
Тест
говоря, что mVar4 = mVar3, это заставляет mVar4 быть ссылкой на mVar3.
Решение этой проблемы - сказать
DataTable mVar4 = mVar3.Copy();
Итак, мой вопрос: что заставляет datatable работать иначе, чем простое целочисленное поле. Почему создается ссылка, когда я использую mVar4 = mVar3 вместо другой копии DataTable?