It's common in C# to modify objects in private methods as they are commonly reference-types instead of value types, for example:
public void Main()
{
var person = new Person();
SetPersonsName(person);
System.Writeln(person.Firstname + " " + person.Lastname);
}
private void SetPersonsName(Person person)
{
person.Firstname = "Jimi";
person.Lastname = "Hendrix";
}
Firstname and Lastname are applied to the object and will be correctly printed as we pass in the object by reference (pointer to it's location in memory) rather than creating a copy of the object like we'd do for value-types.
So what if we have an IQueryable and which to use the same approach to add Where clauses to the object collection, like below?
public void Main()
{
// Returns Jimi Hendrix and Justin Bieber
var people = _workspace.GetDataSource<Person>();
FilterByRockGods(people);
foreach(var person in people)
{
// Will still print "Jimi Hendrix" and "Justin Bieber"
// Should only print "Jimi Hendrix" (obviously)
System.Writeln(person.Firstname + " " + person.Lastname);
}
}
private void FilterByRockGods(IQueryable<Person> people)
{
people = people.Where(x => x.IsRockGod);
}
This won't work, the Where clause applied in the private method is not applied to the collection
You have to do the following instead:
public void Main()
{
// Returns Jimi Hendrix and Justin Bieber
var people = _workspace.GetDataSource<Person>();
people = FilterByRockGods(people);
foreach(var person in people)
{
// Prints "Jimi Hendrix"
System.Writeln(person.Firstname + " " + person.Lastname);
}
}
private IQueryable<Person> FilterByRockGods(IQueryable<Person> people)
{
people = people.Where(x => x.IsRockGod);
return people;
}
Why is this?
string
- methods that suggest they modify the string instead return a new string that represents the altered state. Or any class which has been designed to be immutable but has methods suggesting change. – VancouverFilterByRockGods
you are only setting an expression, the expression is not "applied" until the collection is enumerated, the fact that you are passing the the collection to a method is not relevent, you get this behaviour however you do it, it is called deferred execution. – Antihero