草庐IT

numeric_traits_integer

全部标签

c++ - Uniform_real 不接受 numeric_limits::lowest()

我有一条线:std::uniform_real_distributiondistribution(std::numeric_limits::lowest(),std::numeric_limits::max());它编译但在调试时崩溃(VS2017CE)。我的猜测是,根据std::uniform_real_distribution的文档:Requiresthata≤bandb-a≤std::numeric_limits::max()当我的b是::max()和a是::lowest(),条件:b-a≤std::numeric_limits::max()未满足b-a基本上使max的值翻倍.有

c++ - GNU/G++ 4.9(2.95.3 之前的版本)的 C++11 中的 string_char_traits<char>

我有一些遗留的C++代码(用于使用GNUg++2.95.3进行编译)具有以下声明std::basic_string,malloc_alloc>x;头文件是#include现在,我正在迁移到GUg++4.9,但出现此错误:1.std/bastring.h未找到2.当我改变#include作为#include,我收到以下错误:error:'string_char_traits'wasnotdeclaredinthisscopestd::basic_string,malloc_alloc>x;error:templateargument2isinvalidstd::basic_string,

c++ - 使用类型删除创建运行时 type_traits 查询

是否有可能使用类型删除来创建封装任意类型的对象(我们称之为ErasedType),并且可以在运行时查询以判断是否存在另一个任意类型T可转换为ErasedType?考虑之后,我不认为这是可能的-尽管看起来它在理论上可能是可能的。编译器会知道哪些类型T我们正在尝试与ErasedType进行比较,因此可以在运行前生成必要的代码。问题是,在实践中,似乎没有任何方法可以将模板参数类型从基类实例传递到子类实例。例如:structFooBase{templateboolis_convertible(){returncall_derived();}protected:virtualboolcall_d

c++ - boost type_traits is_array

我一直在尝试浏览Boosttype-traitsheader,考虑到无数#define提供的强烈不可读性,现在我感到非常恶心。然后是更多#define。具体来说,我有兴趣弄清楚以下3个特征:类型T是数组、类还是枚举。任何人都可以帮助建议一些破译明显疯狂背后的方法的方法吗?比如你如何从一个类型中找出特征背后的理论,任何相关的阅读Material等。 最佳答案 is_array非常简单直接:templatestructis_array{staticconstboolvalue=false;};templatestructis_array

c++ - 为什么没有未调整大小的 Integer 类型?

按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visitthehelpcenter指导。关闭11年前。为什么STL不包含无限整数数据类型?我感觉是一种目的类似于字符串的数据类型。程序员不必担心值溢出并且可以处理更大的数字。所以我很好奇它的缺失是否有特定原因。这不是关于如何实现或使用来自第3方库的问题,但只是一个问题,为什么这种语言还没有附带一个。感谢有关此事的任何链接。

c++ - std::allocator_traits::construct with const 指针

下面的代码可以正常编译:#include#includeintmain(){constint*a=newint(5);std::cout>;autoalloc=std::allocator();at::construct(alloc,a);std::cout在libstdc++的背后::new((void*)a)int;但是a是const!这是未定义的行为吗?或者placementnew不算修改?我修改了*a的值,是const。据我了解,这是不允许的:Modifyingaconstobjectthroughanon-constaccesspathandreferringtoavolat

c++ - 如何使用 numeric_cast 策略?

所以我有自己的uint64_t到uint32_t数字转换策略structMyOverflowHandlerPolicy{voidoperator()(boost::numeric::range_check_result){std::cout如何让boost::numeric_cast使用它? 最佳答案 为了使用numeric_cast,numeric_cast_traits特化应该在每个类型转换上定义。这些特化已经为内置数字类型定义了默认值。可以通过定义BOOST_NUMERIC_CONVERSION_RELAX_BUILT_IN_

c++ - 数组索引类型 : signed/unsigned integer avantages

在C++中,数组索引的默认大小是size_t,它是大多数x86-64平台上的64位无符号64位整数。我正在为我的高性能计算库构建自己的std::vector类(主要原因之一是我希望此类能够取得指针的所有权,而std::vector没有提供)。对于数组索引的类型,我正在考虑使用:size_t我自己的index_t是一个signedint或longsignedint,这取决于我的程序与无符号整数相比,使用有符号整数的优点很多,例如for(index_ti=0;i像它应该的那样工作(使用无符号整数,当v的大小为0时,这个循环会变得疯狂)for(index_ti=v.size()-1;i>=0

c++ - type_traits - 连续内存

我有一个处理任何容器类型的接口(interface)。std::vector、std::array,甚至std::basic_string。问题是没有什么可以阻止某人传递没有连续内存的容器。我目前的解决方案是删除那些我想阻止的接口(interface)。voiddosoemthing(conststd::list&)=delete;voiddosoemthing(conststd::map&)=delete;但是,如果我可以只添加一个基于类型特征的静态断言,我会更愿意。这引出了我的问题。它们是否存在可用于识别其内存是否连续的容器类型特征?我一直在通过documentation来还没有找

c++ - 没有匹配函数调用 `std::basic_ofstream<char, std::char_traits<char>>::basic_ofstream(std::string&)'

我正在尝试编写一个程序,要求用户输入文件名,然后打开该文件。当我编译它时,出现以下错误:nomatchingfunctionforcalltostd::basic_ofstream>::basic_ofstream(std::string&)这是我的代码:usingnamespacestd;intmain(){stringasegurado;cout>asegurado;ofstreamentrada(asegurado,"");if(entrada.fail()){cout 最佳答案 std::ofstream如果您有C++11或