為什麼在 C 語言中從 stdin 讀取行明顯比 Python 慢?
在本文中,我們旨在研究為什麼從標準輸入(stdin)讀取字串資料行)使用 C 通常比 Python 慢得多。我們首先檢查提供的程式碼,確定潛在的關注領域。
C 程式碼
string input_line; long line_count = 0; time_t start = time(NULL); int sec; int lps; while (cin) { getline(cin, input_line); if (!cin.eof()) line_count++; }
此程式碼使用 getline() 讀取文字行stdin 並計算檔案中的行數。但是,它在內部循環中一次讀取文件的每個字元。這種方法效率低下,會導致過多的系統調用,從而導致執行緩慢。
C Streams 的預設設定
與 Python 不同,C Streams 的預設設定優先與 C 風格標準同步輸入和輸出功能。這種同步可確保 C 和 C 流一致地存取輸入和輸出資源。然而,這種同步也會阻止 C 流使用更有效率的緩衝機制。
cin 與 stdio 同步,這會導致它避免任何輸入緩衝。因此,cin 一次只能讀取一個字符,使得過程更加耗時。
效能改進
為了提高 C 程式碼的效能,我們可以停用 cin 和 stdio 之間的同步。透過在程式開頭加入語句 cin.sync_with_stdio(false),我們可以允許 C 流獨立緩衝其 I/O,從而顯著提高速度。
替代方案:使用 fgets
另一個提高效能的有效方法是使用 fgets() 而不是getline()。 fgets 是一個 C 函數,它從 stdin 讀取指定數量的字元到字元陣列中,從而更好地控制緩衝過程。
基準測試結果
示範效能差異,使用包含 1 億行的檔案進行基準測試。使用原始(同步)C 程式碼、停用同步的 C 程式碼和 Python 的結果如下:
Implementation | Lines per Second |
---|---|
Python (default) | 3,571,428 |
cin (default/naive) | 819,672 |
cin (no sync) | 12,500,000 |
fgets | 14,285,714 |
wc (not a fair comparison) | 54,644,808 |
在 C 中停用同步帶來了顯著的改進,而使用 fgets 提供了更好的效能。需要注意的是,使用 wc 並不是一個公平的比較,因為它是專門為計數行而設計的。
結論
透過了解C 流的預設設定並實現適當的最佳化,例如停用串流同步或使用fgets,可以顯著提高C 程式碼從stdin 讀取行的性能,使其與Python 對應物相當甚至更快。
以上是為什麼 C 的 stdin 行讀取速度明顯慢於 Python,如何改進?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

Tomergelistsinpython,YouCanusethe操作員,estextMethod,ListComprehension,Oritertools

在Python3中,可以通過多種方法連接兩個列表:1)使用 運算符,適用於小列表,但對大列表效率低;2)使用extend方法,適用於大列表,內存效率高,但會修改原列表;3)使用*運算符,適用於合併多個列表,不修改原列表;4)使用itertools.chain,適用於大數據集,內存效率高。

使用join()方法是Python中從列表連接字符串最有效的方法。 1)使用join()方法高效且易讀。 2)循環使用 運算符對大列表效率低。 3)列表推導式與join()結合適用於需要轉換的場景。 4)reduce()方法適用於其他類型歸約,但對字符串連接效率低。完整句子結束。

pythonexecutionistheprocessoftransformingpypythoncodeintoExecutablestructions.1)InternterPreterReadSthecode,ConvertingTingitIntObyTecode,whepythonvirtualmachine(pvm)theglobalinterpreterpreterpreterpreterlock(gil)the thepythonvirtualmachine(pvm)

Python的關鍵特性包括:1.語法簡潔易懂,適合初學者;2.動態類型系統,提高開發速度;3.豐富的標準庫,支持多種任務;4.強大的社區和生態系統,提供廣泛支持;5.解釋性,適合腳本和快速原型開發;6.多範式支持,適用於各種編程風格。

Python是解釋型語言,但也包含編譯過程。 1)Python代碼先編譯成字節碼。 2)字節碼由Python虛擬機解釋執行。 3)這種混合機制使Python既靈活又高效,但執行速度不如完全編譯型語言。

UseeAforloopWheniteratingOveraseQuenceOrforAspecificnumberoftimes; useAwhiLeLoopWhenconTinuingUntilAcIntiment.forloopsareIdealForkNownsences,而WhileLeleLeleLeleLeleLoopSituationSituationsItuationsItuationSuationSituationswithUndEtermentersitations。

pythonloopscanleadtoerrorslikeinfiniteloops,modifyingListsDuringteritation,逐個偏置,零indexingissues,andnestedloopineflinefficiencies


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

Atom編輯器mac版下載
最受歡迎的的開源編輯器

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境