내 질문에 답이 달리지 않는다면?
다음 중 빠진 것이 있는지 확인해보자.
1. 내가 짠 코드
2. 코드의 목적
3. 시도해본 것
4. 오류의 종류
5. 에러 메시지
1. 내가 짠 코드
- 코드를 보여주지 않으면 무슨 문제를 풀고자 하는지 알기 어렵다.
- 어떤 문제는 말보다 코드로 설명하는 것이 더 좋을 때가 있다.
- 문제를 푸는 방법이 한 가지가 아닐 때가 많다.
- 이미 짜놓은 코드에 따라 좋은 해답이 달라질 수 있다.
- 코드를 보면 어디가 잘못됐는지 콕 짚어줄 수 있다.
2. 코드의 목적
- 코드의 목적을 알려주지 않으면 답변자가 코드를 보고 해석해야 한다.
- 코드를 봐도 어떤 문제를 풀고자 하는지 알기 어렵다.
- 사람마다 코딩 스타일이 다르므로 코드 해석에 시간이 소요된다.
- 코드에 여러 문제가 혼재되어 있을 수 있다.
- 코드의 목적을 알면 아예 더 간단한 방법을 알려줄 수도 있다.
3. 시도해본 것
- 풀고자 하는 문제에 특별한 조건 및 제한이 걸려있을 수 있다.
- 보통이라면 좋은 방법이, 조건/제한이 복잡한 경우에는 그렇지 않을 수 있다.
- 이미 시도해본 것을 알려주지 않으면 질문자와 답변자의 시간이 낭비된다.
- 이미 시도해본 것을 알면, 왜 그 방법은 배제해야 하는지 토론이 가능하다.
- 이미 시도해본 것에서 약간만 수정하면 최적의 솔루션이 나올 수도 있다.
4. 오류의 종류
- 답변자는 전지전능하지 않다.
- 오류는 다양하다.
- 결과가 이상한지? 반응이 없는지? 에러가 났는지? 프로그램이 꺼지는지?
- "안된다"는 말은 아무런 정보를 주지 못한다. 중요한 정보는 "어떻게"에 들어 있다.
- 당연한 얘기지만, 오류의 종류에 따라 해결책은 달라진다.
5. 에러 메시지
- 답변자는 전지전능하지 않다고 말했다.
- 에러의 종류도 다양하다. IndexError? KeyError? IndentationError? TypeError? AttributeError?
- 에러 메시지에는 디버깅에 필요한 모든 정보가 다 들어있다.
- 전문가도 맨날 에러 메시지를 만난다. 그걸 해석하고 해결하니까 전문가라고 불린다.
- 다시 말하지만, 중요한건 '안된다'는 사실이 아니다. '어떻게' 안되는지가 중요하다.
- 게으른
같이 읽기