inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

C 프로그래밍 - 입문부터 게임 개발까지

scanf_s 예외가 발생함

1470

fairenough1546

작성한 질문수 2

1

다음 사진처럼 코드를 짠 상황에서 'f5'를 눌러 실행을 한 뒤 c1과 c2에 각각

a b

를 치고 enter를 누르면 다음과 같이 예외가 발생했다며 오류?가 뜹니다. 

해결방법 아시는 분 계신가요ㅠㅠ

c

답변 1

0

skyline

안녕하세요!

scanf_s 함수는 C언어의 기본 함수인 scanf 함수의

저장하려는 변수 크기보다 입력된 데이터의 크기가 더 클 때

변수의 저장 공간(메모리)을 덮어버리며 발생할 수 있는 *취약점을 막기 위해 사용됩니다.

scanf_s("%c %c", &c1, sizeof(c1), &c2, sizeof(c2)) 와 같이

함수 호출 시 각 변수의 사이즈를 추가로 넘겨주셔야 합니다.

* 버퍼 오버플로우 취약점 (buffer overflow) : 

 데이터를 버퍼에 저장할 때 프로그래머가 지정한 곳 바깥에 저장하는 것을 의미한다.

벗어난 데이터는 인접 메모리를 덮어 쓰게 된다.

(출처: 위키백과: 버퍼 오버플로)

0

fairenough1546

혹시 #pragma warning(disable:4996)선언하고 scanf_s 가 아닌 scanf를 쓰면 sizeof를 사용 안해도 되나요?

아니면 그것과 상관없이 sizeof를 사용해줘야 하나요? 

0

skyline

넵 scanf 사용시에는 sizeof 사용 안하시면 됩니다!

추가로, #pragma warning(disable:4996)

외에도

#define _CRT_SECURE_NO_WARNINGS

를 사용하기도 합니다.

scanf 외에도 gets, strcpy, strcat 등 문자열 관련 함수들이 같은 취약점이 있습니다.

안녕하세요 7장 포인터에 관해 질문드립니다.

0

63

1

8-8 연장전 / 소스코드 공유해드려요. 참고하세요!

0

64

0

섹션6. 프로젝트 소스코드 올려드려요.

0

93

1

영상속에서 배운 코드들을 Git Repository에 올려두될까요?

0

79

1

경찰서 조서 프로젝트 문의

0

104

1

경찰관 조서 프로젝트

0

142

1

scanf

0

92

1

제대로 작성한것 같은데 빌드가 않됩니다.,

0

170

1

구문 오류 C2059

0

397

1

컴파일 시 fatal error C1010 발생

0

284

1

반환값이 없는 함수

0

215

1

반올림 되는건가요?

0

252

1

맥으로수강

0

193

1

10-2

0

257

1

질문이 있습니다

0

341

1

3-3 for 반복문 ++i 일때 질문입니다.

0

244

1

6-4(배열 파트 '문자 vs 문자열') sizeof 예제 다르게 출력되는 분들 참고하세요.

1

411

0

함수 선언과 정의를 동시에 해도 되나요?

0

1076

1

빌드오류가 있다고 나오고, 지정된 파일을 찾을 수 없다고 오류가 나옵니다..

0

403

1

안녕하세요 좋은 강의와 책 감사드립니다!! 다름이 아니라 명령어를 실행시켰을 때 저런식으로 나와서 질문드립니다

0

933

0

질문있습니다!

0

376

1

질문드립니다

0

384

1

scanf_s(" %d", &answer); 이후 바로 종료

0

309

0

질문 드립니다.

0

429

1