C++可执行文件绝对路径值与VS安全检查详解
目录
- 前言
- :_pgmptr
- :VS安全检查
- 总结
前言
前几天写新项目需要用到程序所在绝对路径的时候,发现网上居然一点相关分享都没有。
:_pgmptr
翻箱倒柜找出了几本教程,发现了一个叫_pgmptr
的东西。
进去看了一下,在stdlib.h
里拓展KerVh到了函数__p__pgmptr()
,函数原型:
复制代码 代码如下:_CRT_INSECURE_DEPRECATE_GLOBALS(_get_pgmptr ) _ACRTIMP char** __cjsdecl __p__pgmptr (void);
返回值为char**
,也就是普通的字符串数组。
:VS安全检查
赶紧放到项目里试一试,结果却报错了。
定睛一看,原来是Vwww.devze.comisual Studio的安全开发者_开发入门检查不让这个“可能”越界的函数过编译。一般来说,改用它提示的安全函数就可以过,可这次居然没有安全函数...
于是乎,要么找别的函数, 要么绕过安全检查。我选择了后者,根据错误提示定义安全宏:
#define _CRT_SECURE_NO_WARNINGS
别急着拷,先往下看...
定义了安全js宏之后,还是报了同样的错...不知道你们会不会,反正我是这样
那么,要绕过安全检查,就得另辟蹊径了。
在解决方案资源管理器中右键项目,单击属性,进入下方页面
找到C/C++ -> SDL检查 -> 否(/sdl-)-> 确定
这样,安全检查就被绕过了。
总结
1.程序绝对路径获取:_pgmptr
2.VS安全检查:项目属性 -> C/C++ -> SDL检查 -> 否(/sdl-)
到此这篇关于C++可执行文件绝对路径值与VS安全检查的文章就介绍到这了,更多相编程客栈关C++可执行文件绝对路径值内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!
精彩评论