草庐IT

symbolic

全部标签

c++ - Eclipse CDT's symbol 'X' 无法解析的通用解决方案?

我有一个包含C++和C文件的项目。代码可以正确编译和运行,但我需要消除以下错误:Symbol'ERANGE'couldnotberesolved我能够用这两个文件重现它(Ubuntu上最新的x64ElipseJuno):主要.h:#ifndefMAIN_H_#defineMAIN_H_extern"C"{#include}#endif/*MAIN_H_*/主要.cpp:#include#include#include"main.h"intmain(intargc,char*argv[]){assert(errno!=ERANGE);//在ERANGE上正确执行OpenDeclarati

c++ - undefined symbol __istype with/opt/local/bin/g++?

当我用这个编译我的程序时:g++-std=c++11main.cpp-orun我得到这个错误(不确定,因为我没有使用任何带有__istype的代码):Undefinedsymbolsforarchitecturex86_64:"__istype(int,unsignedlong)",referencedfrom:std::ctype::is(unsignedlong,char)constinccuyHAvU.old:symbol(s)notfoundforarchitecturex86_64collect2:error:ldreturned1exitstatus我搜索过但找不到答案。一

c++ - Poco C++ 中的 undefined symbol

我之前编译了一个简单的命令行程序,它使用了PocoC++(顺便说一句,我喜欢它)。该程序完美运行了几个月。我的电脑上肯定有一些变化,因为现在当我运行程序时,我收到以下错误。dyld:Symbolnotfound:__ZN4Poco4Util11Application12handleOptionERKNSt3__112basic_stringIcNS2_11char_traitsIcEENS2_9allocatorIcEEEESA_Referencedfrom:/Users/me/bin/sqlmergeExpectedin:/usr/local/opt/poco/lib/libPoco

c++ - CreateFile 打开在另一个终端 session 中创建的 MS-DOS 设备

我有一个(某种过滤器)驱动程序,它应该与用户模式组件通信。它通过调用IoCreateDevice创建一个设备对象,然后通过IoCreateSymbolicLink为它创建一个所谓的MS-DOS符号链接(symboliclink),使用户可以访问它-模式代码(通过CreateFile)。这或多或少是一种标准技术。驱动程序创建一个形式为\DosDevices\mydevicename的符号链接(symboliclink),而用户模式代码打开一个名为\\.\mydevicename的文件。现在,当驱动程序在终端服务器session的上下文中创build备时,问题就开始了。创建的符号链接(sy

c++ - 不满意链接错误 : undefined symbol _ZN5boost6system16generic_categoryEv in java (JNI)

我创建了一个.so文件,其中我根本没有使用boost库(当然早些时候我使用过它),但后来我切换到pthreads并删除了所有头文件和boost.so文件链接生成文件。Java文件编译成功。但是,当我尝试使用java-Djava.library.path=libs/-cpbuild/发送它给我以下错误。线程“main”中的异常java.lang.UnsatisfiedLinkError:/home/aahmed/libplxmsg-java/libs/libplxmsgjavaasyncbinder.so:/home/aahmed/libplxmsg-java/libs/libplxms

c++ - CMake 和 Dylib : symbol definitions

我在为dylib配置cmake时遇到了一些困难。这是我的测试:mylibfunc.cpp#includestaticintcount=0;extern"C"{intmylibfunc(){count++;returncount;}}基本测试.cpp#include#include#includetypedefint(*funcPtr)();intmain(){//Loadfirstlibraryvoid*handleA=dlopen("libmylib.dylib",RTLD_LAZY);funcPtrfunctionA=(int(*)())dlsym(handleA,"mylibfu

c++ - 编译器构造 : Handle references to unordered symbols

我有龙书,但它似乎没有处理那个话题......在大多数现代语言中,可以使用某些变量,即使它们在代码中的出现是无序的。示例classFoo{voidbar(){plonk=42;}intplonk;}在函数之后声明变量plonk并不重要。问题有没有什么最佳实践/有用的模式来实现这个?我想到了两种方法:在解析时为看不见的符号添加虚拟符号。当声明被解析时,这些虚拟符号会被它们的真实符号所取代。解析后,我们可以检查是否有剩余的虚拟对象,如果有则输出错误。解析时不要做任何符号的事情,而只创建AST。在通过AST解析步骤后,根据节点添加符号。例如一个类节点添加child的符号并在之后处理它们。例如

c++ - 惰性符号绑定(bind)失败 : symbol not found

我有三个头文件inmyproject描述对象Rational,Complex,和RubyObject.前两个是模板。所有这些都可以使用在头文件中定义的复制构造函数相互转换——除了那些从constRubyObject&构造Rational和Complex的构造函数,定义inasourcefile.注意:这些定义是必要的。如果它们全部进入标题,您将得到circulardependency.不久前,我遇到了someunresolvedsymbolerrors使用源文件中定义的两个复制构造函数。我能够在源文件中包含以下函数voidnm_init_data(){nm::RubyObjectobj

c++ - 删除内联函数调用导致 Unresolved external symbol 错误

我试图证明您需要在所有使用它的TU中定义一个inline函数。但是,以下代码编译良好(MSVS2010):inc.hinlinevoidfoo();测试.cpp#include"inc.h"voidx();intmain(){foo();//测试2.cpp#include"inc.h"voidx(){foo();}请注意函数调用是为了防止优化。这会编译,虽然foo被声明为inline并且仅在test.cpp中定义,但也在test2.cpp中使用>.如果我在main()中注释掉对foo的调用,我会得到预期的错误。"void__cdeclfoo(void)"(?foo@@YAXXZ)ref

c++ - 带有 C++ 模板的 SWIG : undefined symbol

C++模板和SWIG不能很好地结合在一起。当我尝试导入我的模块时出现错误ImportError:./_simple.so:undefinedsymbol:_Z9double_itIiET_S0_我正在使用SWIG1.3。这是一个简单的例子来说明问题://file:simple.htemplateTdouble_it(Ta);//file:simple.cctemplateTdouble_it(Ta){return(2*a);}//file:simple.i%module"simple"%{#include"simple.h"%}%include"simple.h"%template(i