您的位置:首页 > 编程语言 > C语言/C++

C/C++ 算术移位&&逻辑移位 int && long long间的转化

2017-07-23 17:06 447 查看
int弱类型转化为long long强类型,int输出的值是多少,long long就为多少,即使int是通过运算溢出的数据。对于long long来说,我有足够的位。若int num = 1 << 31; -2147483648。long long a = num; 则a也为-2147483648,高位按位补。

那么int强制转化为long long呢?原理很简单,直接截取掉long long的高32位。如: long long a = 0xffffffff; 8个f. int a = num; 那么 a = -1;

还有就是,默认小于(1<<31)の整数都是int型的,若想要long long型的,在数子后加LL。如1LL。然后 1LL << 31赋给long long就不是负值了。


写程序关于位操作,结果出现了我不理解的错误

下面转自:皓皓松

最近下了个牛客APP,在上面做了几道题。

在做题的过程中呢。我发现了一道比较有意思的题目

老规矩,直接上代码

[cpp] view
plain copy

 print?

int main()  

{  

    int a = 1;  

    int b = 32;  

    printf("%d %d\n", a << b, 1 << 32);  

    return 0;  

}  

乍一看,咦,结果一定输出的是 两个相同的数字 

如果你说是,那么,恭喜你,你看我的这篇文章是有意义的


 

让我们看一下结果(VS2013环境)



你可能会有疑问,这不都是将数字1进行左移32位吗?为什么结果不一样

根据结果我们先推测一下:

(1)1<<32,这两个数字都是常量,所以结果会是0;

(2)a<<b,这是两个变量,结果是1;

再联想一下算术移位和逻辑移位的区别(注:逻辑移位补的是0,算术移位补的是符号位)

让我们进行验证

第一步,注意,一定要做,文件一定是Cpp文件

[cpp] view
plain copy

 print?

int main()  

{  

    const int a = 1;  

    const int b = 32;  

  

    printf("%d", a << b);  

    return 0;  

}  

在a和b的前面分别加上const修饰符

结果:


C++语法规定 const修饰的就是一个常量

第二步,将cpp文件修改成c文件

结果:


 

小结:

(1)算术移位和逻辑移位是有区别的,算术移位会补上 符号位 ,逻辑移位只是补0

(2)const在C和C++下的含义是不一样的,在C语言只是表示一个具有常量性质的变量,而C++中就表示的是常量

如果还对const有疑问的小伙伴可以戳下面的链接


一、const是什么?

const是一个C语言的关键字,它限定一个变量不允许被改变。使用const在一定程度上可以提高程序的安全性和可靠性。


二、const在C和C++下的不同之处

比如一句  const int a = 0;

在C编译器下解释为: a并不是一个常量,只是一个变量具有了常属性。

在C++编译器下解释为: a就是一个常量


(1)验证方法:

[cpp] view
plain copy

 print?

#include<stdio.h>  

#include<stdlib.h>  

int main()  

{  

    const int a = 1;  

    int str[a];//由于数组括号里只能写常量 ,可以根据编译器是否允许成功来判断  是否是常量   

    system("pause");  

    return 0;  

}  

在C编译器下,报错:“应输入常量表达式”

C++编译器通过


(2)通过指针修改const的值

[cpp] view
plain copy

 print?

<span style="font-size:14px;">#include<stdio.h>  

#include<stdlib.h>  

int main()  

{  

    const int a = 1;  

    int *p = (int *)&a;//由于a是整形,我们需要强制类型转换成指针类型的整型  

    *p = 6666;//修改为6666  

    printf("%d",a);  

    system("pause");  

    return 0;  

}</span>  

C编译器下输出6666

C++编译器输出1,是因为将其放在了寄存器的原因,其实内存里已经修改了

在const前面加一个 关键字volatilec语言32个关键字之一),用于保持内存可行性。每次读取都从内存读取,而不是寄存器
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: