Cout long double issue

nervousDev picture nervousDev · Dec 18, 2014 · Viewed 8.1k times · Source

So, I'm working on a C++ project. I have a var of long double type and assigned it a value like "1.02"

Then, I try to use cout to print it and the result is: -0

I already tried to use setprecision and all I found googling the problem.

What is the solution for this?

Example code:

#include <cstdlib>
#include <iomanip>

using namespace std;

int main(int argc, char** argv)
{

    cout.precision(15);
    long double var = 1.2;
    cout << var << endl;
    return 0;
}

OS: Windows 8.1 64 bits Compiler: minGW IDE: NetBeans 8.0.2

Answer

Smylic picture Smylic · Jun 8, 2015

It seems to be a problem with compiler. Take a look here: http://mingw.5.n7.nabble.com/Strange-behaviour-of-gcc-4-8-1-with-long-double-td32949.html

Use printf or convert a value of your variable to double before passing to cout. (BTW are sure you need 80-bit precision?)