草庐IT

static_pointer_cast

全部标签

C++ 类和对象(静态的static、友元、内部类、匿名对象、explicit)

绪论        时间的步伐有三种:未来姗姗来迟,现在像箭一样飞逝,过往永远静立不动。本章是类和对象的一个收尾篇,相信通过这三篇类和对象的学习,应该你已经更加清楚了解了C++的类和对象。话不多说安全带系好,发车啦(建议电脑观看)。附:红色,部分为重点部分;蓝颜色为需要记忆的部分(不是死记硬背哈,多敲);黑色加粗或者其余颜色为次重点;黑色为描述需要思维导图:要XMind思维导图的话可以私信哈目录1.再谈构造函数1.1初始化列表1.2:explicit  2.static3.友元3.2友元类4.内部类5.匿名对象1.再谈构造函数知识点:前面我们已经学习过来构造函数,他是用来给对我们的成员进行初始

c++ - GCC/Linux : adding a static library to a . 所以?

我有一个程序通过从一些plugin_name.so中动态加载一个函数来实现一个插件系统(像往常一样)。但是反过来我有一个静态的“助手”库(我们称它为helper.a),它的功能在主程序和插件中的主函数中都被使用。它们不必以任何方式互操作,它们只是用于文本操作等的辅助函数。这个程序一旦启动,就不能重新加载或重新启动,这就是为什么我希望从插件而不是主程序中获得新的“助手”功能。所以我的问题是..是否可以强制.so中的这个“插件功能代码”使用(静态链接?)与主程序不同(也许更新)的“助手”版本?这怎么可能?也许通过静态链接或以其他方式将helper.a添加到plugin_name.so?

c++ - GCC/Linux : adding a static library to a . 所以?

我有一个程序通过从一些plugin_name.so中动态加载一个函数来实现一个插件系统(像往常一样)。但是反过来我有一个静态的“助手”库(我们称它为helper.a),它的功能在主程序和插件中的主函数中都被使用。它们不必以任何方式互操作,它们只是用于文本操作等的辅助函数。这个程序一旦启动,就不能重新加载或重新启动,这就是为什么我希望从插件而不是主程序中获得新的“助手”功能。所以我的问题是..是否可以强制.so中的这个“插件功能代码”使用(静态链接?)与主程序不同(也许更新)的“助手”版本?这怎么可能?也许通过静态链接或以其他方式将helper.a添加到plugin_name.so?

C++代码迁移: handling uninitialized pointers

根据标题,我计划移动一些十多年前为AIX开发的遗留代码。问题是代码库很大。开发人员没有在原始代码中初始化他们的指针。现在,在将代码迁移到最新服务器时,我发现了一些问题。我知道最好的解决方案是遍历所有代码并根据需要初始化所有变量。但是,我只是想知道是否有任何其他解决方案可以解决这个问题。我试过谷歌但找不到合适的答案。 最佳答案 最具预防性的长期方法是在声明它们的位置初始化所有指针,更改代码以使用适当的智能指针来管理生命周期。如果您有任何类型的单元测试,这种重构可能相对轻松。在短期内,如果您要移植到Linux,您可以使用valgrind

C++代码迁移: handling uninitialized pointers

根据标题,我计划移动一些十多年前为AIX开发的遗留代码。问题是代码库很大。开发人员没有在原始代码中初始化他们的指针。现在,在将代码迁移到最新服务器时,我发现了一些问题。我知道最好的解决方案是遍历所有代码并根据需要初始化所有变量。但是,我只是想知道是否有任何其他解决方案可以解决这个问题。我试过谷歌但找不到合适的答案。 最佳答案 最具预防性的长期方法是在声明它们的位置初始化所有指针,更改代码以使用适当的智能指针来管理生命周期。如果您有任何类型的单元测试,这种重构可能相对轻松。在短期内,如果您要移植到Linux,您可以使用valgrind

c - asprintf() : how to free the pointers?

我有这样的代码:我分配了两次log,第一个&log是否有潜在的内存泄漏?char*log=NULL;asprintf(&log,"Hello:%s",name);if(known_person==true){asprintf(&log,"%s,%s",log,",myoldfriend.");}free(log); 最佳答案 是的,代码会泄漏,因为asprintf既不检查也不尝试重用前一个指针。因此,内存只是丢失了。避免示例中问题的最佳方法是将代码重写为char*log=NULL;if(known_person==true)aspr

c - asprintf() : how to free the pointers?

我有这样的代码:我分配了两次log,第一个&log是否有潜在的内存泄漏?char*log=NULL;asprintf(&log,"Hello:%s",name);if(known_person==true){asprintf(&log,"%s,%s",log,",myoldfriend.");}free(log); 最佳答案 是的,代码会泄漏,因为asprintf既不检查也不尝试重用前一个指针。因此,内存只是丢失了。避免示例中问题的最佳方法是将代码重写为char*log=NULL;if(known_person==true)aspr

c - "Warning: Linking the shared library against static library is not portable"是什么意思?

我正在使用libmxml.a库的某些函数制作一个动态库,但我收到此警告:*Warning:Linkingthesharedlibrarylibgstmatroskademux.laagainstthe_*staticlibrary/home/Mr32/gst-template4_final/gst-plugin/src/libmxml.a_isnotportable!我也收到这个警告:gcc:/home/Mr32/gst-template4_final/gst-plugin/src/libmxml.a:linker_inputfileunusedbecauselinkingnotdon

c - "Warning: Linking the shared library against static library is not portable"是什么意思?

我正在使用libmxml.a库的某些函数制作一个动态库,但我收到此警告:*Warning:Linkingthesharedlibrarylibgstmatroskademux.laagainstthe_*staticlibrary/home/Mr32/gst-template4_final/gst-plugin/src/libmxml.a_isnotportable!我也收到这个警告:gcc:/home/Mr32/gst-template4_final/gst-plugin/src/libmxml.a:linker_inputfileunusedbecauselinkingnotdon

linux - 检查二进制文件是否使用 "-static"编译

我在Linux中有一个二进制文件。如何检查它是否已使用“-static”编译? 最佳答案 ldd/path/to/binary如果二进制文件是静态编译的,则不应列出任何共享库。 关于linux-检查二进制文件是否使用"-static"编译,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/8040631/