乐趣区

关于c:CC常见赋值编译报错警告如何处理

问题形容 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;

运行后果:

退出移动版