//一个简单的程序,它将空格和逗号解释为参数(分隔字符)
//并在自己的行上打印每个子字符串-即每个标记:
#include "stdafx"
#include <iostream>
#include <cstring>
using namespace std;
int main(){
char the_string[81], *p;
cout << "Input a string to parse: ";
cin.getline(the_string, 81);
p = strtok_s(the_string, ", ");
while (p != nullptr) {
cout << p << endl;
p = strtok_s(nullptr, ", ");
}
return 0;}
这是它给我的错误1错误C2660:'strtok_s‘:function不带2个参数的问题
IntelliSense:函数调用中的参数太少
发布于 2016-04-04 05:37:33
编译器只是推荐更安全的CRT函数,如果您真的想使用原始的strtok函数,它还会为您提供关闭警告的说明:
warning C4996: 'strtok': This function or variable may be unsafe. Consider
using strtok_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNING只需在项目设置中添加_CRT_SECURE_NO_WARNING作为预处理器定义,或添加到stdafx.h文件的顶部#define _CRT_SECURE_NO_WARNING 1
请参阅CRT中的安全特性
您显然对C/C++非常陌生,所以您现在还不需要担心这个细节。此警告之所以出现在这里,是因为许多可追溯到Kernighan &Ritchie原文的长标准C字符串库函数在现代恶意软件世界中存在一些固有的安全问题。因此,任何生产应用程序都应避免使用“更安全的CRT”版本。
特别是,strtok的工作方式是在库中具有内部隐藏状态,有时可以利用该状态在解析器中创建安全问题。
char *strtok(char *str, const char *delim);strtok_s函数只是为状态使用一个显式上下文变量,而不是使用隐藏的内部变量。它与strtok在所有其他方面的工作原理完全相同。
char *strtok_s(char *strToken, const char *strDelimit, char **context);因此,您的代码将执行与您的图书示例完全相同的操作,如下所示:
#include <iostream>
#include <cstring>
using namespace std;
int main(){
char the_string[81], *p;
char *next_token = nullptr;
cout << "Input a string to parse: ";
cin.getline(the_string, 81);
p = strtok_s(the_string, ", ", &next_token);
while (p != nullptr) {
cout << p << endl;
p = strtok_s(nullptr, ", ", &next_token);
}
return 0;
} 有关更安全CRT的更多信息和历史,请参见安全开发生命周期(SDL)禁止的函数调用。
https://stackoverflow.com/questions/36393334
复制相似问题