草庐IT

double-byte

全部标签

c++ - 随机 double 总是无限的

我有以下内容:std::random_devicerd;std::mt19937_64randEng(rd());std::uniform_real_distributionrg(std::numeric_limits::lowest(),std::numeric_limits::max());for(size_ti=0;i其中nums是一个vector,预大小为numToGenerate尽管打印出的每个数字都显示inf,但我的理解是,我已将其设置为在这种情况下获取-1.79769e+308和1.79769e+308因为它恰好在我的机器上。我在这个随机数生成器的设置中做错了什么

c++ - 提升精神 x3 int32 | double_ 无法解析 double

我正在尝试编写一个解析器,它解析int32_t或double.作为第一次尝试,我编写了这个解析器:constautoint_or_double=boost::spirit::x3::int32|boost::spirit::x3::double_;我希望得到一个boost::variant解析器成功解析了类似12,100,-42,7的整数但它无法解析像13.243,42.7,12.0-10000.3这样的double这是一个直播demo为什么这个解析器在double上失败? 最佳答案 您的问题与thisquestion非常相似.当整

c++ - 使用与 double 数组的内存匹配的 std::vector

我正在尝试连接两个现有代码库——一个使用C,另一个使用C++。C++代码使用std::vector而另一个基于double组。我想从C代码传递double组,在C++代码中对std::vectors执行操作,并最终将这些操作反射(reflect)在double组中。是否可以创建一个std::vector来匹配double数组占用的内存?我尝试了几种选择,但它们都涉及创建一个新vector和将double数组的拷贝复制到该vector中。例如:voidfcn(double*a,intsizeofa){std::vectorvect_a;vect_a.assign(a,a+sizeofa)

c++ - 为 vector<double> 类重载 *, +, -' 运算符

我正在编写一个Line类来制作数值方法,我想要这些运算符(*、+、-)使我的代码更具可读性和更容易理解。#includeusingnamespacestd;typedefvectorVector;classLine:publicVector{public:Line();~Line();Lineoperator+(Line);Lineoperator-(Line);Lineoperator*(double);};LineLine::operator*(doublealfa){Linetemp;intn=size();temp.resize(n);for(inti=0;iat(i)*alf

c++ - 如何检查字符串是否可以在 C++ 中转换为 double ?

我有一个字符串,它可以是数字(甚至是float或double类型,不仅是整数),也可以是非数字的单词。我想检查这个字符串是否可以转换为double,如果可以,那么我想进行转换。如果是非数字字符串,我想要不同的行为。我试过这个:doubletmp;stringstr;stringstreamss;ss>tmp;if(ss.fail()){//non-numericstring}else{//stringtodoubleconversionissuccessful}此代码的问题在于ss.fail()总是true,即使tmp包含正确的值。有一个函数叫做atof()它将字符串转换为double

c++ - 定义最大 double 时,“无法在初始化中将 'double (*)() noexcept' 转换为 'double'”

我读到使用最大double值的标准C++方法是std::numeric_limits::max.然后在我想要将我的double初始化为我使用的最大double的每个函数中:#include#defineMAX_DOUBLE(std::numeric_limits::max)使用gcc-pedantic-pedantic-errors-Wall-Wextra-Werror,我得到以下错误:Cannotconvert'double(*)()noexcept'to'double'ininitialization你能解释一下这个错误吗? 最佳答案

C++ : double iteration through map

我想遍历一个map,但内部循环只会遍历元素的上半部分。使用vector它看起来像这样:for(autoelement1=myVector.begin();element1!=myVector.end();++element1){for(autoelement2=element1+1;element2!=myVector.end();++element2){//mystuff}}但是对于mapelement1+1返回错误nooperatormatchesthisoperand..我相信这是因为元素在map中没有排序.那么我怎样才能正确地做到这一点呢?我目前正在使用这种需要在每个循环中进行

c++ - 使用 fstream 设置精度以输出文件 - double 格式

对于如何使用已打开的fstream将格式化的double输出到文本文件,我找不到答案。目前我的代码是这样做的:intwriteToFile(fstream&f,product_record&p){if(!f){cout其中p是名为product_record的结构,price、tax、sANDh和total都是doubles我试过f但这不起作用。我如何将此double格式设置为小数点后两位的精度。像这样"#.00".我如何使用专门的fstream来实现这一目标?此外,仅供引用,总体任务是简单地读取一个txt文件,将数据存储在一个结构中,将结构添加到一个vector中,然后从结构中读取以

MySQL 1071 - Specified key was too long; max key length is 1000 bytes解决方案

1071-Specifiedkeywastoolong;maxkeylengthis1000bytes解决方案在设计数据库表时,主键设计varchar长度为255,点击保存表,数据库报错如下图所示原因:在UTF-8MB4字符集下,每个字符通常需要4字节来存储。因此,如果你在VARCHAR(255)字段上使用UTF-8MB4字符集,它的最大存储长度将是255*4=1020字节,这已经超过MySQL的默认主键长度限制(1000字节)。在这种情况下,如果你尝试将VARCHAR(255)列作为主键并使用UTF-8MB4字符集,你可能会遇到“1071-Specifiedkeywastoolong;max

c++ - 如何使用类似 `std::basic_istream<std::byte>` 的东西

本题旨在使用std::byte具有标准输入输出。是否有任何计划为read(_bytes)添加适当的函数重载?和write(_bytes)到basic_istream的接口(interface)和basic_ostream在未来的标准?有什么理由反对它?我知道CharT*-应保留过载。我可以做什么来使用std::byte?我目前在我的项目功能中定义std::istream&read(std::istream&,std::byte*,std::streamsize)std::ostream&write(std::ostream&,conststd::byte*,std::streamsiz