해결된 질문
작성
·
223
답변 1
0
안녕하세요, 우선 질문자님께서 어떻게 그렇게 생각하게 되셨는지를 구체적으로 모르겠습니다.
어떤 순서가 헷갈리고 계신 것 같은데 15가 마지막 줄에 따로 나오는 이유가 있을까요?
우선 코드를 보면 출력값인 "Sum : "이 부분은 무조건 가장 마지막에 실행되어야 합니다.
아직 as.sum(5)가 계산되지 않았기 때문에 앞의 Sum과 산술 연산을 할 수 없습니다.
피연산자를 알아야 산술 연산을 할 수 있을테니까요.
그 다음에는 해설에서 말씀드렸던 것처럼, 자식 메서드에서 Add 5를 출력하고, 부모의 sum을 호출합니다.
부모에서는 sum을 부르고 그 때도 자식에서 재정의된 것을 사용합니다.
죽 내려오면서 Add 5 ~ Add 0까지 출력되는 것은 이해하셨으리라 생각하고,
가장 마지막에 15 값이 리턴되어서 그것을 문자열과 더해서 Sum: 15로 출력되는 것입니다.
참고로 저기에서 뒤에 똑같이 다른 값을 넣어서 출력하면 다음과 같이 나옵니다.
학습에 도움이 될 수 있도록 예시를 들어드리겠습니다.
예시)
System.out.println("Sum: " + as.sum(5) + as.sum(2));
출력값)
Add 5
Add 4
Add 3
Add 2
Add 1
Add 0
Add 2
Add 1
Add 0
Sum: 153
여기서 왜 Sum은 153이 나올까요?
문자열끼리 붙으면 더해지기 때문입니다. 실제 153이 아니라 15와 3이 붙어서 나옵니다.