iomanip

iomanip

iomanip,在C++程式裡面經常見到下面的頭檔案#include <iomanip>,io代表輸入輸出,manip是manipulator(操縱器)的縮寫(在c++上只能通過輸入縮寫才有效)。

基本介紹

  • 外文名:iomanip
  • 含義:C++程式中的頭檔案
  • 開頭:#include <iomanip>
  • 性質:操縱運運算元
作用
主要是對cin,cout之類的一些操縱運運算元,比如setfill,setw,setbase,setprecision等等。它是I/O流控制頭檔案,就像C裡面的格式化輸出一樣.以下是一些常見的控制函式的:
dec 置基數為10 相當於"%d"
hex 置基數為16 相當於"%X"
oct 置基數為8 相當於"%o"
setfill( 'c' ) 設填充字元為c
setprecision( n ) 設顯示有效數字為n位
setw( n ) 設域寬為n個字元
這個控制符的意思是保證輸出寬度為n。如:
cout << setw( 3 ) << 1 << setw( 3 ) << 10 << setw( 3 ) << 100 << endl; 輸出結果為
_ _1_10100 (默認是右對齊)當輸出長度大於3時(<<1000),setw(3)不起作用。
▲setw(n)用法: 通俗地講就是預設寬度
如 cout<<setw(5)<<255<<endl;
結果是:
(空格)(空格)255
▲setfill(char c) 用法 : 就是在預設寬度中如果已存在沒用完的寬度大小,則用設定的字元c填充
如 cout<<setfill(‘@‘)<<setw(5)<<255<<endl;
結果是:
@@255
應當指出,setw只作用於緊隨其後的部分,例如
cout<<setfill('*')<<setw(6)<<123<<456;的運行結果為***123456,這裡setfill('*')<<setw(6)只對 123 起作用輸出了***123,456作為另一部分隨後輸出。
▲setbase(int n) : 將數字轉換為 n 進制.
如 cout<<setbase(8)<<setw(5)<<255<<endl;
cout<<setbase(10)<<setw(5)<<255<<endl;
cout<<setbase(16)<<setw(5)<<255<<endl;
結果是:
(空格)(空格)377
(空格)(空格) 255
(空格)(空格)(空格) f f
▲ setprecision(long f)方法的用法
使用setprecision(n)可控制輸出流顯示浮點數的數字個數。C++默認的流輸出數值有效位是6。
如果setprecision(n)與setiosflags(ios::fixed)合用,可以控制小數點右邊的數字個數。setiosflags(ios::fixed)是用定點方式表示實數。
如果與setiosflags(ios::scientific)合用, 可以控制指數表示法的小數位數。setiosflags(ios::scientific)是用指數方式表示實數。
setiosflags(ios::fixed) 固定的浮點顯示
setiosflags(ios::scientific) 指數表示
setiosflags(ios::left) 左對齊
setiosflags(ios::right) 右對齊
setiosflags(ios::skipws) 忽略前導空白
setiosflags(ios::uppercase) 16進制數大寫輸出
setiosflags(ios::lowercase) 16進制小寫輸出 //VS2010中該方法已不使用,意外使用顯示沒有該成員錯誤。
setiosflags(ios::showpoint) 強制顯示小數點
setiosflags(ios::showpos) 強制顯示符號
▲ resetflags(long f)方法的用法
該方法是setiosflags方法的反向方法,即清除之前語句中所使用的setiosflags設定的格式,恢復為默認格式。
舉例:
//此程式輸出通過Microsoft Visual C++ 2017運行得出。// iomanip.cpp : 此檔案包含 "main" 函式。程式執行將在此處開始並結束。#include "pch.h"#include <iostream>#include<iomanip>using namespace std;int main(){    cout << 12345.0 << endl;//輸出"12345"    cout << setiosflags(ios::fixed) << setprecision(3) << 1.2345 << endl;//輸出"1.234"(遵循四捨六入五成雙的原則,而不是四捨五入的原則)    cout << resetiosflags(ios::fixed);//需要用resetiosflags()函式清除前面的輸出格式    cout << setiosflags(ios::scientific) << 12345.0 << endl;//輸出"1.235e+04"    cout << resetiosflags(ios::scientific);//需要用resetiosflags()函式清除前面的輸出格式    cout << setiosflags(ios::fixed) << setprecision(3) << 12345.0 << endl;//輸出"12345.000"    return 0;}// 運行程式: Ctrl + F5 或調試 >“開始執行(不調試)”選單// 調試程式: F5 或調試 >“開始調試”選單// 入門提示: //   1. 使用解決方案資源管理器視窗添加/管理檔案//   2. 使用團隊資源管理器視窗連線到原始碼管理//   3. 使用輸出視窗查看生成輸出和其他訊息//   4. 使用錯誤列表視窗查看錯誤//   5. 轉到“項目”>“添加新項”以創建新的代碼檔案,或轉到“項目”>“添加現有項”以將現有代碼檔案添加到項目//   6. 將來,若要再次打開此項目,請轉到“檔案”>“打開”>“項目”並選擇 .sln 檔案輸出分別為:123451.2341.235e+0412345.000

相關詞條

熱門詞條

聯絡我們