如何解决显示该方法修改c#中的参数的最佳方法是什么?
| 我有一个方法,除了其他一些动作之外,还可以修改其中一个参数。 例如:public void DoSomeStuffAndModifyList(List<int> list)
{
...
list.Add(newElement);
}
在我看来,方法的名称不足以指出这一点。可能是整个方法是错误的,还是可能使用了ref或out?
解决方法
为您的方法/参数使用描述性名称
public void FillItems(string foo,IList<Item> itemsToFeed)
, 除非有实际必要,否则请勿使用ref
。
如果你的方法是
void DoSomething(List<int> list)
{
list.Add(whatever);
}
加ref
没有用。您没有做任何需要的事情,只会增加额外的复杂性而无济于事,并且可能会使维护程序员难以推理该方法。
当您的方法实际上可以通过将list
指向原始列表以外的其他地方来更改change6ѭ时,请使用ref
。这可以是一个全新的列表,另一个现有列表或null。并且仅当您希望此更改在呼叫者处可见时才使用ref
。
对于您的方法,请探索对其进行重构,以便可能不需要在列表中添加或删除项目。完成此操作后,请绝对正确地命名该方法。完成此操作后,请利用方法和参数摘要注释来传达您认为有用的信息。
/// <summary>
/// Describe the method andhere
/// </summary>
/// <param name=\"list\">Describe what\'s relevant about the parameter here.</param>
不要滥用ref
关键字,进行适当的重构,使用文档。
, 更改时使用ObservableCollection<T>
并触发CollectionChanged
事件
http://msdn.microsoft.com/en-us/library/ms668604.aspx
或者您可以像这样将您的方法设置为扩展方法
public static List<int> DoSomeStuffAndModifyList(this List<int> list)
{
...
list.Add(newElement);
return list;
}
, 如何返回新列表:
public List<int> DoSomeStuff(List<int> list)
{
...
return list.Concat(new[] { newElement });
}
, 我对你的问题有些困惑。您在问如何命名方法吗?
您应该将自己的动作分解为不同的方法。我不必担心调用这些操作的方法。只要具有足够的描述性,就可以了。
正如约翰·桑德斯(John Saunders)所说,将您的方法划分为单一责任。
public List<int> GetList()
{
//return list
}
public void ModifyList(List<int> list)
{
//Modify list,you could return if you wanted to.
}
//Call 2 methods
List<int> list = GetList();
ModifyList(list);
, 创建扩展方法。
public static class ListExtensions
{
public static void DoSomeStuffAndModifyList(this List<int> list)
{
...
list.Add(newElement);
}
)
并称之为:
var gradeList = new List<int>();
gradeList.DoSomeStuffAndModifyList();
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。