2014년 2월 19일 수요일

[C#,구로닷넷교육]연산자 오버로딩(bool, ==, Equals),C#/ASP.NET/ADO닷넷/닷넷교육/닷넷강좌학원/닷넷공부/닷넷책/닷넷객체지향교육 다음은 C#에서 오버로딩 할 수 있는 연산자들이다. 단항 연산자 : +, -, !, ~, ++, --, true, false 이항 연산자 : +, -, *, /, %, &, |, ^, <<, >> 비교 연산자 : ==, !=, <, <=, >, >= - true와 false를 오버라이딩 하면 클래스들을 부울 표식 안에서 사용 할 수 있다. - += 같은 배정 연산자는 오버로딩 할 수 없지만 +연산자를 오버로딩 함으로서 +=을 오버로딩 한 것과 같은 효과를 나타낸다. =의 경우 오버로딩 할 수 없는데 이 연산자는 작동 방식을 바꿀 필요가 없는 것이다. &&와 ||역시 오버로딩 할 수 없는데 이것 역시 &, |를 오버로딩 하면 된다. - < 와 >의 경우 반드시 쌍으로 오버로딩 해야 한다. 즉 < 를 오버로딩 했을 때 >도 반드시 오버로딩 오버로딩 해야 한다. 비교연산자를 오버로딩 할 때는 한 연산자에서 다른 연산자를 호출하는 식으로 구현해서 코드를 줄이곤 한다. public class AddClass1 { public int val; public static bool operator >= (AddClass1 op1, AddClass1 op2) { return (op1.val >= op2.val); } public static bool operator < (AddClass1 op1, AddClass1 op2) { return !(op1 >= op2); } } - ==와 != 연산자에 대해서는 위의 경우 처럼 사용이 가능하나 Object.Equals()와 Object.GetHashCode()도 재정의 하는 경우가 많이 있다. 즉 ==를 재정의 하는 부분에서 Equals 메소드도 재정의 함으로서 사용자가 == 또는 Equals() 어느 것으로 비교 하든지 같은 결과가 나타나게 할 수 있다. [예제] using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace ConsoleApplication2 { public class AddClass1 { public int val; public static bool operator ==(AddClass1 op1, AddClass1 op2) { return (op1.val == op2.val); } public static bool operator !=(AddClass1 op1, AddClass1 op2) { return !(op1 == op2); } public override bool Equals(object op1) { return val == ((AddClass1)op1).val; } //GetHashCode 는 개체의 상태에 기반한 고유한 int 값을 얻는데 사용 한다. public override int GetHashCode() { return val; } static void Main() { AddClass1 op1 = new AddClass1(); op1.val = 2; AddClass1 op2 = new AddClass1(); op2.val = 2; Console.WriteLine("op1 = op2 = {0}", op1 == op2); Console.WriteLine("op1 = op2 = {0}", op1.Equals(op2)); } } } [연산자 오버로딩 예제] 두 날짜의 차이를 구하기 위한 예문 using System; public class Time { private int Year = 0; private int DDay = 0; private int Month = 0; // 기본 생성자 public Time() { this.Year = 0; this.Month = 0; this.DDay = 0; } //매개변수가 있는 경우의 생성자 public Time(int Year, int Month, int DDay) { this.Year = Year; this.Month = Month; this.DDay = DDay; } // ‘-‘ 연산자 Overloading public static Time operator-(Time t1, Time t2) { int newYear = t1.Year - t2.Year; //년도는 그냥 빼자 int newMonth = 0; int newDDay = 0; //뒤의 월이 큰 경우 if (t1.Month < t2.Month) { newYear = newYear -1; //년을 1 빼고 newMonth = newMonth + 12; //월을 12를 더 해줌, Carry(올림수) } newMonth = newMonth + t1.Month - t2.Month; //뒤의 일이 큰 경우 if (t1.DDay < t2.DDay) { newMonth = newMonth -1; newDDay = newDDay + 30; } newDDay = newDDay + t1.DDay - t2.DDay; Time newTime = new Time(newYear, newMonth, newDDay); return newTime; } public override string ToString() { return String.Format("{0}:{1}:{2}", Year, Month, DDay); } } public class OpOverloadTest { public static void Main() { Time t1 = new Time(2014, 01, 05); Time t2 = new Time(2012, 07, 07); Time t3 = t1 - t2; Console.WriteLine(t1); Console.WriteLine(t2); Console.WriteLine(t3); } } [출처] 오라클자바커뮤니티 - http://www.oraclejavanew.kr/bbs/board.php?bo_table=LecCsharp&wr_id=151

[C#,구로닷넷교육]연산자 오버로딩(bool, ==, Equals),C#/ASP.NET/ADO닷넷/닷넷교육/닷넷강좌학원/닷넷공부/닷넷책/닷넷객체지향교육

다음은 C#에서 오버로딩 할 수 있는 연산자들이다.

단항 연산자 : +, -, !, ~, ++, --, true, false
이항 연산자 : +, -, *, /, %, &, |, ^, <<, >>
비교 연산자 : ==, !=, <, <=, >, >=

- true와 false를 오버라이딩 하면 클래스들을 부울 표식 안에서 사용 할 수 있다.
- += 같은 배정 연산자는 오버로딩 할 수 없지만 +연산자를 오버로딩 함으로서 +=을 오버로딩 한 것과 같은 효과를 나타낸다. =의 경우 오버로딩 할 수 없는데 이 연산자는 작동 방식을 바꿀 필요가 없는 것이다.  &&와 ||역시 오버로딩 할 수 없는데 이것 역시 &, |를 오버로딩 하면 된다. 
- < 와 >의 경우 반드시 쌍으로 오버로딩 해야 한다. 즉 < 를 오버로딩 했을 때 >도 반드시 오버로딩 오버로딩 해야 한다. 비교연산자를 오버로딩 할 때는 한 연산자에서 다른 연산자를 호출하는 식으로 구현해서 코드를 줄이곤 한다.

public class AddClass1 {
public int val;
public static bool operator >= (AddClass1 op1, AddClass1 op2) {
return (op1.val >= op2.val);
}
public static bool operator < (AddClass1 op1, AddClass1 op2) {
return !(op1 >= op2);
}
}

- ==와 != 연산자에 대해서는 위의 경우 처럼 사용이 가능하나 Object.Equals()와 Object.GetHashCode()도 재정의 하는 경우가 많이 있다. 즉 ==를 재정의 하는 부분에서 Equals 메소드도 재정의 함으로서 사용자가 == 또는 Equals() 어느 것으로 비교 하든지 같은 결과가 나타나게 할 수 있다. 

[예제]
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace ConsoleApplication2
{
    public class AddClass1
    {
        public int val;
        public static bool operator ==(AddClass1 op1, AddClass1 op2)
        {
            return (op1.val == op2.val);
        }
        public static bool operator !=(AddClass1 op1, AddClass1 op2)
        {
            return !(op1 == op2);
        }

        public override bool Equals(object op1)
        {
            return val == ((AddClass1)op1).val;
        }

        //GetHashCode 는 개체의 상태에 기반한 고유한 int 값을 얻는데 사용 한다.
        public override int GetHashCode()
        {
            return val;
        }

      

        static void Main()
        {
            AddClass1 op1 = new AddClass1();
            op1.val = 2;

            AddClass1 op2 = new AddClass1();
            op2.val = 2;

            Console.WriteLine("op1 = op2 = {0}", op1 == op2);
            Console.WriteLine("op1 = op2 = {0}", op1.Equals(op2));

        }
    }



}



[연산자 오버로딩 예제] 두 날짜의 차이를 구하기 위한 예문

using System;
public class Time 
{
private int Year = 0;
private int DDay = 0;
private int Month = 0;
// 기본 생성자
public Time() 
{
this.Year = 0;
this.Month = 0;
this.DDay = 0;
}
//매개변수가 있는 경우의 생성자
public Time(int Year, int Month, int DDay) 
{
this.Year = Year;
this.Month = Month;
this.DDay = DDay;
}
// ‘-‘ 연산자 Overloading
public static Time operator-(Time t1, Time t2) 
{
int newYear = t1.Year - t2.Year;  //년도는 그냥 빼자
int newMonth = 0;
int newDDay = 0;

//뒤의 월이 큰 경우
if (t1.Month < t2.Month) 
{
newYear = newYear -1;     //년을 1 빼고
newMonth = newMonth + 12; //월을 12를 더 해줌, Carry(올림수)
}

newMonth = newMonth + t1.Month - t2.Month;
//뒤의 일이 큰 경우
if (t1.DDay < t2.DDay) 
{
newMonth = newMonth -1;
newDDay = newDDay + 30;
}
newDDay = newDDay + t1.DDay - t2.DDay;

Time newTime = new Time(newYear, newMonth, newDDay);
return newTime;
}

public override string ToString() 
{
return String.Format("{0}:{1}:{2}", Year, Month, DDay);
}
}

public class OpOverloadTest 
{
public static void Main() 
{
Time t1 = new Time(2014, 01, 05);
Time t2 = new Time(2012, 07, 07);
Time t3 = t1 - t2;

Console.WriteLine(t1);
Console.WriteLine(t2);
Console.WriteLine(t3);
}
}

댓글 없음:

댓글 쓰기