好奇怪的问题~

我们知道,在C、C++中进行不同类型的的数据运算时,编译器首先要进行隐式转换。比如(请看下图):

int b=-1;
unsigned int c=b;

 执行结果:

我的问题就在这里,

1.一个负数转换为无符号整数(-1——>3435973836),怎么会变得这么大???底层是如何进行转换的呢?

2.另外:65536*65536为什么就是没有结果?一开始以为是位数太多计算机处理不了,但是我又在之前的基础上加了2位数,居然可以!(请看下图,注释部分为lz在测试long long的精度,可以达到20位!)你tm在逗我?

lz计算机基础不太好,还请各位大神赐教!不胜感激!~

转载于:https://www.cnblogs.com/markwave/p/3590241.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值