Qt жүйесінде бағдарламалық жасақтаманы әзірлеу кезінде qDebug() көмегімен өзгермелі нүкте сандарын көрсету кезінде бір нюансқа тап болдым. Мәселе ондық нүктеден кейінгі барлық таңбалардың көрсетілмейтіндігінде. Бұл std::cout шығысына да қатысты.
Ұқсас пайдаланушы жағдайы келесі жағдайда туындауы мүмкін:
Сізде "8564.26495574" саны бар QString нысаны бар, оны біз toDouble(), әдісі арқылы қалқымалы мәнге түрлендіреміз және нәтижені qDebug() шығысымен тексереміз, бірақ мәселе міне. , қорытынды жалған болып шығады.
QString str("8564.26495574"); qDebug() << str.toDouble(); // В выводе получаем -> 8564.26
Біз нақты дұрыс санды алып жатқанда, яғни жолдан 8564.26495574 саны қайтарылды, тек qDebug() шығысы дөңгелектенген нәтижені көрсетеді.
qDebug(). ішінде double санының мәнін жай ғана шығаруға тырыссаңыз, дәл осылай байқауға болады.
double a = 8564.26495574; qDebug() << a; // В выводе получаем -> 8564.26
Көрсеткіш toDouble(). әдісіне аргумент ретінде жіберілетін bool айнымалысы арқылы QString-тен екі еселенген санды түрлендіру кезінде қателердің болмайтынына көз жеткізуге болады.
QString str("8564.26495574"); bool ok = false; qDebug() << str.toDouble(&ok); qDebug() << ok; // В выводе получим следующее // 8564.26 // true - то есть ошибок не было
Дұрыс шығару үшін пішімдеу түрі мен дәлдігі көрсетілген QString::arg() әдісін пайдалану керек.
QString str("8564.26495574"); double a = 8564.26495574; double b = str.toDouble(); qDebug() << QString("%1").arg(a, 0, 'f', 5); qDebug() << QString("%1").arg(a, 0, 'g', 5); qDebug() << QString("%1").arg(a, 0, 'e', 10); qDebug() << QString("%1").arg(a, 0, 'g', 30); qDebug() << QString("%1").arg(b, 0, 'f', 5); qDebug() << QString("%1").arg(b, 0, 'g', 5); qDebug() << QString("%1").arg(b, 0, 'e', 10); qDebug() << QString("%1").arg(b, 0, 'g', 30);
Нәтижесінде біз келесі нәтижені аламыз qDebug():
"8564.26496" "8564.3" "8.5642649557e+3" "8564.26495574000000488013029099" "8564.26496" "8564.3" "8.5642649557e+3" "8564.26495574000000488013029099"
Екі жағдайда да біз бірдей нәтиже аламыз, өйткені сан жерде және жерде бірдей.
Пішімдеу түрлері туралы бірнеше сөз:
- 'g' - санның бүтін бөлігіндегі ең үлкен цифрдан басталатын таңбалардың көрсетілген санын көрсетеді;
- 'f' - ондық дәлдікпен белгіленген символдар санын көрсетеді;
- 'e' - ондық дәлдікпен белгіленген таңбалар санын және жасырын цифрлар санын көрсетеді.
Көріп отырғаныңыздай, 8564.26495574000000488013029099 шығысында кішкене қателік бар. Бұл қазірдің өзінде есептеулер жүргізілетін компьютердің математикалық аппаратының ерекшеліктеріне байланысты. Кез келген компьютердегі сандардың сыйымдылығы шектеулі, сондықтан ондық бөлшектен кейінгі ең соңғы санда дөңгелектеу орын алады, бұл санның осындай нұсқаларының пайда болуына әкеледі. Бұл нақты есептеулерде ескерілуі керек.
Добрый день, подскажите пожалуйста. Столкнулся с проблемой, парсю JSON получаю цифровые значения типа string, пример (QJsonValue(string, "0.0000000001")), делаю преобразование типа в double.
На выходе у меня получается такое значение 1Е-10, каким образом мне получить значение 0.0000000001 в переменной double. Делать дополнительное преобразование в QML считаю не нормальным.
Решение было найдено. В QML использовал метод JavaScript toFixed() Method, массив data_1[0].toFixed(10), 10 количество мне нужных знаков после запятой.