inflearn logo
강의

Course

Instructor

Linear Data Structures for People Who Learned C the Hard Way

Additional improvements and conclusion

05_adtFileIO 개정이력에 대한 질문

Resolved

42

tjrghks0216

1 asked

0

안녕하세요.

LinearDataStructure 프로젝트의 main함수 내용을 보니


puts("2024-03-20\t전**님의 제보에 따른 05_adtFileIO 예제 버그 수정(v1.5)");

puts("\t\t(사용자가 새로운 항목 추가 시 파일 저장위치 옵셋이 0으로 하드코딩된 오류)");


라고 되어있길래
AddNewUser() 함수 정의를 살펴보니 아직 AddNewNode()함수 호출 시 offset이 0으로 하드코딩 되어있더라구요.

 

혹시 제공된 예제코드에 아직 반영이 되지 않은것일까요?

 

물론 이벤트루프가 종료되면서 SaveNewDataToFile함수에서 append모드로 파일이 열려서 파일의 맨 끝부터 정상적으로 추가되고, 다음에 다시 실행하면 MYNODE의 offset이 정상적으로 반영은 되더라구요.

 

그런데 새로 유저를 추가하고, 그 유저를 바로 검색해서 수정한뒤, commit을 한다고 하면, 그때 그 유저의 노드에 담겨져 있는 offset은 0이기 때문에, 가장 앞에 있는 노드의 데이터가 덮어씌워지는 것을 확인했습니다. (예제에서는 'Hoon')

 

전** 님의 Q&A에 답변하신 것 처럼 전역변수 이용해서 offset을 지정하면 이런 문제가 해결되지 않을까 싶습니다.

 

항상 좋은 강의 감사합니다. 선생님 강의 들으면서 매번 쾌감이 느껴집니다.

c 코딩-테스트 알고리즘 vc++

Answer 2

1

nullnull8537

제보 고맙습니다. 관련 내용을 이미 오래 전에 수정반영 하였는데 다른 문제가 더 있거나 혹은 파일이 제대로 올라가지 않았을 수 있습니다. 확인해보도록 하겠습니다. 😄

0

tjrghks0216

네. 잘 듣고 있습니다 선생님

0

communityai8509

안녕하세요, 인프런 AI 인턴입니다. 정스카이님!

질문해주신 부분에 대해 유사한 사례를 확인해 본 결과, 질문하신 사례와 관련된 정보를 제공하고자 합니다.

질문의 내용을 보면, 예제 코드의 버그 수정을 이미 제보해 주신 “전**님”의 사례와 관련이 있을 수 있습니다. 이와 관련하여 비슷한 질문 및 답변들이 있는데, 아래 링크들을 확인해 보시면 도움이 되실 것 같습니다:

  1. 05_adtFileIO 질문있어요. - 여기에서는 SaveNodeToFile() 함수에 관한 질문과 함수의 수정사항에 대한 논의가 있습니다. 이를 참고하여 수정 방안에 대한 아이디어를 얻을 수 있습니다.

  2. 05_adtFileIO 프로젝트 문의 - 데이터 캐싱과 commit 논리 문제에 대한 질문을 통해, 예제 코드가 어떻게 동작하고 어떤 방식으로 수정될 수 있는지 논의됩니다. 이는 예제에서 파일의 행동을 어떻게 수정할 수 있을지를 이해하는 데 도움을 줍니다.

이 피드백들은 파일 오프셋 및 데이터 추가 시 ‘Hoon’ 노드에 대한 수정이 필요한 점을 반영하여, 전역 변수나 다른 방법을 통해 오프셋 문제를 해결하는 방안을 탐색할 수 있도록 도와주며, 스카이님이 이야기하신 버그를 인지하고 개선해 나가는 데 도움이 될 것입니다.

현재 제공된 예제에 아직 반영되지 않은 것 같다면, 위에서 설명한 방식으로 직접 개선해 보시길 권장합니다. 강의를 통해 불완전한 부분을 직접 수정하면서 개발자적인 사고와 실력을 키우는 것도 좋은 기회가 될 것입니다.

저는 질문자님 이해를 돕고자 지식공유자님 기존 답변을 참고하여 유사한 답변 링크를 추천해 드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주시면 곧 지식공유자께서 답변해 주실 것입니다.

마지막 열의 노드를 삭제하였을때 읽기 엑세스 위반 발생 건

0

61

2

첫번째 루프에서 최소값을 못찾았는데 계속 진행하는 이유가 무엇인가요?

0

47

1

[질문]: [섹션4] -> [2중 연결 리스트로 전환] -> [21:30]

0

129

2

인덱스정렬 강의, 04_ListAndIndex질문드립니다.

0

125

1

예제는 어디서 다운로드 받을 수 있나요?

0

178

2

04_MultiIndex 예제에서 질문이 있습니다

0

120

1

헤드노드에 관해..

0

231

3

AddNewNode 함수 구현시 질문입니다.

0

160

2

Event Loop

0

191

1

인덱스정렬 강의, 04_ListAndIndex질문드립니다.

0

192

1

CPU의 다른 이름 Machine 강의 질의

0

273

4

스택의 POP코드 질문드립니다.

0

259

1

adtFileIO 예제코드관련 질문 있습니다.

0

170

1

ADT강의 관련 질문 있습니다.

0

231

2

RangeSearch002 의 singlelist.c 파일 중 질문 있습니다.

0

192

1

섹션4 자료 자체와 정렬된 인덱스 분리 내용 질문

0

252

2

자료 자체와 정렬된 인덱스 분리 강의에서 질문

0

234

2

구현 연습에 대한 개인적 의문

0

279

1

05_adtFileIO 프로젝트 문의

0

318

2

CLI UI적용 강의에서 질문드립니다.

0

333

1

SearchToRemove와 RemoveNode가 분리되어야 할 필요가 있을까요?

0

293

1

05_adtFileIO 프로젝트 문의

0

257

1

자료 자체와 정렬된 인덱스 분리 (인덱스 정렬) - 인덱스 범위 코드에 버그가 있어서 질문 드립니다.

0

304

2

강의자료 관련

0

203

1