委托是引用类型,但在尝试将其传递给方法时仍需要ref关键字。
这让我想起了一个字符串,它需要在一个方法中修改ref,因为它们是不可变的,委托是不可变的吗?
这是我的迷你项目:
delegate void MyDel();
static void Main(string[] args)
{
MyDel _del = new MyDel(Idle);
while(true)
{
if(_del != null)
_del();
int c = Console.Read();
AI(c,ref _del);
Console.Read();
Console.Read();
}
}
}
static void AI(int c, ref MyDel del)
{
if(c == 'a')
{
del = Attack;
}else if(c == 'i'){
del = Idle;
}else if (c == 's'){
del = SwingSword;
}
else if (c == 'w')
{
del = Attack;
del += SwingSword;
}
else {
del = Idle;
}
}
如果没有ref关键字,我会回到交换方法的情况,只会在方法内部发生。
有谁可以告诉我为什么代表需要通过引用传递?
答案 0 :(得分:4)
您必须使用ref的原因是因为您要更改_del
引用的委托。
将您的代码更改为以下内容,您将不需要ref参数:
static MyDel AI(int c)
{
if(c == 'a')
{
return Attack;
}
if(c == 'i')
{
return Idle;
}
if (c == 's')
{
return SwingSword;
}
if (c == 'w')
{
return (MyDel)Attack + SwingSword;
}
return Idle;
}
除非您指定ref
关键字,否则C#不会通过引用传递。但是,由于委托类型变量的值是对方法的引用,因此传递的值是引用。使用ref
关键字并传递对变量存储的引用,而不是方法,因此可以更改其值。
如果前一段与泥浆一样清楚,请阅读https://stackoverflow.com/a/8708674/7122,这是对价值传递与传递参考的非常好的解释。
答案 1 :(得分:3)
这不是关于不变性。您为外部作用域中声明的变量分配一个新值,并且您希望外部作用域知道此作业 - 这就是您需要ref
的原因。
对于任何类型都是如此。
* 修改的
“外部范围”实际上并不是最好的术语。 “调用方法的范围”就是我的意思。