开发者

Is .NET old code updated in new releases? [closed]

开发者 https://www.devze.com 2023-02-13 08:24 出处:网络
It's difficult to tell what is being asked here. This question is ambiguous, vague, incomplete, overly broad, or rhetorical andcannot be reasonably answered in its current form. For help clari
It's difficult to tell what is being asked here. This question is ambiguous, vague, incomplete, overly broad, or rhetorical and cannot be reasonably answered in its current form. For help clarifying this question so that it can be reopened, visit the help center. Closed 11 years ago.

I'm just asking this, because the same happened to me when trying to iterate over a DataRowCollection:

DataSet s;
...
foreach (var x in s.Tables[0].Rows)
{
    //IntelliSense doesn't work here. It takes 'x' as an object.
}

I saw @Marc Gravell answer in Why is there no Intellisense with 'var' variables in 'foreach' statements in C#?, and now it's clear to me why this is happening.

I decided to take a look at the code of the DataRowCollection class, and GetEnumerator() is:

return this.list.GetEnumerator();

where list is a DataRowTree type that 开发者_Python百科inherits the abstract class RBTree<K> (by the way, never knew there was an implementation of a Red-Black Tree in .NET before) which implements IEnumerable instead of IEnumerable<K>.

Is too hard to make RBTree<K> implement IEnumerable<K>? That would solve the main problem here.

I suppose it was developed like this in previous versions of .NET, but that doesn't really make sense anymore, does it?

My question is:

Is .NET old code updated in new releases? (for example, make DataRowCollection implement IEnumerable<DataRow> instead of IEnumerable)


Breaking changes, such as changing the class hierachy, is only implemented if there's a really good reason. In this case it's only for convinience.

An example of why it's a breaking change: Let's say a project has these two methods.

public void Foo(object obj){
   Console.WriteLine(obj.ToString();
}

public void Foo<T>(IEnumerable<T> obj){
  throw new Exception();
}

now the change you want will make a program that has been recompiled but not changed throw an exception every time instead of printing to the console. It's not that it throws that's the problem but that the behaviour is different.

There's other ways such a change could break/alter a perfectly good program so the benefits (being able to write var in foreach loops) does not outweigh the cost (designing, implementing,testing,documenting), nor the potential costs of breaking customers work.

0

精彩评论

暂无评论...
验证码 换一张
取 消