作者typers (Typer)
看板mud
标题[请益] LPC 数值转型
时间Sat Jun 23 12:26:32 2018
float pi = 3.14;
int i = (int) pi;
if (intp(i)) {
printf("It's INT, i = %d\n", i);
} else if (floatp(i)) {
printf("It's FLOAT, i = %f\n", i);
} else if (stringp(i)) {
printf("It's STRING, i = \"%s\"\n", i);
}
猜猜上面这段 LPC 会印出哪一种结果
--
※ 发信站: 批踢踢实业坊(ptt.cc), 来自: 36.235.37.201
※ 文章网址: https://webptt.com/cn.aspx?n=bbs/mud/M.1529727995.A.C49.html
1F:→ laechan : 蛮有意思的呵122.117.106.224 06/23 13:09
2F:→ nightcola : int ! 1.171.39.137 06/23 13:19
(以下说明是以 fluffos 2.27 为基础, 其他版本的 mudos 也许会有不一样的结果)
答案: It's FLOAT, i = 3.140000
这个结果实在是有够让人 Orz 的
经过了几次测试
发现 int i = (int) pi; 这样的用法
只是把 float 型态的值硬塞进 int 型态的变数
表面看起来是 int, 但骨子里还是 float, 实际上并没有转型
另外测试去掉转型变成 int i = pi;
^^^^^^^^^^^
这边有误, 详见补充说明
则是会引发 runtime error
又 fluffos 提供了一个 to_int() 的 efun
可以将 string/float 转成 int
故小弟的结论:
LPC 中 (int|float|string|...) 形式的转型, 实际上是没有作用的
同时也要避免使用, 因为用了反而会抑制 error 的发生, 导致更多的 bug
这种现象应该算是 fluffos 2.27 的 bug 了
但小弟对 lex/yacc 实在不熟, 连问题在哪都看不出来
在还没找到修正的方式之前, 只能避免使用强制转型了
※ 编辑: typers (36.235.37.201), 06/24/2018 01:27:26
3F:推 ddavid : 这也太华丽的处理方式了吧XD 114.36.162.193 06/24 08:27
4F:推 ddavid : 那这之後i被拿去int操作,它又怎麽 114.36.162.193 06/24 08:32
5F:推 ddavid : 处理的,会烂得很惨还是神秘地能够 114.36.162.193 06/24 08:36
6F:推 ddavid : 撑住某些常用情况? 114.36.162.193 06/24 08:36
转型後的 i 就是 int 皮 float 骨
後续的 +-*/ 都会当作 float 运算
赋值至其他 int 变数时不会出错, 结果仍是 int 皮 float 骨
不过在 printf("%d", i); 这种会检查型别的 efun 则会跳 runtime error
7F:→ laechan : 意思就是这种还是少用122.117.106.224 06/24 09:23
※ 编辑: typers (1.165.46.138), 06/24/2018 22:57:25
8F:→ m8403051 : 看mudos simul_efun.c,floatp是检查 101.10.96.168 06/25 13:37
9F:推 m8403051 : sp->type所以应该是都是object type 101.10.96.168 06/25 13:41
10F:推 m8403051 : 说错, 是 efuns_main.c 101.10.96.168 06/25 13:47
11F:推 neca : 学习了 210.68.129.8 06/25 17:24
12F:→ smmoon : 原来还有人在研究lpc啊 真怀念 114.32.144.77 06/26 10:39
13F:推 neca : 老兵不死 只是凋零 210.68.129.8 06/26 15:52
补充说明:
更正会出现 runtime error 的 code 如下
ob->set_temp("pi", pi);
i = ob->query_temp("pi");
而 int i = pi; 并不会发生错误, 但结果依然 Orz
i = (int) pi; // i = 3.1400, 型态 float
i = pi; // i = 3, 型态 int
提示要转型的没有转型, 没提示的却转型了.........
※ 编辑: typers (36.233.6.251), 06/26/2018 17:05:23
14F:推 PiGFAcE : 果然是大大 198.101.95.98 06/30 13:58