Форум программистов, компьютерный форум CyberForum.ru

Почему при объявлении переменных тип float выдает ошибку - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 17, средняя оценка - 4.82
nutius
0 / 0 / 0
Регистрация: 01.06.2011
Сообщений: 60
18.10.2012, 16:20     Почему при объявлении переменных тип float выдает ошибку #1
Подскажите, пожалуйста, почему когда я объявляю переменные как float, то выскакивает ошибка, а когда меняю тип на double, то все корректно работает?

#include <math.h>
#include <stdio.h>
#include <conio.h>

void main ()
{
float a=6.32, b=7.28, c=3.15, d=2.16, result;
printf ("Formula ravno");
result=(sinh(abs(b))/pow (a,b))+4*(pow(d,1.4)/log(c));
printf ("\n Result = %7.2f", result);
getch ();

}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Герц
523 / 340 / 4
Регистрация: 05.11.2010
Сообщений: 1,077
Записей в блоге: 1
18.10.2012, 16:21     Почему при объявлении переменных тип float выдает ошибку #2
main имеет тип int.
nutius
0 / 0 / 0
Регистрация: 01.06.2011
Сообщений: 60
18.10.2012, 16:34  [ТС]     Почему при объявлении переменных тип float выдает ошибку #3
Цитата Сообщение от Герц Посмотреть сообщение
main имеет тип int.
Спасибо за ответ, но с void оно работает, я же оператор return не вписывала. Дело, мне кажется, в другом...

Добавлено через 3 минуты
Вот, допустим, эта программа работает с возвращаемым типом void:

#include <stdio.h> //header file for input-output
#include <math.h> //header file for math calculations
#include <conio.h> //header file for console
/* -------------------- main function -------------------- */
void main()
{
float a, b, c, p, S;
printf("Enter the sides of triangle:\n");
scanf ("%f%f%f",&a,&b,&c);//input of variables
p=(a+b+c)/2;
S=sqrt( p*(p-a)*(p-b)*(p-c) );
printf("\n Result: S=%7.2f",S); // output results
getch();
}
Герц
523 / 340 / 4
Регистрация: 05.11.2010
Сообщений: 1,077
Записей в блоге: 1
18.10.2012, 16:38     Почему при объявлении переменных тип float выдает ошибку #4
Без вывода компилятора сказать ничего нельзя.
Возможно он вам просто кидает ворнинги на понижающее приведение double-литерала (6.32) в float, при котором теряется точность. Может быть выдает ошибку, так как включен режим warnings as errors.
Короче, что компилятор пишет?)
И вообще, это не C++, а C.
nutius
0 / 0 / 0
Регистрация: 01.06.2011
Сообщений: 60
18.10.2012, 16:40  [ТС]     Почему при объявлении переменных тип float выдает ошибку #5
Цитата Сообщение от Герц Посмотреть сообщение
Без вывода компилятора сказать ничего нельзя.
Возможно он вам просто кидает ворнинги на понижающее приведение double-литерала (6.32) в float, при котором теряется точность. Может быть выдает ошибку, так как включен режим warnings as errors.
Короче, что компилятор пишет?)
И вообще, это не C++, а C.
Вот что он пишет:

1>c:\documents and settings\ann_\мои документы\visual studio 2008\projects\1111\1111\33.cpp(8) : warning C4305: 'initializing' : truncation from 'double' to 'float'
1>c:\documents and settings\ann_\мои документы\visual studio 2008\projects\1111\1111\33.cpp(8) : warning C4305: 'initializing' : truncation from 'double' to 'float'
1>c:\documents and settings\ann_\мои документы\visual studio 2008\projects\1111\1111\33.cpp(8) : warning C4305: 'initializing' : truncation from 'double' to 'float'
1>c:\documents and settings\ann_\мои документы\visual studio 2008\projects\1111\1111\33.cpp(8) : warning C4305: 'initializing' : truncation from 'double' to 'float'
1>c:\documents and settings\ann_\мои документы\visual studio 2008\projects\1111\1111\33.cpp(10) : error C2666: 'pow' : 6 overloads have similar conversions
1> c:\program files\microsoft visual studio 9.0\vc\include\math.h(575): could be 'long double pow(long double,int)'
1> c:\program files\microsoft visual studio 9.0\vc\include\math.h(573): or 'long double pow(long double,long double)'
1> c:\program files\microsoft visual studio 9.0\vc\include\math.h(527): or 'float pow(float,int)'
1> c:\program files\microsoft visual studio 9.0\vc\include\math.h(525): or 'float pow(float,float)'
1> c:\program files\microsoft visual studio 9.0\vc\include\math.h(489): or 'double pow(double,int)'
1> c:\program files\microsoft visual studio 9.0\vc\include\math.h(123): or 'double pow(double,double)'
1> while trying to match the argument list '(float, double)'
1>Build log was saved at "file://c:\Documents and Settings\Ann_\Мои документы\Visual Studio 2008\Projects\1111\1111\Debug\BuildLog.htm"
1>1111 - 1 error(s), 4 warning(s)
========== Build: 0 succeeded, 1 failed, 0 up-to-date, 0 skipped ==========
Герц
523 / 340 / 4
Регистрация: 05.11.2010
Сообщений: 1,077
Записей в блоге: 1
18.10.2012, 16:45     Почему при объявлении переменных тип float выдает ошибку #6
Добавляй суффикс 'f' на конец каждого числового литерала, например 6.32f.
Если бы это был C++ код, то проблемы бы не было.
И да, про "void main", такие вольности разрешены только в C.
C++ компилятор сказал бы тебе "main must return int".
C++
1
2
3
4
5
6
7
8
9
#include <cmath>
#include <cstdio>
int main ()
{
float a=6.32, b=7.28, c=3.15, d=2.16, result;
printf ("Formula ravno");
result=(std::sinh(std::abs(b))/std::pow (a,b))+4*(std::pow(d,1.4)/std::log(c));
printf ("\n Result = %7.2f", result);
}
Croessmah
Модератор
Эксперт С++
 Аватар для Croessmah
11822 / 6801 / 769
Регистрация: 27.09.2012
Сообщений: 16,869
Записей в блоге: 2
Завершенные тесты: 1
18.10.2012, 16:54     Почему при объявлении переменных тип float выдает ошибку #7
Цитата Сообщение от Герц Посмотреть сообщение
Если бы это был C++ код, то проблемы бы не было.
Как раз компилятор C++ более строгий и в таких случаях нужное явное привидения типом.
Герц
523 / 340 / 4
Регистрация: 05.11.2010
Сообщений: 1,077
Записей в блоге: 1
18.10.2012, 16:57     Почему при объявлении переменных тип float выдает ошибку #8
Да ну?
http://liveworkspace.org/code/c5d619...9295d9eae0e4f0
nutius
0 / 0 / 0
Регистрация: 01.06.2011
Сообщений: 60
18.10.2012, 17:03  [ТС]     Почему при объявлении переменных тип float выдает ошибку #9
Цитата Сообщение от Герц Посмотреть сообщение
Добавляй суффикс 'f' на конец каждого числового литерала, например 6.32f.
Если бы это был C++ код, то проблемы бы не было.
И да, про "void main", такие вольности разрешены только в C.
C++ компилятор сказал бы тебе "main must return int".
C++
1
2
3
4
5
6
7
8
9
#include <cmath>
#include <cstdio>
int main ()
{
float a=6.32, b=7.28, c=3.15, d=2.16, result;
printf ("Formula ravno");
result=(std::sinh(std::abs(b))/std::pow (a,b))+4*(std::pow(d,1.4)/std::log(c));
printf ("\n Result = %7.2f", result);
}
извините, за глупый вопрос..Я что-то немного запуталась...а почему мой код не с++, а сишный?
почему функция main должны возвращать только тип int, а если мне, допустим, необходимо вывести тип string, тогда как быть?
Герц
523 / 340 / 4
Регистрация: 05.11.2010
Сообщений: 1,077
Записей в блоге: 1
18.10.2012, 17:08     Почему при объявлении переменных тип float выдает ошибку #10
Ваш код не C++, потому что он использует C-соглашение о типе функции main(void либо int), использует функции стандартной библиотеки C (из заголовочных файлов stdio.h, math.h).
Функция main в соответствии со стандартном C++ должна возвращать исключительно int.
main - особенная функция, и ее возвращаемое значение служит кодом возврата для операционной системы (в основном используется только в консольных приложениях), обычно return 0; означает успешное ее завершение.

А куда вы собираетесь вернуть свой string из main? :-)
nutius
0 / 0 / 0
Регистрация: 01.06.2011
Сообщений: 60
18.10.2012, 17:13  [ТС]     Почему при объявлении переменных тип float выдает ошибку #11
Цитата Сообщение от Герц Посмотреть сообщение
Ваш код не C++, потому что он использует C-соглашение о типе функции main(void либо int), использует функции стандартной библиотеки C (из заголовочных файлов stdio.h, math.h).
Функция main в соответствии со стандартном C++ должна возвращать исключительно int.
main - особенная функция, и ее возвращаемое значение служит кодом возврата для операционной системы (в основном используется только в консольных приложениях), обычно return 0; означает успешное ее завершение.

А куда вы собираетесь вернуть свой string из main? :-)
Спасибо большое, теперь все больше мне проясняется!
Только вот ваш код прожки у меня тоже не работает...(( теже ошибки
Правда, я еще нашла ошибку, что я не подключила файл для abs, а именно stdlib.h. но ошибки остались прежними
Герц
523 / 340 / 4
Регистрация: 05.11.2010
Сообщений: 1,077
Записей в блоге: 1
18.10.2012, 17:23     Почему при объявлении переменных тип float выдает ошибку #12
http://liveworkspace.org/code/d4eee7...a8a5037338523d - вот мой код, в gcc работает.
Если ты используешь Visual Studio, он не слишком блюдет стандарт, так что возможно что не собирается.
Croessmah
Модератор
Эксперт С++
 Аватар для Croessmah
11822 / 6801 / 769
Регистрация: 27.09.2012
Сообщений: 16,869
Записей в блоге: 2
Завершенные тесты: 1
18.10.2012, 18:34     Почему при объявлении переменных тип float выдает ошибку #13
Цитата Сообщение от Герц Посмотреть сообщение

C++
1
2
3
4
5
6
int main(){
   int * p=0;
   void *p2=0;
  p=p2;
   return 0;
}
gcc - проблем нет.
g++ - ошибка
OhMyGodSoLong
~ Эврика! ~
 Аватар для OhMyGodSoLong
1234 / 983 / 42
Регистрация: 24.07.2012
Сообщений: 2,002
18.10.2012, 18:50     Почему при объявлении переменных тип float выдает ошибку #14
Цитата Сообщение от Croessmah Посмотреть сообщение
C++
1
2
3
4
5
6
int main(){
   int * p=0;
   void *p2=0;
  p=p2;
   return 0;
}
gcc - проблем нет.
g++ - ошибка
Си++ не позволяет неявно приводить void* к указателю на что угодно. В Си так делать можно. gcc компилирует Си, а не Си++.
Герц
523 / 340 / 4
Регистрация: 05.11.2010
Сообщений: 1,077
Записей в блоге: 1
18.10.2012, 18:51     Почему при объявлении переменных тип float выдает ошибку #15
Замечательно, но причем тут то, о чем я писал выше?
Тебе не хватает reinterpret_cast'a (хотя даже static_cast'а хватит), это стандартное поведение.
Такие извращения с указателями вполне логично запретить делать по-умолчанию.
~OhMyGodSoLong~ меня опередил :-)
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
18.10.2012, 18:54     Почему при объявлении переменных тип float выдает ошибку
Еще ссылки по теме:

Почему выдает ошибку при вводе? C++
Почему при умножении двух переменных типа int выдает ответ 76? C++
Почему выдает ошибку при работе с большим файлом, напишите как исправить ? C++

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
Croessmah
Модератор
Эксперт С++
 Аватар для Croessmah
11822 / 6801 / 769
Регистрация: 27.09.2012
Сообщений: 16,869
Записей в блоге: 2
Завершенные тесты: 1
18.10.2012, 18:54     Почему при объявлении переменных тип float выдает ошибку #16
Цитата Сообщение от Герц Посмотреть сообщение
Замечательно, но причем тут то, о чем я писал выше?
Тебе не хватает reinterpret_cast'a, это стандартное поведение.
~OhMyGodSoLong~ меня опередил :-)
А при том, что я написал, что в си++ нужно явноепривидение типов, Вы же начали спорить. Отсюда вывод какой компилятор строже относится к типам.
здесь хватит (int*)
Yandex
Объявления
18.10.2012, 18:54     Почему при объявлении переменных тип float выдает ошибку
Ответ Создать тему
Опции темы

Текущее время: 23:40. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru