c语言给自定义函数赋值,[求助]用自定义的函数给结构体中的float类型变量赋值 编译 都通过了 运行总是出错...

TC开发时(80年代)DOS下的存储资源紧缺,因此TC在编译时尽量不加入无关部分。在没发现需要做浮点转换时,就不将这个部分安装到可执行程序里。但有时TC不能正确识别实际确实需要浮点转换,因此就会出现上面错误。

解决方法:设法告诉TC需要做浮点数输入转换。

struct内的float不能用 scanf来读,是TC的一个Bug

下面例子里增加了一个double变量并用它输入。

大程序里由于变量很多,只要有了线索,TC就会把浮点转换连上,因此反而不常遇到这个问题。

/* 能导致出现运行错误的程序例子。

在这里用的一个结构数组,结构里面有double类型的成分,TC不能正确识别和处理,因此会导致上述问题。*/

#include

#define NUM 4

struct entry {

int inum; /* 商品编号 */

int pc; /* 件数 */

double price;/* 价钱 */

} st[NUM]; /* st是个商品表 */

int main () {

int i;

for (i = 0; i < NUM; i++)

scanf("%d %d %lf", &st[i].inum, &st[i].pc, &st[i].price);

for (i = 0; i < NUM; i++)

printf("total price of item %d: %f\n",

st[i].inum, st[i].pc * st[i].price);

return 0;

}

/* 这个程序编译正常,运行中会出现上面错误信息 */

/* 修改的程序,其中增加了一个double变量x。问题就解决了 */

#include

#define NUM 4

struct entry {

int inum;

int pc;

double price;

} st[NUM];

int main () {

int i;

double x;

for (i = 0; i < NUM; i++) {

scanf("%d %d %lf", &st[i].inum, &st[i].pc, &x);

st[i].price = x;

}

for (i = 0; i < NUM; i++)

printf("total price of item %d: %f\n",

st[i].inum, st[i].pc * st[i].price);

return 0;

}

搜出来的,参考一下吧

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值