问题形容 1
将默认为双精度的实型常量赋值给单精度变量。
语句编写:
#include<stdio.h>
#define pl 3.14
int main()
{
float r,area;
r=1.5;
area=pl*r*r;
printf("area=%f\n",area);
return 0;
}
编译正告️
werning C4244:”=’:co onversion from ‘double / to “float
但不影响程序运行
解决办法:
如果将 float 批改为 double,将 %f 批改为 %lf 后,就没有正告了。
运行后果:
问题形容 2
两个定义的时候,同时赋初值。
语句编写:
#include<stdio.h>
int main()
{
int x=y=2,z;
z=x+y;
printf("x+y=%d\n",z);
return 0;
}
编译谬误 erlor c2065: ‘y’ : undeclared identifier
解决办法:
变量 x 和 y 独自定义独自赋初值,将 int x=y=2,z 批改为 int x=2,y=2,z;
运行后果:
问题形容 3:
将带双引号的字符串赋值给了字符变量
语句编写:
#include<stdio.h>
int main()
{
char ch;
ch="A";
printf("%c 的 ASCll 的值为:%d\n",ch,ch);
return 0;
}
编译正告️
warning c4847: “=” : “char ” diff Fers in levels of indirection from “char [2]
解决办法:
将字符串 ”A” 批改为字符 ’A’。
运行后果:
问题形容 4:
实型数据参加了 %(求余)运算
语句编写:
#include<stdio.h>
int main()
{printf("%d\n",3%2.0);
return 0;
}
编译谬误:error C2297: ‘%’ : illegal, right operand has type “const double “
解决办法:
只有整数能力加入 %(求余)运算,将 2.0 批改为 2。
运行后果:
乘法运算问题
问题形容 5:
两个变量进行乘法运算时,遗记书写乘号 ”*”。
语句编写:
#include<stdio.h>
int main()
{
double l=2,w=3,s;
s=lw;
printf("s=%lf\n",s);
return 0;
}
编译谬误 error c2065: ‘lw’: undeclared identifler
解决办法:
乘法的符号不能省略,将 s =lw; 批改为 s =l*w;
运行后果: