해결된 질문
작성
·
430
답변 2
12
안녕하세요 :)
전위 증가 연산자와 후위 증가 연산자는 아시다시피 작동되는 과정이 다릅니다.
각각의 과정에 따라 전위 증가 연산자의 리턴 타입은 L-value 참조이며 후위 증가 연산자의 리턴 타입은 R-value 입니다. (리턴 타입이 다른 이유와 작동원리는 https://www.inflearn.com/questions/108838 이 링크를 참고해주세요)
앞에서 배우셨겠지만 함수가 오버로딩되는 조건에 "리턴 타입"은 해당되지 않습니다.
즉, 리턴 타입이 다르더라도, 오버로딩 조건인 함수 이름, 매개변수 개수, 매개변수 타입이 같다면 동일한 함수로 인식된다는 이야기입니다. 동일한 함수를 또 정의하는 것은 문법적 오류입니다.
따라서 전위 증가연산자와 후위 증가 연산자를 구별할 수 있는 것은 리턴 타입 뿐이라는 것인데, 위에서 설명드린 것과 같이 리턴 타입만으로는 컴파일러가 두 연산자를 구별할 수가 없고 동일한 함수로 인식합니다. 더군다나 연산자 이름도 ++ 로 같으니까요 ㅠ
따라서 매개 변수에 더미를 추가해준 것입니다. 매개변수의 개수가 다르면 함수의 이름이 동일하더라도 다른 함수로 인식됩니다. 즉, 오버로딩이 되는 것입니다. 이는 앞에서 배우셨을 함수 오버로딩 부분을 복습해보시면 이해가 되실 것입니다.
따라서 사용하지 않을 더미 매개변수를 하나 더 추가하여 두 연산자를 컴파일러가 구별할 수 있도록 해준 것입니다. 리턴타입이 다른 것만으로는 두 연산자가 구분이 되기에 충분하지 않기 때문입니다.
이 링크를 참고해보셔도 좋을 것 같습니다.
4
"사용하지 않을" 에서 설명이 다 된 것 같습니다.. 감사합니다!