草庐IT

double-elimination

全部标签

c++ - 如何追踪 "double free or corruption"错误

当我运行我的(C++)程序时,它会因此错误而崩溃。*glibcdetected*./load:doublefreeorcorruption(!prev):0x0000000000c6ed50***如何追踪错误?我尝试使用print(std::cout)语句,但没有成功。gdb可以让这更容易吗? 最佳答案 如果你使用glibc,你可以将MALLOC_CHECK_环境变量设置为2,这将导致glibc使用一个容错版本的malloc,这将导致您的程序在双重释放完成时中止。您可以在运行程序之前使用setenvironmentMALLOC_CH

c++ - 为什么 sizeof(unsigned double) 等于 4?

我的一个同事问有没有unsigneddouble,我说没有,但我还是查了一下,编译到MicrosoftVisualC++2010:unsigneddoublea;doubleb;printf("size_a=%dsize_b=%d",(int)sizeof(a),(int)sizeof(b));它输出size_a=4size_b=8。即unsigneddouble为4个字节,double为8个字节。 最佳答案 unsigneddouble无效。在MSVC中也是如此。在启用警告的MSCV2010中编译上述代码时,您会得到:警告C407

c++ - C/C++ 中的最小 double 值

是否有标准和/或可移植的方式来表示C(++)程序中的最小负值(例如,使用负无穷大)?float.h中的DBL_MIN是最小的正数。 最佳答案 -DBL_MAXinANSIC,在float.h中定义。 关于c++-C/C++中的最小double值,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/1153548/

c++ - 我应该使用 double 还是 float ?

在C++中使用一种代替另一种的优点和缺点是什么? 最佳答案 如果你想知道真正的答案,你应该阅读WhatEveryComputerScientistShouldKnowAboutFloating-PointArithmetic.简而言之,虽然double在其表示中允许更高的精度,但对于某些计算,它会产生更大的错误。“正确”的选择是:使用尽可能多的精度,但不要更多并选择正确的算法。无论如何,许多编译器都在“非严格”模式下进行扩展float学运算(即使用硬件中可用的更广泛的浮点类型,例如80位和128位浮点),这也应该被考虑在内。在实践中

C++ 将 vector <int> 转换为 vector <double>

什么是转换std::vectorintVec的好方法?至std::vectordoubleVec.或者,更一般地,转换两个可转换类型的vector? 最佳答案 使用std::vector的范围构造函数:std::vectorintVec;std::vectordoubleVec(intVec.begin(),intVec.end()); 关于C++将vector转换为vector,我们在StackOverflow上找到一个类似的问题: https://stac

c++ - 为什么将两个 int 分配给 double 时不会产生正确的值?

为什么会出现在下面的代码片段中inta=7;intb=3;doublec=0;c=a/b;c最终的值为2,而不是预期的2.3333。如果a和b是double,那么答案确实会变成2.333。但肯定是因为c已经是一个double它应该与整数一起使用?那么为什么int/int=double不起作用? 最佳答案 这是因为您使用的是operator/的整数除法版本,它需要2个int并返回一个int。为了使用返回double的double版本,必须将至少一个int显式转换为双.c=a/(double)b;

c++ - 0.1 float 大于 0.1 double。我以为是假的

这个问题在这里已经有了答案:Ifoperator(5个回答)关闭9年前。让:doubled=0.1;floatf=0.1;应该表达(f>d)返回true还是false?根据经验,答案是true。但是,我希望它是false。由于0.1不能完美地用二进制表示,而double有15到16十进制数字精度,而float只有7。因此,它们都小于0.1,而double更接近0.1。我需要对true的确切解释。 最佳答案 我想说答案取决于将double转换为float时的舍入模式。float有24位binary位精度,而double有53位。在二进

iphone - 从 float 或 double 实例化 NSDecimalNumber 的正确方法

我正在寻找从double或short实例化NSDecimalNumber的最佳方法。有以下NSNumber类和实例方法...+NSNumbernumberWithFloat+NSNumbernumberWithDouble-NSNumberinitWithFloat-NSNumberinitWithDouble但这些似乎返回NSNumber。另一方面,NSDecimalNumber定义如下:+NSDecimalNumberdecimalNumberWithMantissa:exponent:isNegative:+NSDecimalNumberdecimalNumberWithDeci

iphone - 如何找到 malloc "double free"错误的原因?

我正在用Objective-C编写一个应用程序,但我收到了这个错误:MyApp(2121,0xb0185000)malloc:***errorforobject0x1068310:doublefree***setabreakpointinmalloc_error_breaktodebug当我释放NSAutoreleasePool时会发生这种情况,但我无法确定我要释放两次的对象。如何设置他的断点?有没有办法知道这个“对象0x1068310”是什么? 最佳答案 当一个对象被“双重释放”时,最常见的原因是您(不必要地)释放了一个自动释放的

c++ - 如何在 C++ 中将 double 转换为字符串?

我需要将double值存储为字符串。我知道如果我想显示它可以使用printf,但我只想将它存储在一个字符串变量中,以便以后可以将它存储在map中(作为value,而不是键)。 最佳答案 //TheCway:charbuffer[32];snprintf(buffer,sizeof(buffer),"%g",myDoubleVar);//TheC++03way:std::ostringstreamsstream;sstream(myDoubleVar); 关于c++-如何在C++中将dou