亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

c++ 實現(xiàn)文件逐行讀取與字符匹配

 更新時間:2021年05月20日 10:32:45   作者:Dechin''s  
這里嘗試通過C++來實現(xiàn)一個文件IO的功能,看看是否能夠比python的表現(xiàn)更好一些,感興趣的朋友可以參考下

C++讀取文件

首先我們構造一個txt文件用于測試,比如以下這個名為mindspore.txt的文件(之所以取這個名字,是因為最近在研究mindspore,因此最方便拿到的數(shù)據(jù)就是mindspore的借口api文檔):

MindSpore Python API
MindSpore Python API
mindspore
mindspore.common.initializer
mindspore.communication
mindspore.compression
mindspore.context
mindspore.dataset
mindspore.dataset.config
mindspore.dataset.text
mindspore.dataset.transforms
mindspore.dataset.vision
mindspore.explainer
mindspore.mindrecord
mindspore.nn
mindspore.numpy
mindspore.nn.probability
mindspore.ops
mindspore.profiler
mindspore.train
MindArmour Python API
mindarmour
mindarmour.adv_robustness.attacks
mindarmour.adv_robustness.defenses
mindarmour.adv_robustness.detectors
mindarmour.adv_robustness.evaluations
mindarmour.fuzz_testing
mindarmour.privacy.diff_privacy
mindarmour.privacy.evaluation
mindarmour.privacy.sup_privacy
mindarmour.utils
MindSpore Hub Python API
mindspore_hub
MindSpore Serving Python API
mindspore_serving
MindQuantum Python API
mindquantum

然后構造一個C++代碼用于逐行讀取這個文件,通過getline函數(shù),將獲取到的行字符串保存到strline中,并且每次讀取一行都在屏幕上輸出出來。由于這里使用的是while循環(huán),因此采用index的方案設置了一個跳出循環(huán)的條件,只讀取特定的行范圍:

// iofile.cpp
#include <iostream>
#include <fstream>
#include <string>

int main()
{
    using namespace std;
    string filename="mindspore.txt";
    ifstream fin(filename.c_str());
    int index = 0;
    string strline;
    while (getline(fin, strline) && index < 20)
    {
        cout << strline << endl;
        index ++;
    }
    fin.close();
    cout << "Done!\n";
    return 0;
}

在讀取完畢后,記得使用close()將文件關閉。上述代碼的執(zhí)行結(jié)果如下:

dechin@ubuntu2004:~/projects/gitlab/dechin/$ g++ iofile.cpp 
dechin@ubuntu2004:~/projects/gitlab/dechin/$ ./a.out
MindSpore Python API
MindSpore Python API
mindspore
mindspore.common.initializer
mindspore.communication
mindspore.compression
mindspore.context
mindspore.dataset
mindspore.dataset.config
mindspore.dataset.text
mindspore.dataset.transforms
mindspore.dataset.vision
mindspore.explainer
mindspore.mindrecord
mindspore.nn
mindspore.numpy
mindspore.nn.probability
mindspore.ops
mindspore.profiler
mindspore.train
Done!

這里我們使用的g++版本為9.3.0:

dechin@ubuntu2004:~/projects/gitlab/dechin/$ g++ --version
g++ (Ubuntu 9.3.0-17ubuntu1~20.04) 9.3.0
Copyright (C) 2019 Free Software Foundation, Inc.
This is free software; see the source for copying conditions.  There is NO
warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.

因為上述案例讀取的是前20行的內(nèi)容,那么在Linux下我們還可以通過head來查看前20行的文件內(nèi)容:

dechin@ubuntu2004:~/projects/gitlab/dechin/$ head -n 20 mindspore.txt 
MindSpore Python API
MindSpore Python API
mindspore
mindspore.common.initializer
mindspore.communication
mindspore.compression
mindspore.context
mindspore.dataset
mindspore.dataset.config
mindspore.dataset.text
mindspore.dataset.transforms
mindspore.dataset.vision
mindspore.explainer
mindspore.mindrecord
mindspore.nn
mindspore.numpy
mindspore.nn.probability
mindspore.ops
mindspore.profiler
mindspore.train

經(jīng)過對比發(fā)現(xiàn)兩個結(jié)果是一致的。

C++字符串匹配

我們假象一個這樣的測試案例,在上述的txt文本中,我們想把帶有字符context的那一行標記出來,使其跟其他的行不一樣。這時候就需要使用到C++的字符串匹配功能,其格式為string.find("context"),返回的是一個識別碼,用于標記是否存在或者是存在的位置,如果字符不存在,則返回結(jié)果等價于string::npos。按照這個思路,我們定義一個布爾值,在檢索過程中如果遇到context字符就輸出1,否則輸出0,具體的代碼實現(xiàn)如下:

// iofile.cpp
#include <iostream>
#include <fstream>
#include <string>

int main()
{
    using namespace std;
    string filename="mindspore.txt";
    ifstream fin(filename.c_str());
    int index = 0;
    string strline;
    while (getline(fin, strline) && index < 20)
    {
        bool exists = strline.find("context") == string::npos;
        cout << strline << '\t' << !exists << endl;
        index ++;
    }
    fin.close();
    cout << "Done!\n";
    return 0;
}

上述代碼的執(zhí)行結(jié)果如下所示:

dechin@ubuntu2004:~/projects/gitlab/dechin/$ g++ iofile.cpp && ./a.out
MindSpore Python API    0
MindSpore Python API    0
mindspore       0
mindspore.common.initializer    0
mindspore.communication 0
mindspore.compression   0
mindspore.context       1
mindspore.dataset       0
mindspore.dataset.config        0
mindspore.dataset.text  0
mindspore.dataset.transforms    0
mindspore.dataset.vision        0
mindspore.explainer     0
mindspore.mindrecord    0
mindspore.nn    0
mindspore.numpy 0
mindspore.nn.probability        0
mindspore.ops   0
mindspore.profiler      0
mindspore.train 0
Done!

我們可以注意到,在含有context的那一行的行末輸出了一個1,其他行的行末輸出的都是0.

C++運行時間統(tǒng)計

在python中我們常用的一個功能是導入time.time()來記錄時間,然后計算兩次時間之間的差值,就可以得到一個程序的精確運行時間。C++中有一個比較類似的用法是clock_t,這里為了方便測試,我們把上述用到的代碼封裝到一個reader函數(shù)內(nèi),然后在main函數(shù)中調(diào)用以及統(tǒng)計運行時間:

// iofile.cpp
#include <iostream>
#include <fstream>
#include <string>
#include <time.h>
using namespace std;
int reader()
{
    string filename="mindspore.txt";
    ifstream fin(filename.c_str());
    int index = 0;
    string strline;
    while (getline(fin, strline) && index < 20)
    {
        bool exists = strline.find("context") == string::npos;
        cout << strline << '\t' << !exists << endl;
        index ++;
    }
    fin.close();
    cout << "Done!\n";
    return 0;
}
int main()
{
    clock_t start, end;
    start = clock();
    reader();
    end = clock();
    cout << "The time cost is: " << double(end-start)/CLOCKS_PER_SEC << "s" << endl;
}

上述代碼的執(zhí)行結(jié)果如下所示:

dechin@ubuntu2004:~/projects/gitlab/dechin/$ g++ iofile.cpp && ./a.out
MindSpore Python API    0
MindSpore Python API    0
mindspore       0
mindspore.common.initializer    0
mindspore.communication 0
mindspore.compression   0
mindspore.context       1
mindspore.dataset       0
mindspore.dataset.config        0
mindspore.dataset.text  0
mindspore.dataset.transforms    0
mindspore.dataset.vision        0
mindspore.explainer     0
mindspore.mindrecord    0
mindspore.nn    0
mindspore.numpy 0
mindspore.nn.probability        0
mindspore.ops   0
mindspore.profiler      0
mindspore.train 0
Done!
The time cost is: 0.000245s

輸出的時間表示這個函數(shù)運行時間共計0.2ms。

總結(jié)概要

本文簡單的介紹了C++中的三種基礎操作:逐行讀取文件內(nèi)容、字符串匹配以及運行時間的統(tǒng)計,并且通過一個簡單的范例來實現(xiàn)了這三種基本的功能。相比于python而言,C++的代碼編寫量肯定要多一些,但是考慮到C++可能帶來的效率增益,我們也應當了解其基本的用法以及功能實現(xiàn)。

以上就是c++ 實現(xiàn)文件逐行讀取與字符匹配的詳細內(nèi)容,更多關于c++ 文件逐行讀取與字符匹配的資料請關注腳本之家其它相關文章!

相關文章

  • C++之函數(shù)的重載

    C++之函數(shù)的重載

    這篇文章主要介紹了c++函數(shù)重載的相關知識,文章講解的非常細致,代碼幫助大家更好的理解和學習,感興趣的朋友可以了解下
    2021-11-11
  • C語言中的操作符優(yōu)先級的詳細介紹

    C語言中的操作符優(yōu)先級的詳細介紹

    這篇文章主要介紹了C語言中的操作符優(yōu)先級的詳細介紹的相關資料,希望通過本文能幫助到大家,大家通過本文能徹底掌握這部分內(nèi)容,需要的朋友可以參考下
    2017-08-08
  • C++實現(xiàn)旋轉(zhuǎn)掃描儀的示例代碼

    C++實現(xiàn)旋轉(zhuǎn)掃描儀的示例代碼

    旋轉(zhuǎn)掃描儀(Rotating?Scanner),也稱為旋轉(zhuǎn)掃描儀或圓形掃描儀,是一種用于獲取圖像和文檔的設備,下面就跟隨小編一起來學習一下如何使用C++實現(xiàn)旋轉(zhuǎn)掃描儀功能吧
    2024-02-02
  • C++中關于getchar()的使用方法

    C++中關于getchar()的使用方法

    這篇文章主要介紹了C++中關于getchar()的使用方法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • 電腦開機時間的計算代碼

    電腦開機時間的計算代碼

    這幾天我琢磨著一件事,那就是怎么計算我的PC從開機到現(xiàn)在的總時間。終于,看看這個函數(shù):GetTickCount();
    2013-05-05
  • 利用Matlab繪制有趣圖像的示例代碼

    利用Matlab繪制有趣圖像的示例代碼

    這篇文章主要為大家總結(jié)了一些利用Matlab繪制的有趣好看的圖像的示例代碼。文中的示例代碼簡潔易懂,感興趣的小伙伴可以動手試一試
    2022-03-03
  • 一篇文章帶你了解C語言二分查找的簡單應用

    一篇文章帶你了解C語言二分查找的簡單應用

    這篇文章主要介紹了二分查找算法在C語言程序中的使用示例,文中最后提到了使用二分查找法一個需要注意的地方,需要的朋友可以參考下
    2021-08-08
  • C語言棧與隊列相互實現(xiàn)詳解

    C語言棧與隊列相互實現(xiàn)詳解

    棧和隊列,嚴格意義上來說,也屬于線性表,因為它們也都用于存儲邏輯關系為 "一對一" 的數(shù)據(jù),但由于它們比較特殊,本章講解分別用隊列實現(xiàn)棧與用棧實現(xiàn)隊列
    2022-04-04
  • C++ 實現(xiàn)L2-002 鏈表去重

    C++ 實現(xiàn)L2-002 鏈表去重

    這篇文章主要介紹了C++ 實現(xiàn)L2-002 鏈表去重,本文通過簡要的案例,解題思路講解了該項技術的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • C++協(xié)程實現(xiàn)序列生成器的案例分享

    C++協(xié)程實現(xiàn)序列生成器的案例分享

    序列生成器通常的實現(xiàn)是在一個協(xié)程內(nèi)部通過某種方式向外部傳一個值出去,并且將自己掛起,本文圍繞序列生成器這個經(jīng)典的協(xié)程案例介紹了協(xié)程的銷毀、co_await 運算符、await_transform 以及 yield_value 的用法,需要的朋友可以參考下
    2024-05-05

最新評論