[簡介]
常用網名: 豬頭三
出生日期: 1981.XX.XX
個人網站: https://www.x86asm.org
QQ交流: 643439947
編程生涯: 2001年~至今[共18年]
職業生涯: 16年
開發語言: C/C++、80x86ASM、PHP、Perl、Objective-C、Object Pascal、C#、Python、JavaScript
開發工具: Visual Studio、Delphi、XCode、Eclipse、Android Stuido
技能種類: 逆向 驅動 磁盤 文件
研發領域: Windows應用軟件安全/Windows系統內核安全/Windows系統磁盤數據安全
項目經歷: 磁盤性能優化/文件系統數據恢復/文件信息採集/敏感文件監測跟蹤/網絡安全檢測
[序言]
很長一段時間不用C++了, 最近的項目又重新使用這個語言來開發, 以前做字符串拆分都是用C語言的, 這次使用C++來拆分.
[讀取目標文件, 然後按行拆分]
某個目標文件存儲多行字符串, 每個字符串固定格式爲: A:B,C,D 然後使用如下代碼進行拆分
#include <sstream>
#include <iostream>
#include <fstream>
#include <vector>
int main(int argc, const char * argv[]) {
std::wifstream if_Open("/Users/PigHeadThree/Desktop/test.txt");
if (if_Open.is_open()) {
int int_Index;
wchar_t wchar_SP;
std::wstring wstr_Item, wstr_Item_1, wstr_Item_2, wstr_Item_3, wstr_Item_4;
// 第一部分拆分':' (注意: 這裏可以優化使用std::getline的方式進行一次拆分也行)
while (if_Open >> int_Index >> wchar_SP >> wstr_Item && (wchar_SP == L':')) {
// 第二部拆分','
std::wstringstream wstr_ls(wstr_Item);
// 方法1:
/*
if (std::getline(wstr_ls, wstr_Item_1, L',') &&
std::getline(wstr_ls, wstr_Item_2, L',') &&
std::getline(wstr_ls, wstr_Item_3, L',') &&
std::getline(wstr_ls, wstr_Item_4, L',')) {
std::wcout << int_Index << wstr_Item_1 << wstr_Item_2 << wstr_Item_3 << wstr_Item_4 << std::endl;
}
*/
// 方法2:
std::wstring wstr_Token;
std::vector<std::wstring> vector_Token;
while (std::getline(wstr_ls, wstr_Token, L',')) {
vector_Token.push_back(wstr_Token);
}
std::wcout << int_Index << vector_Token[0] << vector_Token[1] << vector_Token[2] << vector_Token[3] << std::endl;
}
}
if_Open.close();
}
[結尾]
臨時記錄一下而已, 沒有太高深技術.