依旧是学习北京大学老师的视频,边学边记录啦~~
版权归视频所有,我在这里做一个记录,方便以后查看~~
1,Windows+R:打开命令行
如果输入命令:
notepad a.txt
如果这个文件在当前路径下存在,会直接打开,否则会提示是否创建该文件
2,copy 1.txt 2.txt
将1.txt拷贝到2.txt
3,为了获取命令行参数,需要改进main函数的形式
int main(int argc,char* argv[])
- argc:启动程序时,命令行参数的个数,至少为1,因为可执行程序本身的文件名也算是一个参数,如notepad
- argv:指针数组,每一个指向一个字符串,字符串里面存放着命令行参数
位运算:
&:按位“与”
作用:某些位清零同时保留其他位不变;获取某变量中的某一位
(&=)
|:按位或
作用:将变量中的某些位置1而其他位不变
(|=)
^:按位异或
不相同是1,相同为0
作用:将变量中某些位取反,保留其他位不变
特点:
如果a^b=c,那么
c^b=a,c^a=b
上特点可用于加密
异或还能实现不用临时变量就交换两个变量的值
int a = 5,b = 7;
a = a ^ b;
b = b ^ a;
a = a ^ b;
~:按位非
<< 左移运算符
a << b
a各个二进制位向左移b位,高位丢弃,低位补零,a值不因运算而改变
相当于乘以2的n次幂
”>>“ 右移运算符
移出最右边的位就被丢弃,a值不因为位运算而改变
对有符号数,右移符号位一起移动,补位与原符号位相同
相当于除以2的幂,往下取整
视频思考题:
/*int a,
n为0到31,求a的第n位
从右到左,从第0位到第31位*/
#include<iostream>
using namespace std;
int main()
{
int a = 5, n = 2;
a >>= n;//最右边的是第0位
a &= 0x1;
cout << a;
return 0;
}
//n不取31时的另一种解法:
//(a & (1 << n)) >> n
//因为若是取第31位时候用这个,
//&运算之后的第31位如果是1
//右移的时候高位补零,
//得出的结果就不正确了
学位运算,感觉回到了大一,欠的债,总是要还的,我还就打算一天天还上了,不要再欠债!