• 카테고리

    질문 & 답변
  • 세부 분야

    프로그래밍 언어

  • 해결 여부

    해결됨

[3:21]전위/후위증가 오버로딩 구별 질문(dummy)

21.04.03 23:55 작성 조회수 325

3

안녕하세요! 항상 감사드립니다.

3:21경에 전위/후위증가 연산자 오버로딩의 구별을

매개변수에 int라는 더미를 넣어 오버로딩을 한다고

설명해 주셨는데, 메인 함수의 ++d와 d++이 어떻게

더미에 의해 구별이 되는지 궁금합니다.

디버거를 돌려봐도 잘 이해가 가지 않네요..

(아니면 그냥 암기해야하는 부분인지...)

답변 2

·

답변을 작성해보세요.

12

안소님의 프로필

안소

2021.04.04

안녕하세요 :)

전위 증가 연산자와 후위 증가 연산자는 아시다시피 작동되는 과정이 다릅니다.

각각의 과정에 따라 전위 증가 연산자의 리턴 타입은 L-value 참조이며 후위 증가 연산자의 리턴 타입은 R-value 입니다. (리턴 타입이 다른 이유와 작동원리는 https://www.inflearn.com/questions/108838 이 링크를 참고해주세요)

앞에서 배우셨겠지만 함수가 오버로딩되는 조건에 "리턴 타입"은 해당되지 않습니다.

즉, 리턴 타입이 다르더라도, 오버로딩 조건인 함수 이름, 매개변수 개수, 매개변수 타입이 같다면 동일한 함수로 인식된다는 이야기입니다. 동일한 함수를 또 정의하는 것은 문법적 오류입니다.

따라서 전위 증가연산자와 후위 증가 연산자를 구별할 수 있는 것은 리턴 타입 뿐이라는 것인데, 위에서 설명드린 것과 같이 리턴 타입만으로는 컴파일러가 두 연산자를 구별할 수가 없고 동일한 함수로 인식합니다. 더군다나 연산자 이름도 ++ 로 같으니까요 ㅠ

따라서 매개 변수에 더미를 추가해준 것입니다.  매개변수의 개수가 다르면 함수의 이름이 동일하더라도 다른 함수로 인식됩니다. 즉, 오버로딩이 되는 것입니다. 이는 앞에서 배우셨을 함수 오버로딩 부분을 복습해보시면 이해가 되실 것입니다.

따라서 사용하지 않을 더미 매개변수를 하나 더 추가하여 두 연산자를 컴파일러가 구별할 수 있도록 해준 것입니다. 리턴타입이 다른 것만으로는 두 연산자가 구분이 되기에 충분하지 않기 때문입니다.

https://stackoverflow.com/questions/36816973/purpose-of-dummy-parameter-in-postfix-operator-overload-c

이 링크를 참고해보셔도 좋을 것 같습니다.

asdfaa22님의 프로필

asdfaa22

질문자

2021.04.05

"사용하지 않을" 에서 설명이 다 된 것 같습니다.. 감사합니다!

4

호두님의 프로필

호두

2021.04.04

joy님의 정성스러운 답변에 좋아요를 눌러주세요~