Which one of these is the faster/better one?
This one:
List<User> list = new List<User>();
User u;
foreach (string s in l)
{
u = new User();
u.Name = s;
list.Add(u);
}
Or this one:
List<User> list = new List<User>();
foreach (string s in l)
{
User u = new User();
u.Name = s;
list.Add(u);
}
My newbie-developing skills tells me the first one is better, but a friend of mine tells me im wrong, but could not give me a good reason why the second one is better.
Is there any difference in performance at all?
All the variables which are used in the program are declared in the beginning. It is better to declare the variable in the loop as its validity will be only up to that block and the code can stand alone for that section. So, to tell there is no difference in anything if either of the approaches are used.
It's the result of JVM specifications... But in the name of best coding practice it is recommended to declare the variable in the smallest possible scope (in this example it is inside the loop, as this is the only place where the variable is used). It is the result of the JVM Soecification, not 'compiler optimization'.
It is necessary to enclose the statements of foreach loop in curly braces {}. Instead of declaring and initializing a loop counter variable, you declare a variable that is the same type as the base type of the array, followed by a colon, which is then followed by the array name.
Performance-wise both examples are compiled to the same IL, so there's no difference.
The second is better, because it more clearly expresses your intent if u
is only used inside the loop.
In any case, the best way would be to use a constructor that takes a Name... or, otherwise, exploit curly-brace notation:
foreach (string s in l)
{
list.Add(new User(s));
}
or
foreach (string s in l)
{
list.Add(new User() { Name = s });
}
or even better, LINQ:
var list = l.Select( s => new User { Name = s});
Now, while your first example could, in some cases, be unperceptibly faster, the second one is better because it's more readable, and the compiler may discard the variable (and omit it altogether) since it's not used outsid the foreach
's scope.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With