C# でポスト インクリメント演算子をオーバーロードしようとすると問題が発生します。整数を使用すると、次の結果が得られます。
int n;
n = 10;
Console.WriteLine(n); // 10
Console.WriteLine(n++); // 10
Console.WriteLine(n); // 11
n = 10;
Console.WriteLine(n); // 10
Console.WriteLine(++n); // 11
Console.WriteLine(n); // 11
でも、クラスでやってみるとオブジェクトが入れ替わっているように見えます。
class Account
{
public int Balance { get; set; }
public string Name { get; set; }
public Account(string name, int balance)
{
Balance = balance;
Name = name;
}
public override string ToString()
{
return Name + " " + Balance.ToString();
}
public static Account operator ++(Account a)
{
Account b = new Account("operator ++", a.Balance);
a.Balance += 1;
return b;
}
public static void Main()
{
Account a = new Account("original", 10);
Console.WriteLine(a); // "original 10"
Account b = a++;
Console.WriteLine(b); // "original 11", expected "operator ++ 10"
Console.WriteLine(a); // "operator ++ 10", expected "original 11"
}
}
アプリケーションをデバッグすると、オーバーロードされたオペレーター メソッドは古い値 (10) を持つ新しいオブジェクトを返し、参照によって渡されたオブジェクトは新しい値 (11) を持ちますが、最終的にオブジェクトが交換されます。なぜこうなった?