-
Notifications
You must be signed in to change notification settings - Fork 4
Gendarme.Rules.Performance.AvoidUnneededUnboxingRule(2.10)
Sebastien Pouliot edited this page Jan 22, 2011
·
2 revisions
Assembly: Gendarme.Rules.Performance
Version: 2.10
This rule checks methods which unbox the same value type multiple times (i.e. the value is copied from the heap into the stack). Because the copy is relatively expensive, the code should be rewritten to minimize unboxes. For example, using a local variable of the right value type should remove the need for more than one unbox instruction per variable.
Bad example:
public struct Message {
private int msg;
private IntPtr hwnd, lParam, wParam, IntPtr result;
public override bool Equals (object o)
{
bool result = (this.msg == ((Message) o).msg);
result &= (this.hwnd == ((Message) o).hwnd);
result &= (this.lParam == ((Message) o).lParam);
result &= (this.wParam == ((Message) o).wParam);
result &= (this.result == ((Message) o).result);
return result;
}
}
Good example:
public struct Message {
private int msg;
private IntPtr hwnd, lParam, wParam, IntPtr result;
public override bool Equals (object o)
{
Message msg = (Message) o;
bool result = (this.msg == msg.msg);
result &= (this.hwnd == msg.hwnd);
result &= (this.lParam == msg.lParam);
result &= (this.wParam == msg.wParam);
result &= (this.result == msg.result);
return result;
}
}
- This rule is available since Gendarme 2.0
Note that this page was autogenerated (3/17/2011 9:31:58 PM) based on the xmldoc
comments inside the rules source code and cannot be edited from this wiki.
Please report any documentation errors, typos or suggestions to the
Gendarme Mailing List. Thanks!