CPL学习笔记(一)
整型
计算机的内存的基本单位是位(bit),可以将其看作电子开关,可以开,表示1;也可以关表示0。
字节(byte)通常指八位的内存单元。
8bit=1byte=1B;
1KB=1024B;
1M=1024KB;
1G=1024M;
1T=1024G;
如果在考场上忘记了数据类型的范围或字节数,莫着急,C++的特技<climits>就是为了解决此问题的。
常用函数:N_MAX,N_MIN.(N代表数据类型)
秒懂代码:
#include<iostream>
#include<cstdio>
#include<climits>
using namespace std;
int main()
{
int intmax=INT_MAX;
int intmin=INT_MIN;
long longmax=LONG_MAX;
long longmin=LONG_MIN;
short shortmax=SHRT_MAX;
short shortmin=SHRT_MIN;
long long llongmax=LLONG_MAX;
long long llongmin=LLONG_MIN;
printf("short is %d byte\n",sizeof(short));
printf("int is %d byte\n",sizeof(int));
printf("long is %d byte\n",sizeof(long));
printf("long long is %d byte\n",sizeof(long long));
printf("maximum:\n");
printf("short: %hd\n",shortmax);
printf("int: %d\n",intmax);
printf("long: %ld\n",longmax);
printf("long long: %lld\n",llongmax);
printf("minimum: \n");
printf("short: %hd\n",shortmin);
printf("int: %d\n",intmin);
printf("long: %ld\n",longmin);
printf("long long: %lld\n",llongmin);
return 0;
}
输出结果也是一目了然:
short is 2 byte
int is 4 byte
long is 4 byte
long long is 8 byte
maximum:
short: 32767
int: 2147483647
long: 2147483647
long long: 9223372036854775807
minimum:
short: -32768
int: -2147483648
long: -2147483648
long long: -9223372036854775808
--------------------------------
Process exited after 0.1151 seconds with return value 0
请按任意键继续. . .
该方法适用于所有整型。
值得一提的是,char也是整型的一种,CHAR_MAX=127;
这就提醒我们:char类型的加减法一定要小心,a的ASCLL码为97,也就是说两个值为‘a’的char类型相加就会出错。。。
FOR_EXAMPLE:
cout<<(char)('a'+'a');
我们也许会认为这行代码会输出ASCLL码为194的字符,其实不然,这句代码是错误的,它什么也不会输出。
有一种方法可以不完全的解决这个问题:unsigned char(范围0~255)
数据类型的溢出
int intmax=INT_MAX;
int intmin=INT_MAX;
cout<<intmax<<" "<<intmax+1;
cout<<intmin<<" "<<intmin-1;
return 0;
既然是数据类型的最大值,intmax+1应该不会大于2147483647,同理,intmin-1也应该不会小于-2147483648,不错,就是这样。
2147483647 -2147483648
-2147483648 2147483647
意想不到的是,intmax+1竟然=INT_MIN,这就是上溢现象。这种现象不好解释,但是一张图片就能将其描述清楚。
图片位置:C++ XXXX page 44.[手动滑稽]
整型字面值
C++能用三种不同的计数方式来书写整数,基数为10、基数为8、基数为16.
C++使用前一位或二位来标识数字常量的基数。
case 1:第一位为1~9,基数为10(十进制)。
case 2:第一位为0,第二位为1~7,基数为8(八进制)。
case 3: 前二位为0x或0X,则基数为16(十六进制)。
秒懂代码:
#include<bits/stdc++.h>
using namespace std;
int main()
{
int decn=42;
int octn=042;
int hexn=0x42;
printf("042 八进制转十进制:%d\n",octn);
printf("42 十进制:%d\n",decn);
printf("0x42十六进制转十进制:%d\n",hexn);
return 0;
}
下附输出:
042 八进制转十进制:34
42 十进制:42
0x42十六进制转十进制:66
--------------------------------
Process exited after 0.0688 seconds with return value 0
请按任意键继续. . .
也就是说加上特殊标记后,我们可以直接存储十六/八进制数,但输出时默认转为十进制。如果我们希望直接输出十六/八进制数,该怎么办呢?
方法是有的,十六/八进制可是属于C++的计数方式,after all.于是乎,cout装备了一些C++的特技:
直接贴代码:
int n=15;
cout<<n<<endl;
cout<<oct;
cout<<n<<endl;
cout<<hex;
cout<<n<<endl;
cout<<dec;
cout<<n<<endl;
初学者也许会把oct、dec等当成忘记声明的变量(开始我就是这么认为),其实不然,它们分别代表十进制(dec)、八进制(oct)、十六进制(hex)。cout的默认输出格式为十进制,不难猜测,cout<<oct;就是将其输出格式改为八进制,hex也是同理。
输出:
15
17
f
15
--------------------------------
Process exited after 0.07195 seconds with return value 0
请按任意键继续. . .
n的数值自始至终并未发生改变,只是进制改变了。
C++如何确定常量的类型
举个栗子:
cout<<"Year = "<<1492<<endl;
这里的1492的类型将被存为什么呢?答案是:除非int类型不够大或者常量带有后缀,则存为int类型。
那么这里再介绍一下后缀:
u,表示此常量为unsigned int类型,如:1492u;
ul,表示此常量为unsigned long类型.等同于lu.
ull,表示此常量为unsigned long long类型.
ll,表示此常量为long long int类型.
对于不带后缀的十进制数,采用int,l,ll(按优先级顺序)
而对于不带后缀的十六/八进制数,采用int,u,l,ul,ll,ull.
转义序列
根据个人初步理解,转义序列的意义就是用‘\’加字符或数字表示一些特殊意义。
名称 | C++代码 | ASCII(dec) |
---|---|---|
换行符 | \n | 10 |
水平制表符 | \t | 9 |
垂直制表符 | \v | 11 |
退格 | \b | 8 |
回车 | \r | 13 |
振铃 | \a | 7 |
提示:cout<<'\n'; 与 cout<<'\10'; 是等价的。即ASCII码可用于转义序列的表示。
通用字符名
格式为\u或\U开头,后加4(u)或8(U)位十六进制数。 这与一种叫Unicode的编码有关: https://baike.baidu.com/item/Unicode/750500?fr=aladdin <--------度娘在这里
如:
cout<<"\u4734"<<endl;
cout<<"\U000E34E4";
输出在这里:
錅
螅摛
--------------------------------
Process exited after 0.06648 seconds with return value 0
请按任意键继续. . .
这东西。。。高深!
符号常量——预处理器方式
#define INT_MAX 32777
这行代码我们并不陌生,学名:定义符号常量,#define & #include一样,也是预处理器编译指令。这是C语言遗留下来的定义方法,C++中的const其实已经在很多方面上代替了它。
int a=1; C语言的初始化方式
int a(1); C++的初始化方式
const 限定符
const int n=221024;
然后,n的值就无法进行修改了。
const int n;
n=10;
这是一种经典的错误,n开始被初始化成了一个不确定的值,而后面的n=10,也就无效了。