每次面試都被問到的linux

2021-08-28 13:21:32 字數 1954 閱讀 3977

為了之後的面試,**

1. webbench

webbench是乙個在linux下使用的非常簡單的**壓測工具。它使用fork()模擬多個客戶端同時訪問我們設定的url,測試**在壓力下工作的效能,最多可以模擬3萬個併發連線去測試**的負載能力。webbench使用c語言編寫, **實在太簡潔,原始碼加起來不到600行。

tinyhttpd是乙個超輕量型http server,使用c語言開發,全部**只有502行(包括注釋),附帶乙個簡單的client,可以通過閱讀這段**理解乙個 http server 的本質。

3. cjson

cjson是c語言中的乙個json編解碼器,非常輕量級,c檔案只有500多行,速度也非常理想。

cjson也存在幾個弱點,雖然功能不是非常強大,但cjson的小身闆和速度是最值得讚賞的。其**被非常好地維護著,結構也簡單易懂,可以作為乙個非常好的c語言專案進行學習。

專案主頁: 

4. cmockery

cmockery是google發布的用於c單元測試的乙個輕量級的框架。它很小巧,對其他開源包沒有依賴,對被測試**侵入性小。cmockery的源**行數不到3k,你閱讀一下will_return和mock的源**就一目了然了。

主要特點:

免費且開源,google提供技術支援;

輕量級的框架,使測試更加快速簡單;

避免使用複雜的編譯器特性,對老版本的編譯器來講,相容性好;

並不強制要求待測**必須依賴c99標準,這一特性對許多嵌入式系統的開發很有用

5. libev

libev是乙個開源的事件驅動庫,基於epoll,kqueue等os提供的基礎設施。其以高效出名,它可以將io事件,定時器,和訊號統一起來,統一放在事件處理這一套框架下處理。基於reactor模式,效率較高,並且**精簡(4.15版本8000多行),是學習事件驅動程式設計的很好的資源。

6. memcached

memcached 是乙個高效能的分布式記憶體物件快取系統,用於動態web應用以減輕資料庫負載。它通過在記憶體中快取資料和物件來減少讀取資料庫的次數,從而提供動態資料庫驅動**的速度。memcached 基於乙個儲存鍵/值對的 hashmap。memcached-1.4.7的**量還是可以接受的,只有10k行左右。

7. lua

lua很棒,lua是巴西人發明的,這些都令我不爽,但是還不至於臉紅,最多眼紅。

讓我臉紅的是lua的源**,百分之一百的ansi c,一點都不摻雜。在任何支援ansi c編譯器的平台上都可以輕鬆編譯通過。我試過,真是一點廢話都沒有。lua的**數量足夠小,5.1.4僅僅1.5w行,去掉空白行和注釋估計能到1w行。

8. sqlite

sqlite是乙個開源的嵌入式關聯式資料庫,實現自包容、零配置、支援事務的sql資料庫引擎。 其特點是高度便攜、使用方便、結構緊湊、高效、可靠。足夠小,大致3萬行c**,250k。

9. unix v6

unix v6 的核心源**包括裝置驅動程式在內 約有1 萬行,這個數量的源**,初學者是能夠充分理解的。有一種說法是乙個人所能理解的**量上限為1 萬行,unix v6的核心源**從數量上看正好在這個範圍之內。看到這裡,大家是不是也有「如果只有1萬行的話沒準兒我也能學會」的想法呢?

另一方面,最近的作業系統,例如linux 最新版的核心源**據說超過了1000 萬行。就算不是初學者,想完全理解全部**基本上也是不可能的。

10. netbsd

netbsd是乙個免費的,具有高度移植性的unix-like作業系統,是現行可移植平台最多的作業系統,可以在許多平台上執行,從64bit alpha伺服器到手持裝置和嵌入式裝置。netbsd計畫的口號是:」of course it runs netbsd」。它設計簡潔,**規範,擁有眾多先進特性,使得它在業界和學術界廣受好評。由於簡潔的設計和先進的特徵,使得它在生產和研究方面,都有卓越的表現,而且它也有受使用者支援的完整的源**。許多程式都可以很容易地通過netbsd packages collection獲得

面試中經常問到的問題

1 請你自我介紹一下你自己?謝謝 企業喜歡有禮貌的求職者。2 你覺得你個性上最大的優點是什麼?有好奇心 專注。3 說說你最大的缺點?我最大的缺點是過於追求完美 有的人以為這樣回答會顯得自己比較出色,但事實上,他已經岌岌可危了。企業喜歡求職者從自己的優點說起,中間加一些小缺點,最後再把問題轉回到優點上...

面試中被問到的概率題

問題描述 100人坐飛機,第乙個乘客在座位中隨便選乙個坐下,第100人正確坐到自己坐位的概率是?他們分別拿到了從1號到100號的座位,這些乘客會按號碼順序登機並應當對號入座,如果他們發現對應號座位被別人坐了,就會在剩下空的座位隨便挑乙個坐 現在假設1號乘客瘋了 其他人沒瘋 他會在100個座位中隨便選...

面試中常被問到的問題

我對程式設計比較感興趣,擅長資料結構的演算法,了解併發程式設計 設計模式等基本知識。對資料庫也有一些研究。善於專研,勤於學習,能夠團結他人,不懼怕困難。我的工作經驗不足,可能要花一些時間來適應工作環境 我可以接受加班。同時,我會提高我的工作效率,減少不必要的加班 按照招聘的工資給就行 我打算往高階軟...