在C#程序中,我创建了一个从列表中删除对象的方法.用户输入要删除的项目的索引,然后要求用户确认删除,如果用户确认,则从列表中删除该项目,否则列表保持不变.
我不确定将参数传递给方法的最佳方法.我尝试通过引用传递列表(作为out参数):
我不确定将参数传递给方法的最佳方法.我尝试通过引用传递列表(作为out参数):
static void DeleteCustomer(out List<Customer> customers) { // ...display list of objects for user to choose from... int deleteId = ReadInt("Enter ID of customer to delete: "); Console.Write("Are you sure you want to delete this customer?"); if (Console.ReadLine().ToLower() == "y") { customers.RemoveAt(deleteId); } }
上面的代码不起作用,因为我得到错误使用未分配的本地变量’customers’和out参数’customers’必须在控制离开当前方法之前分配.我以为我可以按值传递列表并返回相同的列表,如下所示:
static List<Customer> DeleteCustomer(List<Customer> customers) { int deleteId = ReadInt("Enter ID of customer to delete: "); Console.Write("Are you sure you want to delete this customer?"); if (Console.ReadLine().ToLower() == "y") { customers.RemoveAt(deleteId); } return customers; } // ...which would be called from another method with: List<Customer> customers = DeleteCustomer(customers);
但这似乎并不高效,因为相同的变量按值传递然后返回.
在这种情况下传递参数的最有效方法是什么?
解决方法
像所有引用类型一样的列表,作为对象的引用传递,而不是它的副本.
请注意,这与它通过引用传递非常不同,因为这意味着参数的赋值传播给调用者,它不会
它确实意味着对对象的修改(例如由RemoveAt执行的修改)将自动传播给调用者.
因此,只需通过它;不需要返回值或out / ref参数.
您很少会使用out / ref作为引用类型,并且当用于值类型时,性能差异将非常小而不是返回,除非您已经进行了分析并确保问题出现在那里,否则您不必担心它.使用最具惯用意义的东西.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。