一、C++中的布爾類型
(1)特點
①C++在C語言的基本類型基本系統之上增加了bool
②C++中的bool可取的值只有true和false
③理論上bool只占一個字節
(2)注意
①bool類型只有true(非0)和false(0)兩個值
②C++編譯器會將非0值轉化為true,0值轉換為false
(3)實例分析
#include <stdio.h>
#include <iostream>
int main(int argc, char *argv[])
{
bool b = false;
int a = b;
printf("sizeof(b) = %d\n", sizeof(b)); //輸出:1 布爾類型為1個字節
printf("b = %d, a = %d\n", b, a);//0 0
b = 3;
a = b;
printf("b = %d, a = %d\n", b, a);//1 1
b = -5;
a = b;
printf("b = %d, a = %d\n", b, a);//1 1
a = 10;
b = a;
printf("a = %d, b = %d\n", a, b);// 10 1
a = 0;
b = a;
printf("a = %d, b = %d\n", a, b);//0 0
system("pause");
return 0;
}
編譯器的輸出:
二、C++中的引用
(1)概念:引用可以看作一個已定義變量的別名
(2)引用的語法:Type& name = var;
example :
int a = 4;
int & b = a; //b 為a的別名
b = 5; //操作b就是操作a
(3)實例分析
#include <stdio.h>
#include <iostream>
int main(int argc, char *argv[])
{
int a = 4;
int& b = a;
b = 5;
printf("a = %d\n", a);
printf("b = %d\n", b);
printf("&a = %p\n", &a);
printf("&b = %p\n", &b);
system("pause");
return 0;
}
輸出結果:
可見a和b輸出的值和地址都是一樣的。
參考資料:
https://item.taobao.com/item.htm?spm=a1z10.3-c.w4002-16326486319.21.2620ebfcFFOSQa&id=559166901112