scanf_s 예외가 발생함
1470
작성한 질문수 2
다음 사진처럼 코드를 짠 상황에서 'f5'를 눌러 실행을 한 뒤 c1과 c2에 각각
a b
를 치고 enter를 누르면 다음과 같이 예외가 발생했다며 오류?가 뜹니다.
해결방법 아시는 분 계신가요ㅠㅠ.png)
답변 1
0
안녕하세요!
scanf_s 함수는 C언어의 기본 함수인 scanf 함수의
저장하려는 변수 크기보다 입력된 데이터의 크기가 더 클 때
변수의 저장 공간(메모리)을 덮어버리며 발생할 수 있는 *취약점을 막기 위해 사용됩니다.
scanf_s("%c %c", &c1, sizeof(c1), &c2, sizeof(c2)) 와 같이
함수 호출 시 각 변수의 사이즈를 추가로 넘겨주셔야 합니다.
* 버퍼 오버플로우 취약점 (buffer overflow) :
데이터를 버퍼에 저장할 때 프로그래머가 지정한 곳 바깥에 저장하는 것을 의미한다.
벗어난 데이터는 인접 메모리를 덮어 쓰게 된다.
(출처: 위키백과: 버퍼 오버플로)
0
혹시 #pragma warning(disable:4996)선언하고 scanf_s 가 아닌 scanf를 쓰면 sizeof를 사용 안해도 되나요?
아니면 그것과 상관없이 sizeof를 사용해줘야 하나요?
0
넵 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





