草庐IT

weak-template-vtables

全部标签

c++ - 同名类之间的共享 vtables : call to virtual method crashes when casting to base type

检查下面的更新,我可以重现并需要帮助。我有一个奇怪的崩溃,其中一些方法在除1个地方之外的任何地方都可以正常工作。这是代码:structbase{virtualwchar_t*get()=0;//canbe{returnNULL;}doesn'tmatter};structderived:publicbase{virtualwchar_t*get(){returnSomeData();}};structcontainer{deriveddata;};//thisisapprox.howitisusedinrealprogramvoidoutput(constbase&data){data

c++ - 为什么在锁定 weak_ptr 时会出现访问冲突?

我有一个std::weak_ptr。在尝试使用底层对象之前,我锁定它以获得shared_ptr:autofoo_sharedptr=foo_weakptr.lock();if(foo_sharedptr!=nullptr){//dostuffwithfoo}通常这很好用。但是,有时我在锁定调用期间遇到访问冲突:Unhandledexceptionat0x00007FF91F411BC3(My.dll)inMy.exe:0xC0000005:Accessviolationreadinglocation0xFFFFFFFFFFFFFFFF.我的猜测是底层指针被删除了,但是我对weak_pt

C++ 模板参数和偏特化 : strong or weak typing?

今天,我和我的一个friend在一个愚蠢的错误上苦苦挣扎,我想知道模板参数在C++中是如何工作的。考虑以下代码,我在其中尝试部分特化类attr>其中I是一个unsignedint,虽然MyClass期望一个int参数:#includetemplateclassMyClass{};templatestructattr;templatestructattr>{};intmain(intargc,char*argv[]){attr>att;return0;}g++失败并显示错误消息main.cpp:Infunction‘intmain(int,char**)’:main.cpp:20:22:

c++ - 使用 shared_ptr 和 weak_ptr 来管理 std::function 的生命周期是否安全?

我已经围绕boost::asio::io_service创建了一个包装器来处理OpenGL应用程序的GUI线程上的异步任务。任务可能是从其他线程创建的,因此boost::asio似乎是这个目的的理想选择,这意味着我不需要编写自己的带有关联互斥锁和锁定的任务队列。我想将每帧完成的工作保持在可接受的阈值以下(例如5毫秒),所以我调用poll_one直到超出所需的预算,而不是调用run.据我所知,这需要我调用reset每当发布新任务时,这似乎运作良好。因为它很短,这里是全部内容,没有#include:typedefstd::functionVoidFunc;typedefstd::share

c++ - 为什么这段代码有 C2784 "could not deduce template argument"错误

来自Lambdafunctionpassedasparameter我可以编译示例:templateRangeFindFirstIf(Range,bool(*Function)(typenameRange::ConstReferencevalue));structrange{usingConstReference=constfloat&;};rangerng;rng=FindFirstIf(rng,[](constfloat&val){return(val当然不能链接,因为FindFirstIf没有实现。然而,当我做了类似的事情时:templateRangeMyTest(Range,Va

c++ - 是否可以跨 RTLD_LOCAL 加载的库合并 vtables/typeinfo 等弱符号?

对于上下文:我有一个Java项目,它部分使用两个JNI库实现。例如,libbar.so依赖于libfoo.so。如果这些是系统库,System.loadLibrary("bar");会成功的。但是因为它们是我用我的JAR运送的自定义库,所以我必须做类似的事情System.load("/path/to/libfoo.so");System.load("/path/to/libbar.so");libfoo需要先走,否则libbar找不到它,因为它不在系统库搜索路径中。这已经运行了一段时间,但我现在遇到了一个问题,尽管类型是正确的。我追踪到这两个库对该类型的类型信息有不同的定义,并且它们没

c++ - is_same_template 在模板别名上的奇怪行为

下面的程序...#include#includetemplatestructTemplate{};templateusingAlias=Template;templateclassT1,templateclassT2>structis_same_template:std::false_type{};templateclassT>structis_same_template:std::true_type{};intmain(){std::cout::value::value::value...输出...Template==Template:trueTemplate==Alias:fals

c++ - 在 C++11 标准中,它在哪里禁止 'template <typename T> class A {...}; template <typename T> class A<int> {...};'(如果有的话)?

我试图通过想象神秘的构造来更全面地掌握模板语法和语义。我认为C++11标准不允许使用以下语法:templateclassA{...};//phony"specialization"templateclassA{...};但是,我找不到在C++11标准中不允许使用此语法的地方。C++11标准不允许显示的语法是否正确?如果有,从哪里可以查到语法是不允许的? 最佳答案 令我感到非常惊讶的是,14.5.5[temp.class.spec]中没有明确声明必须在模板参数列表中使用类模板偏特化的所有模板参数。那将使templateclassA无效

c++ - `template <auto>` 和部分类模板特化排序

考虑:#includetemplatestructTag{};templateautotag=Tag{};templatestructSelectorImpl;//1templatestructSelectorImpl...>{};//2template*tag,auto...xs>structSelectorImpl,std::integral_constant...>{};templatestructSelector:SelectorImpl...>{};intmain(){Selector,1,2>{};}gcc和clang都无法编译它,报告SelectorImpl的特化不明确。

c++ - boost 智能指针和 BOOST_NO_MEMBER_TEMPLATES

经过一番努力后,我设法获得了boostsmartpointers以在警告级别4为WindowsCE/Mobile构建。我发现消除编译错误和警告的阻力最小的方法是#defineBOOST_NO_MEMBER_TEMPLATES这到底是什么意思?我把我的灵魂卖给了魔鬼吗?当我真正使用这些类型时,一切都会变得一团糟吗? 最佳答案 本身不应该有任何不良影响,只是功能损失。成员模板是作为模板的成员函数,例如:structfoo{templatevoidi_am_not_supported_sometimes(void);};所以你不会得到未定