What's the difference between #1 and #2:
Code 1 (compiled ok):
byte[] GetSomeBytes()
{
return (byte[])this.Invoke((MethodInvoker)delegate
{
GetBytes();
});
}
byte[] GetBytes()
{
GetBytesForm gbf = new GetBytesForm();
if(gbf.ShowDialog() == DialogResult.OK)
{
return gbf.Bytes;
}
else
return null;
}
Code 2 (didn't complied ok)
int GetCount()
{
return (int)this.Invoke((MethodInvoker)delegate
{
return 3;
});
}
Code #2 gives me Since 'System.Windows.Forms.MethodInvoker' returns void, a return keyword must not be followed by an object expression.
How can I fix it? And why (do) complier think code #1 is right?
In Code #1, your delegate does not return a value - it simply executes GetBytes(), but doesn't return anything. The compiler will not complain because it is not expecting a return value (this is a void method).
However, in code #2 you try to return a value from the delegate -- which is compiler complains about, because you cannot return a value (in this case '3') from a void method.
To answer your first question, try altering your first sample like this:
At this point, you'll have the same compilation error.
public object Invoke(Delegate method)
returns an object, so you can cast the return value to anything and it will compile. However, you are passing in a delegate of typeMethodInvoker
, which has a signaturedelegate void MethodInvoker()
. So, within the body of the method that you cast to MethodInvoker, you cannotreturn
anything.Try this instead for the second one:
Func<int>
is a delegate that returns an int, so it will compile.