- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我正在尝试构建 boost.process使用VS2015 WIN64(前段时间使用VS2010 WIN32和WIN64没有任何问题)。
链接器提示未找到 char * * __cdecl __p__environ(void)
:
process.obj : error LNK2019: symbole externe non résolu "char * * __cdecl __p__environ(void)" (?__p__environ@@YAPEAPEADXZ) référencé dans la fonction "public: static class std::map<class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> >,class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> >,struct std::less<class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> > >,class std::allocator<struct std::pair<class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> > const ,class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> > > > > __cdecl boost::process::self::get_environment(void)" (?get_environment@self@process@boost@@SA?AV?$map@V?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@V12@U?$less@V?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@@2@V?$allocator@U?$pair@$$CBV?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@V12@@std@@@2@@std@@XZ)
这是导致此链接问题的代码:
#if defined(BOOST_WINDOWS_API)
#ifdef GetEnvironmentStrings
#undef GetEnvironmentStrings
#endif
char *environ = ::GetEnvironmentStrings();
if (!environ)
boost::throw_exception(boost::system::system_error(boost::system::error_code(::GetLastError(), boost::system::get_system_category()), "boost::process::self::get_environment: GetEnvironmentStrings failed"));
try
{
char *env = environ;
while (*env)
{
std::string s = env;
std::string::size_type pos = s.find('=');
e.insert(boost::process::environment::value_type(s.substr(0, pos), s.substr(pos + 1)));
env += s.size() + 1;
}
}
catch (...)
{
::FreeEnvironmentStringsA(environ);
throw;
}
::FreeEnvironmentStringsA(environ);
#endif
将 char *environ =::GetEnvironmentStrings();
替换为 char *environ = NULL;
并不能解决问题。评论整个集团解决了这个问题。
最佳答案
我真倒霉....
stdlib.h
有 #define environ _environ
(可能是 VS2015 中的新功能)...
在 boost.process 代码(或任何您喜欢的代码)中添加 #undef environ
或将 environ
替换为 environVar
可以修复编译... .
注意:不要关闭 OP,因为尝试编译 boost.process 的其他人可能会遇到同样的问题。
关于c++ - Visual Studio 2015 : Can't find `char * * __cdecl __p__environ(void)` ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34792180/
这是我正在迁移到 VS2017 的代码库的简化版本。以下代码在 VS2013 和 Intel C++ 编译器 2017 更新 4 中编译,但在 VS2013 中不编译。 #include temp
我想调用一个返回 struct 的函数,这个函数有 __cdecl 调用约定。 __cdecl 调用约定如何返回一个struct? 最佳答案 视情况而定。 没有统一的方法。 简单的函数返回,比如int
我想调用一个返回 struct 的函数,这个函数有 __cdecl 调用约定。 __cdecl 调用约定如何返回一个struct? 最佳答案 视情况而定。 没有统一的方法。 简单的函数返回,比如int
我想在 MPI 中使用 AES 算法。 我用 Visual C++ 编写代码。编译代码时出现此错误: unresolved external symbol "void __cdecl BTM(int,
我的公司向第三方提供了一个 DLL,为他们提供了可用于连接到我们的应用程序的 API 函数。 DLL是用VC9编写的,API函数使用了VC默认的调用约定(__cdecl)。第三方已围绕此接口(inte
显示如何使用 MFC 创建线程的示例代码将线程函数声明为静态函数和 __cdecl。为什么需要后者? Boost 线程不理会这个约定,所以它只是一个时代错误吗? 例如(MFC): static __c
在 Visual Studio 2019 中,我编写了以下测试代码,但结果让我感到困惑。 #include using namespace std; template int call(T x, F
在了解了 __cdecl 后,我对堆栈清理感到困惑。 阅读 __cdecl 将弹出堆栈参数 ( https://msdn.microsoft.com/en-us/library/zkwh89ks.as
__stdcall 和 __cdecl 调用约定规定函数名必须在前面加上下划线: C (__cdecl) The same constraints apply to the 32-bit world
我正在尝试用 C (VS2010) 实现一些简单的功能。应该很容易。但是,我收到了 error LNK2019: unresolved external symbol "1>test01.obj :
在函数声明中使用 _cdecl_ 与 __cdecl(1 个下划线 vs 2 个下划线)有什么不同吗? 我正在使用 Visual Studio 2017 及其附带的标准工具。 最佳答案 __cdecl
只是测试 __cdecl 调用约定。 这是一个 cmake 项目,只有 1 个源文件: #include #define CALL_CONVENTION __cdecl void CALL_CONV
我目前正在使用 WSA 编写一个 tcp/ip 服务器。经过一些故障排除后,我的一个 friend 说我应该使用 bool __cdecl winsock_server ( void ) 而不是 bo
我正在学习C语言,在学习的过程中我发现了一行代码,这对我来说是全新的和陌生的void PullDown(char **, int, void (__cdecl **)(void));我只知道第一个和第
我正在运行 ANTLR 4.2 并使用来自的规范 C 语法: https://github.com/antlr/grammars-v4/tree/master/c 我正在执行以下步骤:(使用 ANTL
#define boo(fmt, ...) SomethingToDo(fmt, __VA_ARGS__) void foo(PCSTR fmt, ...) { // some other
我发现了这个: Because the stack is cleaned by the called function, the __stdcall calling convention create
我正在为第三方应用程序编写 DLL。主要软件工程师提到该应用程序使用 __cdecl (/Gd) 调用约定。我需要确保使用它。 另外,第三方提供给我一个C++ DLL骨架,导出函数如下: #ifdef
我听一些人说 __fastcall 比 __cdecl 和 __stdcall 快,因为它把两个参数放在寄存器中,而不是一个其他电话;但是,另一方面,这不是 C 中使用的标准。 我想知道是什么让 __
我今天的面试中有这样一个问题。 #include int main(void) { char *s="123456790"; printf("%c,%c",*(char *)((in
我是一名优秀的程序员,十分优秀!