草庐IT

dynamic-linking

全部标签

C++/QML : How to define and handle multiple contexts for dynamically created components?

基本上我的情况是这样的:我有一个扩展QQuickView的类,它通过设置上下文属性将某些对象从C++公开到QML。显示的View是从QML创建的,并且都是同一定制组件的不同实例;当某些事件发生时会创建新View,当这种情况发生时,现有View应显示最初在C++端分配给它们的对象,而新View应显示分配给它们的对象。所以,在C++方面,我有这样的东西:WindowManager::WindowManager(QQuickView*parent):QQuickView(parent){//Settingthesourcefiletousethis->setSource(QUrl("qrc:

c++ - CMake 测试 : was a library compiled/linked against libc++ or libstd++?

我正在使用cmake来管理我使用第三方库的项目。此库可能已针对libc++或libstd++(取决于版本)进行编译/链接。我知道如何告诉cmake将我的项目编译/链接到libc++或libstdc++,但我不知道如何检查我正在使用的库是否是根据libc++或libstd++编译/链接的。有任何cmake命令可以检查吗? 最佳答案 对于共享库,您可以使用GetPrerequisites用于测试库是否依赖于libstc++或libc++的标准模块。例如,以下代码测试boost的program_options库是否针对libstc++或l

c++ - 在 Ubuntu 上提升单元测试动态链接

我正在尝试使用Boost的单元测试框架构建单元测试。我想将测试套件库与Boost提供的自动生成的测试模块动态链接起来。这是我一直在使用的基本结构:test_main.cpp:#defineBOOST_TEST_DYN_LINK#defineBOOST_TEST_MAIN#includelib_case.cpp:#defineBOOST_TEST_DYN_LINK#includeBOOST_AUTO_TEST_SUITE(test_lib)BOOST_AUTO_TEST_CASE(test_lib_case){BOOST_ASSERT(true);}BOOST_AUTO_TEST_SUI

C++/阿杜伊诺 : dynamic int array

我正在为Arduino编写类(class)。到目前为止一切顺利,但我现在有点卡住了...我已经在我的类中声明了一个int数组classmyClass{public:MyClass(intsize);private:int_intArray[];};当我初始化类MyClassmyClass1(5)时,我需要数组看起来像这样{0,0,0,0,0}。我的问题:我需要做什么才能使数组包含“大小”数量的零?MyClass::MyClass(intsize){//whatgoesheretodynamicallyinitializethearrayfor(inti=0;i编辑:跟进下面的各种回复,

c++ - 关于C/C++静态库的推理

我从来没有想过下面的问题,但由于我现在不得不处理我的代码中的一堆依赖关系,我想我最好弄清楚我的事实。让我们将其限制为现代Linux版本,例如ubuntuamd64。由于静态库不包含动态库引用,undefinedsymbol如何在静态库中解决?依赖二进制文件是否可以动态加载undefinedsymbol,或者这些符号必须在编译时由另一个静态库或目标文件解析?编译器是否可以通过链接动态库来解析(依赖于静态库的应用程序的)依赖关系,如果是这样,代码文本是否会静态解析为生成的二进制文件,或者是否存在动态引用?例如,静态库L使用libc6.so中的malloc,它将被应用程序A使用>。L和A都会

使用ST-Link烧录程序出现No target connected所有的解决方案

原因分析及解决办法:1)芯片供电不足,导致找不到芯片;【解决办法】用杜邦线或者usb线对芯片再次进行供电 2) ST-Link与单片机接线错误,或者接线不良; 【解决办法】按照下面的方式进行接线,并确保接线良好3.3V⬅➡3.3VGND⬅➡GNDSWDIO⬅➡SWDIOSWCLK⬅➡SWCLK3)SWD引脚被占用或者被禁用 【解决办法】此时可以有两种方法可以解决:按住RESET,并在点击烧录后立马放开,抢一个时间差,这个方法有一定概率会失败,可以多尝试几次;把BOOT0拉高,可以将芯片从系统存储器或者是内置SRAM中启动,这时候并不会运行闪存存储器的程序,那么SWD就没有被占用,烧录一个正常的

c++ - 依赖于另一个库的库上的 CMake 和 target_link_libraries

我正在使用CMake构建不同的C++库,整个事情可以总结如下:liba:不依赖于任何东西libb:依赖于a我现在需要创建一个依赖于b的库c。我只需要在b上链接c吗?或者在b和a上,因为b依赖于a?target_link_libraries(cb)还是target_link_libraries(cba)?谢谢 最佳答案 在你的代码构建库b中,你应该告诉CMakeb依赖于a:target_link_libraries(ba)然后,您的库/应用程序c可以仅链接到它使用的内容,而不必担心依赖项的依赖关系:target_link_librar

c++ - 什么时候需要 dynamic_cast?

这个问题在这里已经有了答案:关闭11年前。PossibleDuplicate:dynamic_castinc++这两种将派生类赋值给基类指针的方式有什么区别?Derivedd1;Base*b1=&d1Derivedd2;Base*b2=dynamic_cast&d2

c++ - 不同库中的相同符号和链接顺序

我有2个库:test.1和test.2。这两个库都包含一个全局extern"C"voidf();函数,具有不同的实现(只是一个用于测试的cout)。我做了以下测试:测试1动态链接:如果我在可执行文件的makefile中添加libtest.1.so然后libtest.2.so然后调用f();main,libtest.1.so->f()被调用。如果我更改makefile中的顺序,将调用libtest.2.so->f()测试2静态链接:静态库完全一样测试3动态加载由于库是手动加载的,所以一切都按预期进行。我预计多个定义会出现错误,但这显然没有发生。此外,这并没有打破单一定义规则,因为情况不同

c++ - dynamic_cast<> 将变量参数传递给模板

我有一个执行测试用例的C++应用程序。某些测试用例可能会依赖于其他测试用例的输出。所有测试用例都实现一个基本接口(interface):///baseclassforalltestcasesclassITest{public:virtualvoidExecute()=0;};产生一些可能对其他测试用例有用的对象的测试用例实现这个接口(interface):///implementedbytestcasesthatprovidedatatoothertestcasestemplateclassIDependency{public:virtualObjGet()=0;};需要来自其他测试用