草庐IT

dynamic-language-runtime

全部标签

c++ - 为什么我在使用 dynamic_cast 和模板时收到错误 "A is an inaccessible base of B"?

为什么对f的调用没有解析为第一个函数重载?我收到错误:source.cpp:Infunction'intmain()':source.cpp:12:31:error:'A'isaninaccessiblebaseof'B'classA{};classB:A{};voidf(constA&){std::coutvoidf(T){std::cout(b));}请注意,如果我取出dynamic_cast,代码将起作用,但secondf被调用(它打印“Generic”)。但我想做的是接到第一个电话。我认为dynamic_cast会起作用,但由于某种原因它会导致问题。我在这里做错了什么?

c++ - 使用 dynamic_pointer_cast 时无法动态转换

为什么这段代码不起作用?std::shared_ptre=ep->pop();std::shared_ptrt;t=std::dynamic_pointer_cast(e);我收到以下错误:/usr/include/c++/4.6/bits/shared_ptr.h:386:error:cannotdynamic_cast'(&__r)->std::shared_ptr::.std::__shared_ptr::get[with_Tp=Event,__gnu_cxx::_Lock_policy_Lp=(__gnu_cxx::_Lock_policy)2u]()'(oftype'clas

【2024美赛】在COMAP比赛中使用大型语言模型和生成式AI工具的政策Use of Large Language ModelGenerative AI Tools in COMAP Contests

【2024美赛】在COMAP比赛中使用大型语言模型和生成式AI工具的政策UseofLargeLanguageModelGenerativeAIToolsinCOMAPContests写在最前面2024美赛翻译——跳转链接中文翻译在COMAP比赛中使用大型语言模型和生成式AI工具的政策团队指南当我们识别出可能是未声明使用此类工具准备的提交时,COMAP将采取适当行动。引用和参考文献指南AI使用报告英文原文UseofLargeLanguageModelsandGenerativeAIToolsinCOMAPContestsGuidanceforteamsCOMAPwilltakeappropria

c++ - dynamic_cast 失败

我有一个基类和一个派生类。每个类都有一个.h文件和一个.cpp文件。我在下面的代码中将基类对象动态转换为派生类:h文件:classBase{public:Base();virtual~Base();};classDerived:publicBase{public:Derived(){};voidfoo();};classAnother{public:Another(){};voidbar(Base*pointerToBaseObject);};cpp文件:Base::Base(){//dosomething....}Base::~Base(){//dosomething....}voi

c++ - 如何编写自己的 dynamic_cast

这个在面试中被问到了。如何编写自己的dynamic_cast。我想,基于typeid的name函数。现在如何实现自己的typid?我对此一无所知。 最佳答案 你没有任何线索是有原因的,dynamic_cast和static_cast不像const_cast或reinterpret_cast,它们实际上执行指针运算并且在某种程度上是类型安全的。指针运算为了说明这一点,请考虑以下设计:structBase1{virtual~Base1();chara;};structBase2{virtual~Base2();charb;};struc

c++ - C 到 C++ : Transitioning from one language to the other

这个问题在这里已经有了答案:关闭11年前。PossibleDuplicate:C++tutorialforexperiencedCprogrammer.我经常使用多种语言进行编程,最近一直在使用C++。基本上我的类只是对纯C代码的包装。几乎就像一个带有关联方法的结构。这为我的数据提供了我想要的封装和隐私。我有一个小的类层次结构,几乎没有使用继承。我熟悉面向对象的概念,并且知道当我需要了解这方面的特定概念时可以使用哪些搜索词。然而,正如我在编程世界中的尝试所发现的那样,通常真正有用的语言特性对新手或新手来说是隐藏的,而我需要的有用的部分已经写好了并且在某个地方的库中可以免费使用可用(大多

c++ - 用于遍历继承层次结构的 Static_cast 与 dynamic_cast

我看到一本关于C++的书提到使用静态转换在继承层次结构中导航比使用动态转换更有效。例子:#include#includeusingnamespacestd;classShape{public:virtual~Shape(){};};classCircle:publicShape{};classSquare:publicShape{};classOther{};intmain(){Circlec;Shape*s=&c;//Upcast:normalandOK//Moreexplicitbutunnecessary:s=static_cast(&c);//(Sinceupcastingis

c++ - dynamic_cast 是否在重载的运算符删除中工作?

我遇到了这个:structBase{void*operatornew(size_t);voidoperatordelete(void*);virtual~Base(){}//(p);if(dynamic_cast(pB)!=0){/*...NOTreachinghere?...*/}free(p);}现在如果我们这样做,Base*p=newDerived;deletep;令人惊讶的是,conditioninsidetheBase::deleteisnotsatisfied我做错了什么吗?或者从void*进行转换会丢失Derived*的信息? 最佳答案

c++ - dynamic_cast 何时因隐藏符号而失败?

根据关于可见性的gccwiki(https://gcc.gnu.org/wiki/Visibility,请参阅“C++异常问题(请阅读!)”)部分,但似乎也是一个示例(dynamic_castfailedwhenhidingsymbol),隐藏类可以导致有效的dynamic_cast失败。我想通过示例准确了解这种情况何时发生:任何人都可以给我一个小示例来正确理解效果吗?这是我的尝试和理解(在Linux上使用gcc>7):据我了解,我需要的是vaguelinkage发生,当基类没有关键方法时发生。所以我尝试了这个基本层次结构:classA{virtual~A();virtualvoidp

【containerd错误解决系列】failed to create shim task, OCI runtime create failed, unable to retrieve OCI...

文章目录环境问题及现象解决方案查看现有libseccomp版本卸载低版本libseccomp安装高版本libseccomp解决后现象原理参考环境#cat/etc/redhat-releaseCentOSLinuxrelease8.0.1905(Core)#uname-r4.18.0-348.rt7.130.el8.x86_64问题及现象pod的状态全部都是ContainerCreating的状态containerd进程有大量报错,主要有:failedtocreatecontainerdtask:failedtocreateshimtask:OCIruntimecreatefailed:unab