草庐IT

dynamic-sizing

全部标签

c++ - 如何使用 dynamic_cast 运算符识别失败的强制转换?

ScottMeyer在他的书EffectiveC++中说dynamic_cast用于执行向下或跨继承层次结构的安全转换。也就是说,您使用dynamic_cast将基类对象的指针或引用转换为派生或同级基类对象的指针或引用,这样您就可以确定转换是否成功。失败的转换由空指针(转换指针时)或异常(转换引用时)指示。我想得到两个代码片段,在可以指示转换指针和转换引用的情况下显示失败的转换。 最佳答案 对于指针,这是一个简单的空检查:A*a=newA();B*b=dynamic_cast(a);if(b==NULL){//Castfailed}

c++ - 如何使用 dynamic_cast 运算符识别失败的强制转换?

ScottMeyer在他的书EffectiveC++中说dynamic_cast用于执行向下或跨继承层次结构的安全转换。也就是说,您使用dynamic_cast将基类对象的指针或引用转换为派生或同级基类对象的指针或引用,这样您就可以确定转换是否成功。失败的转换由空指针(转换指针时)或异常(转换引用时)指示。我想得到两个代码片段,在可以指示转换指针和转换引用的情况下显示失败的转换。 最佳答案 对于指针,这是一个简单的空检查:A*a=newA();B*b=dynamic_cast(a);if(b==NULL){//Castfailed}

c++ - "int size = 10;"是否产生常量表达式?

以下代码在gcc4.8和Clang3.2下编译:intmain(){intsize=10;intarr[size];}C++标准的8.3.4/1规定数组的大小必须是一个整数常量表达式,而size似乎不是。这是两个编译器中的错误,还是我遗漏了什么?最新的VC++CTP拒绝带有这个有趣消息的代码:errorC2466:cannotallocateanarrayofconstantsize0有趣的部分是它似乎认为size为零。但至少它拒绝了代码。gcc和Clang不应该做同样的事情吗? 最佳答案 这是variablelengtharray

c++ - "int size = 10;"是否产生常量表达式?

以下代码在gcc4.8和Clang3.2下编译:intmain(){intsize=10;intarr[size];}C++标准的8.3.4/1规定数组的大小必须是一个整数常量表达式,而size似乎不是。这是两个编译器中的错误,还是我遗漏了什么?最新的VC++CTP拒绝带有这个有趣消息的代码:errorC2466:cannotallocateanarrayofconstantsize0有趣的部分是它似乎认为size为零。但至少它拒绝了代码。gcc和Clang不应该做同样的事情吗? 最佳答案 这是variablelengtharray

c++ - 比较和交换 : synchronizing via different data sizes

使用GCC内置的C原子原语,我们可以使用__atomic_compare_exchange执行原子CAS操作。与C++11的std::atomic类型不同,GCCC原子原语在常规的非原子整数类型上运行,包括cmpxchg16b平台上的128位整数>支持。(C++标准的future版本可能支持与std::atomic_view类模板类似的功能。)这让我产生疑问:如果对较大数据大小的原子CAS操作观察到由对同一内存位置的原子操作发生的变化,但使用较小的数据大小会发生什么?例如,假设我们有:structuint128_type{uint64_tx;uint64_ty;}__attribute

c++ - 比较和交换 : synchronizing via different data sizes

使用GCC内置的C原子原语,我们可以使用__atomic_compare_exchange执行原子CAS操作。与C++11的std::atomic类型不同,GCCC原子原语在常规的非原子整数类型上运行,包括cmpxchg16b平台上的128位整数>支持。(C++标准的future版本可能支持与std::atomic_view类模板类似的功能。)这让我产生疑问:如果对较大数据大小的原子CAS操作观察到由对同一内存位置的原子操作发生的变化,但使用较小的数据大小会发生什么?例如,假设我们有:structuint128_type{uint64_tx;uint64_ty;}__attribute

C++ - 在没有 RTTI/dynamic_cast 的情况下向下转换菱形继承对象

我目前正致力于在非RTTI平台(Android)上集成使用大量RTTI内容的第三方包。基本上,我自己实现了RTTI,但遇到了一个问题。问题是很多类都有菱形继承问题,因为所有类都派生自同一个基类(对象)。所以,如果我想从基类向下转换为派生类,我必须使用dynamic_cast-但RTTI不可用!没有dynamic_cast的虚拟继承时,如何将对象从父对象转换为子对象?看起来是这样的:classA{public:virtualchar*func(){return"A";};};classB:publicvirtualA{public://virtualchar*func(){return"

C++ - 在没有 RTTI/dynamic_cast 的情况下向下转换菱形继承对象

我目前正致力于在非RTTI平台(Android)上集成使用大量RTTI内容的第三方包。基本上,我自己实现了RTTI,但遇到了一个问题。问题是很多类都有菱形继承问题,因为所有类都派生自同一个基类(对象)。所以,如果我想从基类向下转换为派生类,我必须使用dynamic_cast-但RTTI不可用!没有dynamic_cast的虚拟继承时,如何将对象从父对象转换为子对象?看起来是这样的:classA{public:virtualchar*func(){return"A";};};classB:publicvirtualA{public://virtualchar*func(){return"

c++ - 如何检测分配给 size_t 的负数?

此声明在g++-pedantic-Wall(版本4.6.3)中编译时没有警告:std::size_tfoo=-42;不那么明显的虚假是声明一个带有size_t参数的函数,并用一个负值调用它。这样的函数能否防止无意的否定论点(显示为无数个quintillion,遵守§4.7/2)?不完整的答案:只是将size_t更改为(signed)long会丢弃size_t的语义和其他优点。将其更改为ssize_t只是POSIX,而不是标准。将其更改为ptrdiff_t很脆弱,有时会损坏。测试大值(高位设置等)是任意的。 最佳答案 为此发出警告的问

c++ - 如何检测分配给 size_t 的负数?

此声明在g++-pedantic-Wall(版本4.6.3)中编译时没有警告:std::size_tfoo=-42;不那么明显的虚假是声明一个带有size_t参数的函数,并用一个负值调用它。这样的函数能否防止无意的否定论点(显示为无数个quintillion,遵守§4.7/2)?不完整的答案:只是将size_t更改为(signed)long会丢弃size_t的语义和其他优点。将其更改为ssize_t只是POSIX,而不是标准。将其更改为ptrdiff_t很脆弱,有时会损坏。测试大值(高位设置等)是任意的。 最佳答案 为此发出警告的问