草庐IT

typedef-name

全部标签

c++ - 这个 typedef 是如何工作的?

我正在看这个cpp闪电谈话video它在0:37显示这段代码template>classQScopedPointer{typedefT*QScopedPointer::*RestrictedBool;//howdoesthiswork?//whynotQScopedPointersinceQScopedPointerisatemplate?public:inlineoperatorRestrictedBool()const{returnisNull()?Q_NULLPTR:&QScopedPointer::d;}inlineboolisNull()const{return!d;}pro

c++ - 如何使用函数签名的 typedef 作为 std::function 的类型参数?

当用作模板类型参数时,函数的typedef和使用裸函数类型之间肯定有区别。即,考虑#includetypedefstd::functionTF1;typedefvoid(*FooFn)(int);typedefstd::functionTF2;intmain(){TF1tf1;TF2tf2;return0;}我可以创建TF1但不能创建TF2(错误:aggregate'TF2tf2'的类型不完整,无法定义)。(参见ideoneexample。)有没有办法使用函数(签名)的typedef作为模板类型参数;具体来说,作为std::function?的类型参数(没有C++11标记,因为我对bo

c++ - 模板化成员函数 typedef 无法编译

#include#includeusingnamespacestd;voidprintstr(conststring&s){coutclassTest{public:typedefvoid(*Func)(constA&);};typedefvoid(*Func)(conststring&);templatevoidbind(Test::Funcf,//在上面的代码中,我尝试使用另一个类中的函数指针typedef。如图所示,它没有编译,但是其他两行中的任何一行都没有注释,而不是Test::Funcf,。行,它编译得很好!这是我不能用C++做的事情吗?需要什么语法?使用g++4.4.3,我

c++ - std::vector 的 Typedef 和 ostream 运算符

我创建了一个Chromosome类,它最终只是一个带有ostream运算符的vector包装器,所以我决定改用typedefvector。但是,我在使用模板化的ostream运算符时遇到了问题……这是最好的方法吗?(我见过一些方法,但都没有奏效)templateclassChromosome{public:typedeftypenamestd::vectortype;typedeftypenamestd::pairptr_pair;};template//line19below:std::ostream&operator::type&chromosome){for(autoiter=c

c++ - 类中的typedef

有这样的代码:templateclassSomeClass{typedefboost::shared_ptrsPtr;typedefstd::vectorc;typedefc::iteratorcIt;//hereistheproblem};错误是:main.cpp:23:error:type‘std::vector,std::allocator>>’isnotderivedfromtype‘SomeClass’main.cpp:23:error:expected‘;’before‘cIt’如何在类中使用typedef来模板化参数?编辑:我想通了,对于g++,那一定是:typedeft

c++ - 在详细说明符中使用 typedef 名称

根据($3.4.4)后跟类键的typedef名称是无效的。但我不确定是哪个范围?例如:在下文中,如果在函数内部等block中使用了详细说明符,编译器不会报错。typedefclass{/*...*/}S;//invalidclassS;//okvoidfoo(){classS;}使用typedef-name在本地范围内声明类是否有效,为什么? 最佳答案 7.1.3第3段讲述:Inagivenscope,atypedefspecifiershallnotbeusedtoredefinethenameofanytypedeclaredi

C++ 宏之谜 : Printing the name of the TYPE

在宏中,我可以使用xxxx_##TYPE和##TYPE##_xxxxx来正确填写TYPE名称,但我不能在字符串中间使用##TYPE##,例如(打印“##TYPE##是类型的名称”;)有解决办法吗? 最佳答案 您可以通过结合两个特征来做到这一点。一种是“字符串化”,即通过在宏参数前加上#前缀将其转换为字符串。(这与您显然已经熟悉的“标记粘贴”运算符##相关但不同。)另一个事实是,当连续给定多个字符串文字时,C++会将它们组合起来成一个字符串。例如,"a""b""c"等同于"abc"。我不清楚你的宏到底是如何定义的,所以我不能告诉你要输

c++ - 我如何为 tr1::unordered_map 定义一个不绑定(bind)模板参数的宏/typedef/etc?

这可能是个有点傻的问题,但我不得不问。我正在尝试在C++中使用unordered_map类,但不是每次都将其作为tr1::unordered_map引用,我只想使用关键字hashMap。我知道typedeftr1::unordered_maphashMap有效,但这种修复了键的数据类型和对应于hashMap的值,而我希望有更多类似以下内容:#definehashMaptr1::unordered_map我可以根据需要定义键和值的数据类型,但这不起作用。以前有人遇到过这个问题吗?谢谢 最佳答案 这是C++11之前的C++所缺少的东西。

c++ - 模板 typedef c++0x

我发现了几个关于C++0x中模板类型定义的问题,这些问题通过using关键字解决;然而,使用GCC4.6.1(运行g++-std=c++0x),我得到以下错误:错误:在“使用”之前需要不合格的id你能帮我找出我哪里出错了吗?几个小时以来我一直在努力解决这个问题......代码:#includetemplateclassGenericSparseVector{protected:std::mapindices_to_values;};templateusingStandardSparseVector=GenericSparseVector; 最佳答案

c++ - ISO/IEC 10646 中的 "character short name"是什么?

C++112.3/2说:Thecharacterdesignatedbytheuniversal-character-name\UNNNNNNNNisthatcharacterwhosecharactershortnameinISO/IEC10646isNNNNNNNN所以我下载了ISO/IEC10646,但我找不到“字符短名称”的定义。有人可以澄清一下这是指什么吗?我最初的目标是找出为什么在使用\U指定代码点时需要8个十六进制数字,因为6个数字总是足够的。所以我也很想知道为什么C++11指定我们使用\UNNNNNNNN而不是\UNNNNNN。 最佳答案