【C++ Primer | 08】IO庫

一、istringstream類

描述:從流中提取數據,支持?>>?操作

這里字符串可以包括多個單詞,單詞之間使用空格分開

#include <iostream>   
#include <sstream>   
using namespace std;
int main()
{istringstream istr("1 56.7");cout << istr.str() << endl;//直接輸出字符串的數據 "1 56.7"   string str = istr.str();//函數str()返回一個字符串   cout << str << endl;int n;double d;//以空格為界,把istringstream中數據取出,應進行類型轉換   istr >> n;//第一個數為整型數據,輸出1   istr >> d;//第二個數位浮點數,輸出56.7  cout << n << endl;cout << d << endl;d = 0;n = 0;  istr >> d;//istringstream第一個數要自動變成浮點型,輸出仍為1   istr >> n;//istringstream第二個數要自動變成整型,有數字的階段,輸出為56      cout << d << endl;cout << n << endl;return 1;
}

輸出結果:?

?

?

二、ostringstream類

描述:把其他類型的數據寫入流(往流中寫入數據),支持 << 操作

#include <sstream>
#include <string>
#include <iostream>
using namespace std;int main()
{ostringstream ostr1;ostringstream ostr2("abc");ostr1 << "ostr1" << 2012 << endl;    // 格式化,此處endl也將格式化進ostr1中cout << ostr1.str();long curPos = ostr2.tellp(); //返回當前插入的索引位置(即put pointer的值),從0開始 cout << "curPos = " << curPos << endl;ostr2.seekp(2);    // 手動設置put pointer的值ostr2.put('g');    // 在put pointer的位置上寫入'g',并將put pointer指向下一個字符位置cout << ostr2.str() << endl;/*----------------------------------------------------------------------------重復使用同一個ostringstream對象時,建議:1:調用clear()清除當前錯誤控制狀態,其原型為 void clear (iostate state=goodbit);2:調用str("")將緩沖區清零,清除臟數據----------------------------------------------------------------------------*/ostr2.clear();ostr2.str("");cout << ostr2.str() << endl;ostr2.str("_def");cout << ostr2.str() << endl;ostr2 << "gggghh";    // 覆蓋原有的數據,并自動增加緩沖區cout << ostr2.str() << endl;
}

輸出結果:

相關練習:

1.?151. 翻轉字符串里的單詞

參考資料

1.?istringstream、ostringstream、stringstream 類介紹

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/385368.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/385368.shtml
英文地址,請注明出處:http://en.pswp.cn/news/385368.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

gdb調試(如何跟蹤指定進程)

使用gdb調試的時候&#xff0c;gdb只能跟蹤一個進程。可以在fork函數調用之前&#xff0c;通過指令設置gdb調試工具跟蹤父進程或者是跟蹤子進程。默認跟蹤父進程。 set follow-fork-mode child 命令設置gdb在fork之后跟蹤子進程。 set follow-fork-mode parent 設置跟蹤父進程…

【Leetcode | 01】Backtracking

回溯算法序號題號117. 電話號碼的字母組合222. 括號生成 39. 組合總和 40. 組合總和 II 46. 全排列 47. 全排列 II 60. 第k個排列 77. 組合 78. 子集 90. 子集 II 93. 復原IP地址 131. 分割回文串 216. 組合總和 III 306. 累加數 357. 計算各個位數不同的數字個數 401. 二進…

1033. 舊鍵盤打字(20)

舊鍵盤上壞了幾個鍵&#xff0c;于是在敲一段文字的時候&#xff0c;對應的字符就不會出現。現在給出應該輸入的一段文字、以及壞掉的那些鍵&#xff0c;打出的結果文字會是怎樣&#xff1f; 輸入格式&#xff1a; 輸入在2行中分別給出壞掉的那些鍵、以及應該輸入的文字。其中對…

1038. 統計同成績學生(20)

本題要求讀入N名學生的成績&#xff0c;將獲得某一給定分數的學生人數輸出。 輸入格式&#xff1a; 輸入在第1行給出不超過105的正整數N&#xff0c;即學生總人數。隨后1行給出N名學生的百分制整數成績&#xff0c;中間以空格分隔。最后1行給出要查詢的分數個數K&#xff08;不…

EXEC函數族的一般規律

事實上&#xff0c;只有execve是真正的系統調用&#xff0c;其它五個函數最終都調用execve&#xff0c;所以execve在man手冊第2節&#xff0c;其它函數在man手冊第3節。這些函數之間的關系如下圖所示。

exit與_exit函fork與vfork函數

#include <stdlib.h> void exit(int status); #include <unistd.h> void _exit(int status); exit函數與_exit函數一樣&#xff0c;都是系統函數&#xff0c;且都是用來終止一個進程的&#xff0c;無論在程序中的什么位置&#xff0c;只要執行這exit或_exit系統…

1042. 字符統計(20)

請編寫程序&#xff0c;找出一段給定文字中出現最頻繁的那個英文字母。 輸入格式&#xff1a; 輸入在一行中給出一個長度不超過1000的字符串。字符串由ASCII碼表中任意可見字符及空格組成&#xff0c;至少包含1個英文字母&#xff0c;以回車結束&#xff08;回車不算在內&#…

孤兒進程與僵尸進程

孤兒進程&#xff1a;父進程先于子進程結束&#xff08;遇到return、exit、異常終止等情況時&#xff09;&#xff0c;則子進程成為孤兒進程&#xff0c;子進程的父進程成為init進程&#xff0c;稱為init進程領養孤兒進程。可以通過getppid函數來查看孤兒進程的父進程ID&#x…

1043. 輸出PATest(20)

給定一個長度不超過10000的、僅由英文字母構成的字符串。請將字符重新調整順序&#xff0c;按“PATestPATest....”這樣的順序輸出&#xff0c;并忽略其它字符。當然&#xff0c;六種字符的個數不一定是一樣多的&#xff0c;若某種字符已經輸出完&#xff0c;則余下的字符仍按P…

wait函數

#include <sys/types.h> #include <sys/wait.h> pid_t wait(int *status); 僵尸進程。進程結束后放棄了幾乎所有的內存空間&#xff0c;沒有任何可以執行的代碼&#xff0c;也不能被調度&#xff0c;僅僅在進程列表中保留著一個位置&#xff0c;記載著該進程的退出…

map與unordered_map

時間復雜度&#xff1a; mapunordered_mapOrderingincreasing orderno orderImplementationSelf balancing BSTHash Tablesearch timelog(n) O(1&#xff09;: 平均水ping O(n&#xff09;&#xff1a;最糟糕情況 Insertion timelog(n) RebalanceSame sa searchDelete timelo…

waitpid函數

#include <sys/wait.h> #include <sys/types.h> pid_t waitpid(pid_t pid, int *status, int options); 作用&#xff1a;同wait&#xff0c;但可指定pid進程清理&#xff0c;可以不阻塞。 waitpid函數的第二個參數int *status跟wait函數的形參一樣&#xff0c;…

進程間通信的方法

Linux環境下&#xff0c;進程地址空間相互獨立&#xff0c;每個進程各自有不同的用戶地址空間。任何一個進程的全局變量在另一個進程中都看不到&#xff0c;所以進程和進程之間不能相互訪問&#xff0c;要交換數據必須通過內核&#xff0c;在內核中開辟一塊緩沖區&#xff0c;進…

管道的概念(匿名管道)

管道是一種最基本的IPC機制&#xff0c;作用于有血緣關系的進程之間&#xff0c;完成數據傳遞。調用pipe系統函數即可創建一個管道。管道有如下特質&#xff1a;1.其本質是一個偽文件&#xff08;實為內核緩沖區&#xff09;&#xff0c;偽文件即不是真正的文件&#xff0c;不占…

1023. 組個最小數 (20)

給定數字0-9各若干個。你可以以任意順序排列這些數字&#xff0c;但必須全部使用。目標是使得最后得到的數盡可能小&#xff08;注意0不能做首位&#xff09;。例如&#xff1a;給定兩個0&#xff0c;兩個1&#xff0c;三個5&#xff0c;一個8&#xff0c;我們得到的最小的數就…

pipe函數

#include <unistd.h> int pipe(int pipefd[2]); 作用&#xff1a;創建管道 成功&#xff1a;0&#xff1b;失敗&#xff1a;-1&#xff0c;設置errno 函數調用成功返回r/w兩個文件描述符。無需open&#xff0c;但需手動close。規定&#xff1a;fd[0] …

二分查找總結

二分查找法作為一種常見的查找方法&#xff0c;將原本是線性時間提升到了對數時間范圍&#xff0c;大大縮短了搜索時間&#xff0c;具有很大的應用場景&#xff0c;而在LeetCode中&#xff0c;要運用二分搜索法來解的題目也有很多&#xff0c;但是實際上二分查找法的查找目標有…

管道的讀寫行為

使用管道需要注意以下4種特殊情況&#xff08;默認都是阻塞I/O操作&#xff0c;沒有設置O_NONBLOCK標志&#xff09;&#xff1a; 1. 如果所有指向管道寫端的文件描述符都關閉了&#xff08;管道寫端引用計數為0&#xff09;&#xff0c;而仍然有進程從管道的讀端讀數據&#…

【C++ Primer | 08】課后習題答案

文章目錄練習8.13練習8.13 include <iostream> #include <sstream> #include <fstream> #include <string> #include <vector> using namespace std;struct PersonInfo {string name;vector<string> phones; };bool valid(const string&…

管道緩沖區大小

可以使用ulimit –a 命令來查看當前系統中創建管道文件所對應的內核緩沖區大小。通常為&#xff1a;pipe size 4K&#xff0c;即一個頁面大小。也可以使用fpathconf函數來查看&#xff1a; #include <unistd.h> long fpathconf(int fd, int name); 當需要查看管道的大…