C#で演算子のオーバーロードを使用するにはどうすればよいですか?
オーバーロードされた演算子は、特別な名前の関数です。キーワードoperatorの後には、定義されている演算子の記号が続きます。他の関数と同様に、オーバーロードされた演算子には戻り値タイプとパラメーターリストがあります。
次の表は、オーバーロードできる演算子とオーバーロードできない演算子を示しています-
| Sr.No。 | |
|---|---|
| 1 | +、-、!、〜、++、- これらの単項演算子は1つのオペランドを取り、オーバーロードすることができます。 |
| 2 | +、-、*、/、% これらの二項演算子は1つのオペランドを取り、オーバーロードすることができます。 |
| 3 | ==、!=、<、>、<=、> = 比較演算子はオーバーロードされる可能性があります。 |
| 4 | &&、|| 条件付き論理演算子を直接オーバーロードすることはできません。 |
| 5 | + =、-=、* =、/ =、%= 代入演算子はオーバーロードできません。 |
| 6 | =、。、?:、->、new、is、sizeof、typeof これらの演算子はオーバーロードできません。 |
オーバーロードされた演算子は次のように定義されます-
public static Box operator+ (Box b, Box c) { } 例
以下は、C#で演算子のオーバーロードを操作する方法を示す例です-
using System;
namespace OperatorOvlApplication {
class Box {
private double length; // Length of a box
private double breadth; // Breadth of a box
private double height; // Height of a box
public double getVolume() {
return length * breadth * height;
}
public void setLength( double len ) {
length = len;
}
public void setBreadth( double bre ) {
breadth = bre;
}
public void setHeight( double hei ) {
height = hei;
}
// Overload + operator to add two Box objects.
public static Box operator+ (Box b, Box c) {
Box box = new Box();
box.length = b.length + c.length;
box.breadth = b.breadth + c.breadth;
box.height = b.height + c.height;
return box;
}
}
class Tester {
static void Main(string[] args) {
Box Box1 = new Box(); // Declare Box1 of type Box
Box Box2 = new Box(); // Declare Box2 of type Box
Box Box3 = new Box(); // Declare Box3 of type Box
double volume = 0.0; // Store the volume of a box here
// box 1 specification
Box1.setLength(6.0);
Box1.setBreadth(7.0);
Box1.setHeight(5.0);
// box 2 specification
Box2.setLength(12.0);
Box2.setBreadth(13.0);
Box2.setHeight(10.0);
// volume of box 1
volume = Box1.getVolume();
Console.WriteLine("Volume of Box1 : {0}", volume);
// volume of box 2
volume = Box2.getVolume();
Console.WriteLine("Volume of Box2 : {0}", volume);
// Add two object as follows:
Box3 = Box1 + Box2;
// volume of box 3
volume = Box3.getVolume();
Console.WriteLine("Volume of Box3 : {0}", volume);
Console.ReadKey();
}
}
} 出力
Volume of Box1 : 210 Volume of Box2 : 1560 Volume of Box3 : 5400
-
SQL EXISTS:このSQL演算子の使用方法
SQLでクエリを定義するためにできることはたくさんあります。 WHERE句に対して実行できることの1つは、データベース内に一致するパラメーターを持つ行が存在するかどうかを確認することです。これは、EXISTS演算子を使用して行います。 構文は次のとおりです。 SELECT <Column>)FromTable1> FROM <Table 1 Name> WHERE EXISTS (SELECT <Column> FROM <Table 2 Name> WHERE <Table 2 Primary Key> = <
-
Android sqliteでINTERSECT演算子を使用するにはどうすればよいですか?
例に入る前に、Androidのsqliteデータベースが何であるかを知っておく必要があります。 SQLiteは、デバイス上のテキストファイルにデータを保存するオープンソースのSQLデータベースです。 Androidには、SQLiteデータベースの実装が組み込まれています。 SQLiteは、すべてのリレーショナルデータベース機能をサポートしています。このデータベースにアクセスするために、JDBC、ODBCなどのデータベースへの接続を確立する必要はありません。 この例は、AndroidsqliteでINTERSECT演算子を使用する方法について示しています ステップ1 − Android St