¿Por qué las listas list1Instance
y p
en el método Main
del código siguiente apuntan a la misma colección?¿Cómo hacer IEnumerable <T> readonly?
class Person
{
public string FirstName = string.Empty;
public string LastName = string.Empty;
public Person(string firstName, string lastName) {
this.FirstName = firstName;
this.LastName = lastName;
}
}
class List1
{
public List<Person> l1 = new List<Person>();
public List1()
{
l1.Add(new Person("f1","l1"));
l1.Add(new Person("f2", "l2"));
l1.Add(new Person("f3", "l3"));
l1.Add(new Person("f4", "l4"));
l1.Add(new Person("f5", "l5"));
}
public IEnumerable<Person> Get()
{
foreach (Person p in l1)
{
yield return p;
}
//return l1.AsReadOnly();
}
}
class Program
{
static void Main(string[] args)
{
List1 list1Instance = new List1();
List<Person> p = new List<Person>(list1Instance.Get());
UpdatePersons(p);
bool sameFirstName = (list1Instance.l1[0].FirstName == p[0].FirstName);
}
private static void UpdatePersons(List<Person> list)
{
list[0].FirstName = "uf1";
}
}
¿Podemos cambiar este comportamiento con cabo cambiando el tipo de retorno de List1.Get()
?
Gracias
Pero puede convertir cualquier 'IEnumerable' de nuevo a 'T []', 'List ', o el tipo que sea en realidad, y modificar sus elementos (ellos mismos, no sus propiedades). –
Shimmy
@Shimmy Si vamos a obtener información técnica sobre lo que * puedes * hacer, también puedes usar el reflejo para acceder a los miembros privados de cualquier clase y hacer lo que quieras. El hecho de que * pueda * hacer algo (como lanzar 'IEnumerable' a su tipo real) no significa que ** nunca ** deba hacerlo. – Alex
'IEnumerable' no es esencialmente una colección de solo lectura. –
Shimmy