本文爲霍格沃茲測試學院學員學習筆記。
本系 本係列文章總結歸納了一些軟體測試工程師常見的面試題,主要來源於個人面試遇到的、網路蒐集 搜集(完善)、工作日常討論等,分爲以下十個部分,供大家參考。如有錯誤的地方,歡迎指正。有更多的面試題或面試中遇到的坑,也歡迎補充分享。希望大家都能找到滿意的工作,共勉之!~
軟體測試工程師面試題
- 測試常見問題與流程篇
- 測試工具篇
- 計算機網路知識與數據庫篇
- Linux 與 Python 程式設計技能篇
- 自動化測試(Selenium、Appium 和介面測試)與效能測試篇
- 軟素質篇(10 大靈魂拷問)與反問面試官篇
Linux 技能篇
1. 工作中常用的 Linux 命令有哪些?
awk、sed、vim、iotop、dstat、cp、top、ifconfig、pwd、cd、ll、ls、cat、tail、grep、mv、rm、mkdir、df、du
2.什麼命令可以幫助 Linux 執行 Windows 上傳的指令碼?
- 改變編碼格式
- vim test.sh
- :set ff?// 顯示dos的話
- :set ff=unix:wq
3簡述 Linux 三劍客
-
grep 命令
- 根據使用者指定的模式 pattern 對目標文字進行過濾,顯示被模式匹配到的行;
- grep [options] pattern [file]
- 常用參數:
- -v 顯示不被pattern匹配到的行
- -i 忽略字元的大小寫
- -n 顯示匹配的行號
- -c 統計匹配的行數
- -o 僅顯示匹配到的字串
- -E 使用ERE,相當於egrep(可以識別更多的正則表達式規則)
-
sed 命令
- 流編輯器,用來處理一行數據。將一行數據儲存在模式空間中->用sed命令處理->送入螢幕->清空空間。
- 常用參數:
- -h 顯示幫助
- -n 僅顯示script處理後的結果
- -e 指定的指令碼來處理輸入的文字檔案
- -f 以指定的指令碼檔案來處理
- 常用動作:
- a: 新增 sed -e ‘4 a newline’
- c: 取代 sed -e ‘2,5c No 2-5 number’
- d: 刪除 sed -e ‘2,5d’
- i: 插入 sed -ed ‘2i newline’
- p: 列印 sed -n ‘/root/p’
- s: 取代 sed -e ‘s/old/new/g’
- g: 代表全域性
-
awk 命令
- 把檔案逐行的讀入,以空格爲預設分隔符將每行切片。把行作爲輸入,並賦值給$0->將行切段,從$1開始->對行匹配正則/執行動作->列印內容;
awk 'pattern + action' [filenames]
- 常用語法:
- filename awk 瀏覽的檔名
- begin 處理文字前要執行的操作
- end 處理文字之後要執行的操作
- fs 設定輸入域分隔符,等價於命令列-F選項
- nf 瀏覽記錄的域的個數(列數)
- nr 已讀的記錄數(行數)
- 常用參數:
- ofs 輸出域分隔符
- ors 輸出記錄分隔符
- rs 控制記錄分隔符,換行標誌
- $0 整條記錄
- $1 第一條分隔後的記錄
4.如何通命令定位 Linux 伺服器下的日誌?
- 如果要監控日誌,那麼使用 tail -f | grep xxx 命令,過濾需要的欄位;
- 如果在完整日誌中檢視內容,使用 cat xxx.log | grep xxxx | awk ‘{print $1}’ 等命令過濾自己需要的內容;
5.簡述專案中的環境搭建和維護
- 結合自身經驗先從系統安裝開始,如常用的 CentOS 和 Ubuntu 說起,系統安裝主要是磁碟分割區和磁碟陣列問題;
- 基礎環境依賴,如 MySQL、Redis、Jenkins、Docker、專案中用到的其他依賴環境等;
- 維護方便主要從遇到的錯誤說起,如無法遠端連線、伺服器加固等;
Python 程式設計篇
1.Python 中類方法,類實體方法,靜態方法的區別
- 實體方法:由物件呼叫;至少一個 self 參數;執行普通方法時,自動將呼叫該方法的物件賦值給 self;
- 類方法:由類呼叫;至少一個 cls 參數;執行類方法時,自動將呼叫該方法的類複製給 cls;
- 靜態方法:由類呼叫;無預設參數;
2.dict 和 tuple 及 list 的區別(這裏列的是主要區別,面試足夠)
- tuple 是不可變物件,list 和 dict 都是可變物件,這裏的不可變指的是指向地址不可變;
- list 是有序的,dict 是無序的,不可存放有序集合;
- dict 查詢速度快,不管有多少個元素時間都一樣,list 查詢速度慢,需要有序查詢;
- dict 的 key 爲不可變物件,且不可重複,list 則可以重複,存放任意物件;
3.JSON 和 dict 的區別
- JSON 是一種數據格式,純字串。dict 是一種完整的數據結構;
- dict 是一個完整的數據結構,是對 Hash Table 這一數據結構的一種實現,是一套從儲存到提取都封裝好了的方案。它使用內建的雜湊函數來規劃 key 對應 value 的儲存位置,從而獲得O(1)的數據讀取速度;
- JSON 的 key 只能是字串,Python 的 dict 可以是任何可 hash 物件(不可變物件);
- JSON 的 key 可以是有序、可重複的;dict 的 key 不可重複,且無序;
- JSON 任意 key 存在預設值 undefined,dict 預設沒有預設值;
- JSON 存取方式可以是[],也可以是.,遍歷方式分 in、of;dict 的 value 僅可以下標存取;
- dict 可以巢狀 tuple,JSON 裡只有陣列;
4.Python 會不會出現記憶體漏失,爲什麼?
- 當物件之間互相參照的時候再刪除的時候,可能會造成無法釋放物件的情況,出現泄漏;
- 上面爲個人瞭解,如有其它請補充;
5.Python 的同步和非同步
- 直接得到最終結果的結果,就是同步呼叫。
- 不直接得到的最終的結果,就是非同步呼叫。
- 同步與非同步區別在於:呼叫者是否得到了想要的最終結果。
6.常見手撕程式碼題
dict(zip(list1, list2))
str = '1234567890'
print(str[::-1])
l = list(str)
l.reverse()
print(''.join(l))
def Fibonacci(loop):
if loop == 0:
return '無效參數'
elif loop == 1:
return 0
l = [0, 1]
for i in range(2, loop):
l.append(l[i - 1] + l[i - 2])
return l
li = [1, 2, 10, 10, 2, 1]
print([v for v in li if v == max(li)])
sxh = []
for i in range(100, 1000):
s = 0
for j in str(i):
s += int(j)**3
if i == int(j)**3:
sxh.append(i)
print(sxh)
a = []
for i in range(1, 1000):
s = 0
for j in range(1, i):
if i % j == 0 and j < i:
s += j
if s == i:
a.append(i)
def mi(a, n):
if n == 0:
return 1
else:
return a * mi(a, n - 1)
import os
def get_file(path, rule=''):
files = []
for fpath, dirs, fs in os.walk(path):
for f in fs:
if os.path.join(fpath, f).endswith(rule):
files.append(f)
return files
更多內容,我們在後續文章分享。
免費領取:介面測試+效能測試+自動化測試+測試開發+測試用例+簡歷模板+測試文件