網上搜集python面試題(更新中......)

武Sir博客拿的面試題,答案都是自己寫的,多有不足,請多多指教。更新中。。。。。。

 

1.為什麼學習Python?
  a.寫起來快,看起來明白。作為通用性的語言,除了一些對性能要求很高的場合,幾乎什麼都能幹,常見領域:web服務器、計算科學、程序腳本、系統管理

2.通過什麼途徑學Python?
  看各種教學視頻,看博客。

3.Python和Java、PHP、C、C#、C++等其他語言的對比?
  Python是一門面向對象的解釋性語言,Python通過縮進來確定作用域,Python代碼簡潔易讀。 Python擁有很多功能強大的模塊可供使用。但是Python相比較於其他語言,運行效率低,不適合對運行效率要求搞的程序。

4.簡述解釋型和編譯型編程語言?
  計算機不能直接的理解高級語言,只能直接理解機器語言,所以必須要把高級語言翻譯成機器語言,計算機才能執行高級語言的編寫的程序。翻譯的方式有兩種,一個是編譯,一個是解釋。兩種方式只是翻譯的時間不同。
  解釋性語言的程序不需要編譯,解釋性語言在程序運行的時候才需要翻譯,可移植性好,只需要有解釋環境,可在不同平台運行。缺點就是必須要有解釋環境才能運行,需要佔用更多的資源,代碼效率低,解釋器本身也需要佔用資源,程序嚴重依賴於平台。
  編譯型就是直接把程序編譯成機器可以執行的文件,編譯和執行是分開的,但不能跨平台,編譯型語言的程序執行效率高,編譯后程序不可修改,保密性好。缺點代碼需要經過編譯方可運行,可移植性差,只能在兼容的操作系統上運行。

5.Python解釋器種類以及特點?
  CPython
  使用C語言開發,使用最廣泛的解釋器。
  IPython
  基於CPython上的一個交互式解釋器,IPython在交互方式上有所增強,但執行Python代碼的功能和CPython是完全一樣。
  PyPy
  PyPy採用JIT技術,對Python代碼進行動態編譯,可以顯著提高Python代碼的執行速度。
  JPython
  Jython是運行在Java平台上的Python解釋器,可以直接把Python代碼編譯成Java字節碼執行。
  IronPython
  IronPython和Jython類似,只不過IronPython是運行在微軟.Net平台上的Python解釋器,可以直接把Python代碼編譯成.Net的字節碼。

6.位和字節的關係?
  8位(bit) = 1字節(Byte)

7.b、B、KB、MB、GB 的關係?
  1024b(Byet) = 1KB
  1024KB(Byet) = 1MB
  1024MB(Byet) = 1GB
  1024GB(Byet) = 1TB

  8.請至少列舉5個 PEP8 規範(越多越好)
    a.不要在行尾加分好,也不要用分號將兩條命令放在同一行。
    b.每行不超過80個字符(長的導入模塊語句和註釋里的URL除外)
    c.不要使用反斜杠連接行。Python會將圓括號,中括號和花括號中的行隱式連接。
    d.用四個空格來縮進代碼,不要用tab,也不要tab和空格混用。對於行連接的情況,你應該要麼垂直對齊換行的元素,或者使用四空格的懸挂式縮進。
    e.頂級定義之間空兩行,方法定義之間空一行。如函數或者類的定義空兩行,方法定義與第一個方法之間,空一行。
    f.不要在冒號,逗號,分號前面加空格,但應該在他們後面加。

  9.通過代碼實現如下轉換:(未寫)
    二進制轉換成十進制:v = “0b1111011”

    十進制轉換成二進制:v = 18

    八進制轉換成十進制:v = “011”

    十進制轉換成八進制:v = 30

    十六進制轉換成十進制:v = “0x12”

    十進制轉換成十六進制:v = 87

  10.請編寫一個函數實現將IP地址轉換成一個整數。(未寫)
    如 10.3.9.12 轉換規則為:
    10 00001010
    
3 00000011

    9 00001001

      12 00001100

    再將以上二進制拼接起來計算十進制結果:00001010 00000011 00001001 00001100 = ?

  11.python遞歸的最大層數?
    Python解釋器為了避免內存一出和性能影響設置了最大遞歸深度為998,當調用棧超過998層就會報錯。

  12.求結果:
    v1 = 1 or 3
 —————>v1 = 1
    v2 = 1 and 3
 ————–>v2 = 3
    v3 = 0 and 2 and 1 ——–>v3 = 0

      v4 = 0 and 2 or 1 ———>v4 = 1

     v5 = 0 and 2 or 1 or 4 —->v5 = 1

      v6 = 0 or False and 1 —–>v6 = False

  13.ascii、unicode、utf-8、gbk 區別?

ascii:
  在計算機內部,所有信息最終都是一個二進制。每一個二進制位(bit),有0和1兩種狀態,因此,8個二進制位可以組合出256種狀態,這被稱為字節。上個世紀六十年代,美國定製了一套字符編碼,對英文字符與二進制之間做了聯繫,這個被稱為ASCII🐴,一直沿用至今。
ASCII🐴一共規定了128個字符,比如space是32,A是65,這128個符號只佔用了一個字節的後面七位,最前面的一位規定為0。

GBK:
  GBK編碼是對GB2312的擴展,完全兼容GB2312。採用雙字節編碼方案,剔除xx7F碼位共23940個碼位,共收錄漢字和圖形符號21886個,GBK編碼方案與1995年12月15日發布。它幾乎完美支持漢字,因此經常會遇見GBK與UNICode的轉換。
UNICode:
  如上文所述,世界上有多種編碼方法,同一個二進制数字可以被解釋稱不同的符號。因此,在打開一個文本文件時候,就必須知道它的編碼方式,用錯誤的編碼方式打開,就會出現亂碼。假如,有一種編碼,將世界上所有的符號都納入其中,每一種符號都給予獨一無二的編碼,那麼亂碼問題就不會存在了。因此,產生了Unicode編碼,這是一種所有符號的編碼。
  Unicode顯然是一個巨大的集合,現在的規模可以容納100多萬個符號。每個符號的編碼都不一樣,比如U+0041表示英語的大寫字母A,U+4e25表示漢字嚴。
在Unicode龐大的字符集的優勢下,還存在一個問題,比如一個漢字,“嚴”的Unicode是十六進制4e25,轉成二進制足足有15位,也就是,這個符號需要2個字節,表示其他字符還存在3個字節或者更多。計算機怎麼區別三個字節表示的是同一個符號而不是分開表示三個呢?如果Unicode統一規定,每個符號用3個字節表示,但是某些字母顯然不需要3個,那麼就浪費了空間,文本文件大小超出了很多,這顯然是不合理的。直到UTF8字符編碼出現了。

UTF-8:
  隨着互聯網的發展,強烈要求出現一種統一的編碼方式。UTF8就是在互聯網中使用最多的對Unicode的實現方式。還有其他實現,比如UTF16(字符用2個字節或者4個字節表示),UTF32(字符用4個字節表示)。UTF8是Unicode的實現方式之一,也是最為常見的實現方式。UTF8的最大特點是,它是一種變長編碼,可以使用1-4個字節表示一個符號,根據不同的符號來變化字節長度。UTF8編碼規則只有兩條:
  1)對於單字節的符號,字節的第一位設為0,後面的7位為這個符號的Unicode碼。因此,對於英文字母,UTF8編碼和ASCII編碼是相同的。
  2)對於非單字節(假設字節長度為N)的符號,第一個字節的前N位都設為1,第N+1設為0,後面字節的前兩位一律設為10,剩下的沒有提及的二進制,全部為這個符號的Unicode碼。

    《網上搜集python面試題(更新中......)》

 

  14.字節碼和機器碼的區別?
    機器碼:CPU能夠直接解讀的數據,也被稱為原生碼。
    字節碼:一種包含執行程序、由一序列操作代碼/數據組成的二進制文件。它是一種中間代碼,需要轉譯才能被CPU所解讀。

  15.三元運算規則以及應用場景?
    例如:
    h = “變量1” if a>b else “變量2”
    三元運算也可用於生成列表和字典:
      1-10的数字,打印出其中的偶數:
        ss = [i for i in range(1,11) if i%2==0 ]

点赞

發佈留言

發佈留言必須填寫的電子郵件地址不會公開。 必填欄位標示為 *