## 一.布爾值格式化
| 操縱符 | 作用范圍 | 含義 |
| ------- | ---------------------- | ---------------------- |
| `boolalpha` |后續所有流操作| 布爾值輸出為 `true/false` 而不是 `1/0` |
| `noboolalpha` (默認格式) |后續所有流操作| 布爾值輸出為 `1/0` 而不是 `true/false` |
## 二.整型格式化
1. 修改整型進制
| 操縱符 | 作用范圍 | 含義 |
| ------- | ---------------------- | ---------------------- |
| `dec` (默認格式) |后續所有流操作| 整型數據按照十進制輸出,其余數據不影響 |
| `oct` |后續所有流操作| 整型數據按照八進制輸出,其余數據不影響 |
| `hex` |后續所有流操作| 整型數據按照十六進制輸出,其余數據不影響 |
| 函數 | 作用范圍 | 含義 |
| ------- | ---------------------- | ---------------------- |
| `ostream &setbase(int)` | 后續所有流操作 | 修改進制 |
2. 修改整型前導符輸出顯示
+ 前導 `0` 表示八進制
+ 前導 `0x` 表示十六進制
+ 無前導符表示十進制
| 操縱符 | 作用范圍 | 含義 |
| ------- | ---------------------- | ---------------------- |
| `showbase` |后續所有流操作| 整數輸出前導符 |
| `noshowbase` (默認格式) |后續所有流操作| 整數不輸出前導符 |
| `uppercase` |后續所有流操作| 十六進制數據大寫 |
| `nouppercase` (默認格式) |后續所有流操作| 十六進制數據小寫 |
## 三.浮點型格式化
1. 獲取/設置精度
| 函數 |作用范圍 | 含義 |
| ------- | ---------------------- | ---------------------- |
| `int obj.precision()` |后續所有流操作| 返回當前的精度值 |
| `void obj.precision(int)` |后續所有流操作| 設置當前的精度值 |
| `ostream &setprecision(int)` |后續所有流操作| 設置當前的精度值 |
2. 小數點的顯示
| 操縱符 | 作用范圍 | 含義 |
| ------- | ---------------------- | ---------------------- |
| `showpoint` |后續所有流操作| 浮點數沒有小數部分,仍然輸出小數點 |
| `noshowpoint` (默認格式) |后續所有流操作| 浮點數沒有小數部分,不輸出小數點 |
3. 浮點數計數法
| 操縱符 | 作用范圍 | 含義 |
| ------- | ---------------------- | ---------------------- |
| `fixed` (默認格式) |后續所有流操作| 浮點數按照小數點的格式輸出 |
| `scientific` |后續所有流操作| 浮點數按照科學計數法的格式輸出 |
| `uppercase` |后續所有流操作| 浮點數按照科學計數法的格式輸出時,`e`大寫 |
| `nouppercase` (默認格式) |后續所有流操作| 浮點數按照科學計數法的格式輸出時,`e`小寫 |
| [11+]`hexfloat` |后續所有流操作| 浮點數按照十六進制輸出 |
| [11+]`defaultfloat` (默認格式) |后續所有流操作| 浮點數按照十進制輸出 |
## 四.對齊
1. 設置輸入寬度
| 函數 | 作用范圍 | 含義 |
| ------- | ---------------------- | ---------------------- |
| `ostream &setw(int)` | **僅下一個數字或字符串** | 設置數字和字符串輸出的最小空間,默認為 `0` |
| `obj.width(int)` | 后續所有流操作 | 設置數字和字符串輸出的最小空間,默認為 `0` |
2. 對齊
| 操縱符 | 作用范圍 | 含義 |
| ------- | ---------------------- | ---------------------- |
| `left` |后續所有流操作| 左對齊 |
| `right` (默認格式) |后續所有流操作| 右對齊 |
| `internal` |后續所有流操作| 對于數字,符號在左邊,數字在右邊,中間默認用空格填充 |
3. 填充
| 函數 | 作用范圍 | 含義 |
| ------- | ---------------------- | ---------------------- |
| `ostream &setfill(char)` | 后續所有流操作 | 用指定字符代替空格進行填充 |
| `obj.fill(char)` | 后續所有流操作 | 用指定字符代替空格進行填充 |
## 五.讀取空白格
| 操縱符 | 作用范圍 | 含義 |
| ------- | ---------------------- | ---------------------- |
| `noskipws` |后續所有流操作| 輸入時,將空白格讀入變量,而不是跳過他們 |
| `skipws` (默認格式) |后續所有流操作| 輸入時,跳過空白格 |
## 六.緩沖區操作
1. 刷新緩沖區
| 操縱符 |作用范圍 | 含義 |
| ------- | ---------------------- |---------------------- |
| `endl` |一次性操作| 輸出換行,并刷新緩沖區 |
| `flush` |一次性操作| 刷新緩沖區 |
| `ends` |一次性操作| 輸出空格,并刷新緩沖區 |
2. 修改緩沖設置
| 操縱符 |作用范圍 | 含義 |
| ----------- | -------------------------------- | -------------------------------- |
| `unitbuf` |后續所有流操作| 所有輸出操作后都會立即刷新緩沖區 |
| `nounitbuf` |后續所有流操作| 回到正常的緩沖方式 |
## 七.流關聯
使用流對象的 `tie` 函數將另一個流的地址與其關聯。
```c++
cin.tie(NULL);//取消綁定流
cin.tie(&cout);//綁定輸出流
```
## 八.格式管理
1. 批量設置格式
| 函數 | 作用范圍 | 含義 |
| ------- | ---------------------- | ---------------------- |
| `ostream &setiosflags(flags)` | 后續所有流操作 | 設置格式,上面的格式需要加上 `ios::` 作用域,多個格式中間用 `|` 隔開 |
| `obj.setf(flags)` | 后續所有流操作 | 設置格式,上面的格式需要加上 `ios::` 作用域,多個格式中間用 `|` 隔開 |
2. 批量清除格式
| 函數 | 作用范圍 | 含義 |
| ------- | ---------------------- | ---------------------- |
| `ostream &resetiosflags(flags)` | 后續所有流操作 | 清除格式,格式需要加上 `ios::` 作用域,多個格式中間用 `|` 隔開 |
| `obj.usetf(flags)` | 后續所有流操作 | 反設置格式,格式需要加上 `ios::` 作用域,多個格式中間用 `|` 隔開 |
額外的可批量清理的格式:
| 操縱符(已加上 `ios::` 作用域) |作用范圍 | 含義 |
| ----------- | -------------------------------- | -------------------------------- |
| `ios::basefield` |后續所有流操作| 整數進制,包含 `dec` `oct` `hex` |
| `ios::adjustfield` |后續所有流操作| 對齊方式,包含`left` `right` `internal` |
| `ios::floatfield` |后續所有流操作| 浮點輸出方式,包含`fixed` `scientific` |
- 閱讀說明
- 1.1 概述
- C++基礎
- 1.2 變量與常量
- 1.2.1 變量
- 1.2.2 字面值常量
- 字符型常量
- 數值型常量
- 1.2.3 cv限定符
- 1.3 作用域
- 1.3.1 標識符
- 1.3.2 *命名空間
- 1.3.3 作用域
- 1.3.4 可見性
- 1.4 數據類型
- 1.4.1 概述
- 1.4.2 處理類型
- 類型別名
- * auto說明符
- * decltype說明符
- 1.4.3 數組
- 1.4.4 指針
- 1.4.5 引用
- 1.5 表達式
- 1.5.1 概述
- 1.5.2 值的類別
- 1.5.3 *初始化
- 1.5.4 運算符
- 算術運算符
- 邏輯和關系運算符
- 賦值運算符
- 遞增遞減運算符
- 成員訪問運算符
- 位運算符
- 其他運算符
- 1.5.5 *常量表達式
- 1.5.6 類型轉換
- 第2章 面向過程編程
- 2.1 流程語句
- 2.1.1 條件語句
- 2.1.2 循環語句
- 2.1.3 跳轉語句
- 2.1.4 *異常處理
- 2.2 函數
- 2.2.1 概述
- 2.2.2 函數參數
- 2.2.3 內置函數
- 2.2.4 函數重載
- 2.2.5 * 匿名函數
- 2.3 存儲和生命期
- 2.3.1 生命周期與存儲區域
- 2.3.2 動態內存
- 2.4 *預處理命令
- 第3章 面向對象編程
- 3.1 概述
- 3.2 類和對象
- 3.3 成員
- 3.3.1 訪問限制
- 3.3.2 常成員
- 3.3.3 靜態成員
- 3.3.4 成員指針
- 3.3.5 this指針
- 3.4 特殊的成員函數
- 3.4.1 概述
- 3.4.2 構造函數
- 3.4.3 析構函數
- 3.4.4 拷貝語義
- 3.4.5 * 移動語義
- 3.5 友元
- 3.6 運算符重載與類型轉換
- 3.6.1 概述
- 3.6.2 重載方法
- 3.6.3 類型轉換
- 3.7 繼承與多態性
- 3.7.1 概述
- 3.7.2 派生類
- 3.7.3 子類型
- 3.7.4 虛基類
- 3.7.5 虛函數
- 3.7.6 抽象類
- 3.8 模板與泛型
- 3.8.1 概述
- 3.8.2 模板類型
- 3.8.3 *模板參數
- 3.8.4 *模板編譯
- 3.8.5 *模板推斷
- 3.8.6 *實例化與特例化
- 第4章 C++標準庫
- 4.1 概述
- 4.2 輸入輸出流
- 4.2.1 概述
- 4.2.2 *流的狀態
- 4.2.3 *常用流
- 4.2.4 *格式化I/O
- 4.2.5 *低級I/O
- 4.2.6 *隨機訪問
- 4.3 *C輸入輸出
- 4.3.1 *字符輸入輸出
- 4.3.2 *格式化輸入輸出
- 4.4 * 容器
- 4.4.1 * 概述
- 4.4.2 * 基本操作
- 4.4.3 * 順序容器
- 4.4.4 * 迭代器
- 4.4.5 * 容器適配器
- 4.5 * 泛型算法
- 4.6 * 內存管理
- 4.6.1 * 自動指針
- 4.7 * 其他設施