4. 진행 예정 내용 ¶
- 다소 중요하다고 생각된 내용은 보라색 볼드(굵게) 처리하였습니다.
 - #4. 클래스와 객체지향 Part.#2 (5월 25일에서 이어서)
- System.Object와 System.ValueType
 - 배열과 System.Array
 - enum 클래스 타입
 - enum과 Flag 특성
 - this 예약어와 base 예약어
 - 인덱서 구문
 - virtual 예약어와 가상 함수
 - 메서드 오버라이딩과 new 예약어를 통한 메서드 정의
 - 클래스 간의 형변환
 - 추상 메서드와 추상 클래스
 
 - System.Object와 System.ValueType
 - #5. 클래스와 객체지향 Part.#3
- 델리게이트(delegate)의 정의
 - 델리게이트의 특성, C#과 1급 함수
 - System.MulticastDelegate
 - 델리게이트 인스턴스와 산술 연산자
 - 콜백 메서드
 - 인터페이스, 추상 클래스와 인터페이스
 - 인터페이스의 구현
 - 구조체(Struct), 구조체와 클래스
 - 깊은 복사와 얕은 복사, PBV(CBV)와 PBR(CBR)
 - ref와 out 예약어를 통한 PBR
 
 - 델리게이트(delegate)의 정의
 역시 모두 진행 가능할 지는 진행해야 알 것 같습니다.
될 리가 없었다. (?!)
5.1.1. 4. 클래스와 객체지향 Part.#2 (이어서) ¶
- Enum : 정수형 상수로 지정
- 선언
 
 - 선언
 
Enum Day{ Monday, Tuesday = 2, Wednesday, Thursday, Friday, Saturday, Sunday }
//Monday = 0, Tuesday = 2, Wednesday = 3, Thursday = 4, Friday = 5, Saturday = 6, Sunday = 7
- 사용
 
Day working = Day.Monday; Console.WriteLine(workingdays);//Monday Console.WriteLine((int)workingdays);//0
- 기준이 int -> 만약 크기를 키우려면 선언에서 Enum 이름 : 자료형
 - Enum은 숫자다. -> Bit 연산자 사용 가능
 - Flags를 붙이면 Bit 연산자로 연결하면 Monday, Tuesday 이런 식으로 출력해줌
 
- this와 base
- 자기자신의 인스턴스의 변수 사용 : this.변수명
 - 상속한 클래스의 변수 사용 : java에서 super, C#에서는 base
 
 - 자기자신의 인스턴스의 변수 사용 : this.변수명
 - 인덱서 구문 : []구문을 재정의
- 사용
 
 - 사용
 
private int[] arr;
public int this[int index]{
	get
	{
		return this.arr[index];
	}
	set
	{
		this.arr[index]=value;
	}
}
- 정의만 한다면 String이나 다른 변수도 가능
 
- virtual과 override
- 다형성을 위한 키워드
 - virtual : 부모 클래스에 붙임(붙여도 override 안할 수도)
 - override : 자식 클래스에 붙임(재정의를 확실히 하기 위해)
 - new : 이름만 같고 재정의 아님
 
 - 다형성을 위한 키워드
 - 클래스 형변환
- 명시적 형변환 : explicit
 - 암시적 암시적 : implicit
 
 - 명시적 형변환 : explicit
 - abstract : 틀만 제공하는 클래스
- 역시나 override를 붙여서 구현해야 함.
 
 - 역시나 override를 붙여서 구현해야 함.
 - 생성자 위임 : C++ 스타일로(: 이용)
 
5.1.2. 5. 클래스와 객체지향 Part.#3 ¶
- 델리게이트의 정의
- 함수 포인터라 이해하면 편함.
 
 - 함수 포인터라 이해하면 편함.
 
Class Math{
	public delegate void CalcDelegate(int x, int y);
	public Math(){
		CalcDelegate calc = this.Add;
		calc(1, 2);
	}
	public void Add(int x,int y){Console.WriteLine(x+y);}
	public void Sub(int x,int y){Console.WriteLine(x-y);}
}
- 델리게이트의 특성
- 함수 포인터와 다른 점 : 가르키고 있는 함수의 특성을 가지고 있음.(Static이면 0)
 - pointer to member와의 다른 점 : 형식만 맞으면 다른 클래스의 것이라도 가능
 
 - 함수 포인터와 다른 점 : 가르키고 있는 함수의 특성을 가지고 있음.(Static이면 0)
 - 1급 함수
- 메소드에서 Delegate를 리턴할 수 있음
 - 파라미터로 Delegate를 넘길 수 있음
 - 클래스의 멤버변수로써의 Delegate를 가질 수 있음
 
 - 메소드에서 Delegate를 리턴할 수 있음
 - Object->Delegate->MultiCastDelegate
- MuitiCastDelegate : 여러개를 연결할 수 있음(+=,-= 이용)
 
 - MuitiCastDelegate : 여러개를 연결할 수 있음(+=,-= 이용)
 - 콜백 메서드 : 호출자(A)가 피호출자(B)를 불렀는데 거기서 호출자(A)를 부름
- ex) Sort에서 함수 포인터
 
 - ex) Sort에서 함수 포인터
 - abstract class->Interface
- Interface : 0개 이상의 추상 메서드만 담을 수 있는 무언가
 - 정의 : interface 이름{}(이름에 I를 붙여줌)
 - 상속받은 class에서 정의
 - Interface는 override를 쓰면 안됨.
 
 - Interface : 0개 이상의 추상 메서드만 담을 수 있는 무언가
 - 구조체 : 값 형식
- 나머지는 Class처럼 정의
 - new로도 선언 가능 -> new로 선언해도 값 형식임은 유지됨.
 
 - 나머지는 Class처럼 정의
 - 깊은 복사, 얕은 복사
- 깊은 복사(Call By Value) : 값을 옮김
 - 얕은 복사(Call By Reference) : 참조를 옮김
 
 - 깊은 복사(Call By Value) : 값을 옮김
 - ref : 값 형식으로 줘도 참조 형식으로 옮겨감(단, 쓰기 전에 할당 해야됨)
- out : ref의 부분집합, 쓰기 전에 할당을 하지 않아도 됨(단, 반환 전에 할당 해야됨), 할당 전에는 다른 변수에서 참조 불가능
 
 - out : ref의 부분집합, 쓰기 전에 할당을 하지 않아도 됨(단, 반환 전에 할당 해야됨), 할당 전에는 다른 변수에서 참조 불가능
 










