草庐IT

open-type

全部标签

c++ - 带有内存定位文件的 FFmpeg avformat_open_input

我想解码互联网音频流,但我不想将数据写入磁盘,因此数据仅位于内存中。但是当我想将数据解码为原始数据时,我必须初始化格式上下文,所以我需要使用avformat_open_input。但是这些功能需要文件的详细位置。有没有人有解决方案,如何将我的内存定位数据放入格式上下文中以将此数据解码为原始数据? 最佳答案 您必须创建自定义AVIOContext。详情见我对PlayaVideofromMemoryStream,UsingFFMpeg的回答 关于c++-带有内存定位文件的FFmpegavfo

c++ - C/C++ 下划线 t/type (_t/_type) 和类名?

我理解下划线t(_t)是用来标识类型的,下划线type(_type)也是,通常在typedef语句中.用法是否略有不同(例如,模板使用下划线类型,非模板使用下划线t)?为什么不在声明中使用它们?例如:classperson_t{};enumerror_t{};这与之前关于下划线t的问题不同,因为它还要求区分下划线类型。此外,(盲目地)很明显,这两个后缀只是约定俗成,但不清楚为什么它们都用于C++标准。例如,std::size_t与std::istream::pos_type。 最佳答案 对于您的第一个问题,我不知道有任何答案,我相信

c++ - std::type_index 跨 DLL 是否安全

假设我有一个主DLL,其中有一个这样的类:classTest{public:typedefstd::unordered_mapMap;templatevoidSetValue(intval){SetValue(std::type_index(typeid(T)),val);}templateintGetValue(){returnGetValue(std::type_index(typeid(T)));}protected://Definedin.cppfilevoidSetValue(conststd::type_index&idx,intval){m_Map[idx]=val;}/

c++ - 编译错误 : Cannot open precompiled header. pch -- 没有那个文件或目录

我最近购买了BjarneStroustrup撰写的“编程:使用C++的原理和实践”一书,并一直在阅读它。我目前停留在一个早期项目中,我需要输出一些文本字符串。在Windows10LenovoYoga2Pro笔记本电脑上使用VisualStudioCommunity2015update1,我尝试编译该项目但遇到了详细错误:“无法打开预编译头文件:Debug\FindingtheUpstairsBathroom.pch':没有这样的文件或目录”。该项目的名称恰如其分地命名为“FindingtheUpstairsBathroom.cpp”。这是代码://Ihavetheheaders"std

c++ - 增强融合 : convert adapted struct type to text

给定一个这样的结构:structFoo{intx;inty;doublez;};BOOST_FUSION_ADAPT_STRUCT(Foo,x,y,z);我想生成这样的字符串:"{intx;inty;doublez;}"我已经看到如何printthevaluesFusion改编的结构,但在这里我只需要打印类型和名称。我怎样才能最简单地做到这一点?如果有更好的方法,我不会嫁给Boost.Fusion。 最佳答案 我认为您可以通过对thisanswer中的代码稍作修改来获得与您想要的类似的东西。.您可以使用boost::fusion::

c++ - 将函数指针传递给函数时处理 <unresolved overloaded function type>

让我们考虑一下:voidgoo(){std::cout现在我想使用如下定义的一些包装函数来调用其中一个函数:templatevoidc(F&&f,A&&...a){f(std::forward(a)...);}使用方法:c(&goo,10);//(X)c(&goo);//(Y)两种情况都失败(GCC5.3.1)并出现相应的错误:error:nomatchingfunctionforcallto‘c(,int)’error:nomatchingfunctionforcallto‘c()’就我而言,失败是因为编译器在必须初始化f对象时无法选择适当的重载(信息太少)。作为一种解决方案,我当然

c++ - 当您无法测量差异时如何处理 iterator::difference_type?

我正在为第3方C库编写C++包装器。该库提供了一些用于迭代一系列对象的函数。我想编写一个迭代器来包装此行为,以便迭代更容易,但我想不出我将如何提供强制性的“差异”类型,因为迭代对象没有有意义的相对顺序和API我正在使用不提供提前查找可用对象数量的方法。我无法在迭代时对对象进行计数,因为尽管这可以解决单个迭代器,但它会导致end()迭代器和其他迭代器之间的差异未定义。 最佳答案 C++中的所有迭代器都需要提供某种difference_type。该类型是否有意义或有用是一个完全不同的问题。根据您的描述,您似乎正在使用输入迭代器,它使您能

c++推导 "non type pointer to function"类模板参数

考虑一个模板类:templateclassProxy{voidrun(){ReturnTyperet=Fn();//...dosomething...}};//andafunctionsintfn1(){return5;}floatfn2(){return5;}这可以通过使用实例化:Proxyp1;但是显式声明返回值类型似乎是不必要的。我想要实现的是:someProxyInstantationp1;someProxyInstantationp2;不幸的是,我对c++没有任何期望,这似乎是该语言的一个隐藏角落(至少对我而言)。如果我可以从指向函数的指针获取它的类型——类似于:std::t

c++ - 为什么 "gptr"类型的basic_streambuf是char_type*而不是const char_type*?

设置流缓冲的三个“gptr”的basic_streambuf成员,setg声明为:protected:voidsetg(char_type*gback,char_type*gptr,char_type*egptr);我想知道:为什么每个gptr的类型都是char_type*而不是constchar_type*?在这里使用const_cast为这些gptrs使用constchar指针是否安全? 最佳答案 它不是const,因为streambuf接口(interface)不知道您如何填充缓冲区。例如,underflow和uflow方法可

c++ - type_info 不考虑 cv 限定符 : is this right?

这段代码打印1是正确的行为还是g++4.5的怪癖?#include#includeusingnamespacestd;intmain(){structA{};cout我认为cv限定符的不同类型作为非常不同的类型受到威胁,即使较少的cv限定类型可以隐式转换为更多cv限定的类型。 最佳答案 typeid根据C++标准(摘自ISO/IEC14882:2003的§5.2.8)忽略cv限定符:Thetop-levelcv-qualifiersofthelvalueexpressionorthetype-idthatistheoperandof