VS中的scanf_s函数和scanf
                                                            生活随笔
收集整理的這篇文章主要介紹了
                                VS中的scanf_s函数和scanf
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.                        
                                今天,在電腦上安裝了VS2017,因為以前一直使用的是VC6.0和Dev_cpp,所以第一次使用VS有些笨拙。
今天建立的第一個C程序“hello world!”便于到的很大的難題
#include<stdio.h> void main() {printf("hello world!\n");}運行無誤之后,在原先的代碼上添加了一些內容如下:
#include<stdio.h> void main() {int a;printf("please input the number:\n");scanf("%d",&a);printf("nihao:-------->%d\n", a);}本來一個簡單的程序,卻出現了異常:
于是將這段代碼放在Dev_cpp上運行,結果運行無誤,百思不得其解。
在網上搜了關于C4996錯誤,找到了幾種解決辦法:
1、根據提示,在文件頂部加入一行:#define _CRT_SECURE_NO_WARNINGS
運行成功!
2、在文件頂部添加代碼:#pragma warning(disable:4996)
運行成功!
3、真正原因在與vs中的SDL檢查。于是可以:右鍵單擊工程文件-->屬性-------->? c/c++? ------>SDL checks ------------> no
按照錯誤提示,可以將?scanf?替換為??scanf_s
#include<stdio.h> void main() {int a;printf("please input the number:\n");scanf_s("%s",&a);printf("nihao:-------->%d\n", a);}
運行成功
但是將這段代碼放進Dev_cpp,卻出錯了:
于是引發了一些關于scanf_s 的一些思考:
找了一些資料
ANSI C中沒有scanf_s(),只有scanf(),scanf()在讀取時不檢查邊界,所以可能會造成內存泄露。所以VS中提供了scanf_s() 在最新的VS2017中也提供了scanf_s()在調用時,必須提供一個數字以表明最多讀取多少位字符。如果想繼續使用scanf這個不安全的函數可以使用宏命令來阻止錯誤的產生 #define _CRT_SECURE_NO_DEPRECATE 請把宏命令放在最前面 或者編譯選項中加/D_CRT_SECURE_NO_DEPRECATE 或者在所有.c/.cpp文件前面添加#pragma warning(disable:4996) scanf()函數是標準C中提供的標準輸入函數,用以用戶輸入數據scanf_s()函數是Microsoft公司VS開發工具提供的一個功能相同的安全標準輸入函數,VS系統提供了scanf_s()。在調用該函數時,必須提供一個數字以表明最多讀取多少位字符。
scanf()在讀取數據時不檢查邊界,所以可能會造成內存訪問越界:
//例如:分配了5字節的空間但是用戶輸入了10字節,就會導致scanf()讀到10個字節 char buf[5]={'\0'}; scanf("%s", buf); //如果輸入1234567890,則5以后的部分會被寫到別的變量所在的空間上去,從而可能會導致程序運行異常。 以上代碼如果用scanf_s()則可避免此問題:char buf[5]={'\0'}; scanf_s("%s",buf,5); //最多讀取4個字符,因為buf[4]要放'\0' //如果輸入1234567890,則buf只會接受前4個字符 注: scanf_s最后一個參數n是接收緩沖區的大小(即buf的容量),表示最多讀取n-1個字符. PS:?很多帶“_s”后綴的函數是為了讓原版函數更安全,傳入一個和參數有關的大小值,避免引用到不存在的元素,防止hacker利用原版的不安全性(漏洞)黑掉系統。?
總結
以上是生活随笔為你收集整理的VS中的scanf_s函数和scanf的全部內容,希望文章能夠幫你解決所遇到的問題。
                            
                        - 上一篇: android中设置菜单栏,androi
 - 下一篇: 数据库_7_SQL基本操作——表操作