美團外賣服務端的測試面試題居然洩。。洩。。洩。。洩密了。
1. 列出你常用的 linux 命令
答: vim/touch/cat/tail/grep/cd/chmod/mv/rm 等
2. 測試介面時,常會遇到需要傳入不同引數來測試不同場景,如何實現
答:自己寫方法,並新增到 test 中去。詳細程式碼後期補充。
3. 瀏覽器中輸入一個 URL 後,詳細說明將會發生什麼
答: 1. 解析 URL
2. 透過 DNS 找到域名對應的伺服器 IP
3. 瀏覽器與服務端進行 TCP 三次握手
第一次握手:客戶端向伺服器端傳送請求;
第二次握手:伺服器收到請求並確認;
第三次握手:客戶端收到伺服器的回覆指令並返回確認
4. 請求和傳輸資料
5. 瀏覽器渲染頁面
4. 如何檢視 linux 系統程式
答: ps -aux 或 ps -aux | grep java
5. 如何檢視 linux 實時日誌檔案
答: tail -f
6. 如何檢視 Linux 的 CPU 資訊
答: cat /proc/cpuinfo
7. 程式和執行緒的區別
答: 1. 定義:
程式:程式有一定獨立功能的程式,是系統進行資源分配和除錯的一個獨立單位
執行緒:執行緒是程式的一個實體,它比程式更小的能獨立執行的基本單位
2. 關係:
同一個程式的多個執行緒之間可以併發執行;
相對程式而言,執行緒可以與同程式中的其他執行緒共享資料
3. 區別:
1 )一個程式至少有一個程式,一個程式至少有一個執行緒
2 )執行緒的劃分驚訝小於程式,使得多執行緒程式的併發性高
3 )程式在執行過程中擁有獨立的記憶體單元,而多個執行緒共享記憶體,從而提高執行效率
4 )每個程式有獨立的執行入口和出口,執行緒不能獨立執行
5 )多執行緒的意義在於一個應用程式中,有多個執行部分可以同時執行。
4. 優缺點
執行緒執行開銷小,但不利於資源的管理和保護
程式正相反
8. 給定一無序列表,如何去重,程式碼實現
答:
1) 解法一:
ids = [1,2,3,3,4,2,3,4,5,6,1]
new_ids = []
for id in ids:
if id not in new_ids:
news_ids.append(id)
p rint ( new_ids )
2) 解法二:
ids = [1,2,3,4,3,2,5]
new_ids = list(set(ids))
print(new_ids)
9. 程式碼寫說二分法查詢
答:時間複雜度:O(log2n);
def Search(array,t):
low = 0
height = len(array)-1
while low < height:
mid = (low+height)/2
if array[mid] < t:
low = mid + 1
elif array[mid] > t:
height = mid - 1
else :
return array[mid]
return -1
if __name__ == "__main__" :
p rint( Search([1,5,6,8,10,15,18,25],5))
10. 給一個資料庫表,一個 Order 表,有商戶 id ,訂單 id, 商品數量,與商品單價,求某商戶的銷售額,寫 sql
答:
id |
Order_id |
num |
price |
10001 |
9000001 |
3 |
100 |
10001 |
9000002 |
2 |
50 |
10002 |
9000003 |
1 |
1000 |
SELECT id, (num * price) as sum_price FROM Order ORDER BY id
11. 介面測試時主要關注什麼
答:狀態碼與訊息值
12. HTTP 錯誤中 503 代表什麼意思
答: 5XX 為伺服器返回的錯誤,其中 503 代表了服務不可用是的一種狀態,可能是伺服器正在維護或者暫停了,或是 CPU 佔用的頻率大導致的。
13. selenium 中如何定位動態 元素
答: 1) xpath 2) 動態元素的規律 3) 找到父元素,透過 dom 結構定位
14. 求一有序列表 [1,2,3,4,4,4,5,6] 中 4 的區間,程式碼實現
答:
def get_all_index(self, arr, target):
return [i for i, a in enumerate(arr) if a == target]
If __name__ == “__main__”:
arr = [1,2,3,4,4,4,5,6]
target = 4
s = get_all_index(arr, target)
print(s[0], s[-1])
15. 用程式碼判斷一個 IP 是否正確
答:
1) 解法一
try:
first = int(input(“ 請輸入第一個 1-255 數字: ”))
second = int(input(“ 請輸入第二個 0-255 的數字 :”))
third = int(input(“ 請輸入第三個 0-255 的數字: ”))
fourth = int(input(“ 請輸入第四個 0-255 的數字: ”))
except Exception as e:
print(“ 請輸入數字 ”)
if 1 <= first <= 255:
if 0<= second <= 255:
if 0<= third <= 255:
if 0 <= fourth <= 255:
print(“IP %s.%s.%s.%s 有效 ” % (first, second, third, fourth))
else:
print(“IP 無效 ”)
2) 解法二:
import re
def judge_legal_ip(one_str):
'''''
正則匹配 方法
判斷一個字串是否是合法 IP 地址
'''
compile_ip=re.compile('^((25[0-5]|2[0-4]d|[01]?dd?).)’
’{3}(25[0-5]|2[0-4]d|[01]?dd?)$')
if compile_ip.match(one_str):
return True
else:
return False
def judge_legal_ip2(one_str):
'''''
簡單的字串判斷
'''
if '.' not in one_str:
return False
elif one_str.count('.')!=3:
return False
else:
flag=True
one_list=one_str.split('.')
for one in one_list:
try:
one_num=int(one)
if one_num>=0 and one_num<=255:
pass
else:
flag=False
except:
flag=False
return flag
if __name__=='__main__':
ip_list=['','172.31.137.251','100.10.0.1000','1.1.1.1','12.23.13',
'aa.12.1.2','12345678','289043jdhjkbh']
for one_str in ip_list:
if judge_legal_ip(one_str): # 正則方法
#if judge_legal_ip2(one_str): # 字串方法
print ('{%s} is a legal ip address!' % (one_str))
else:
print ('{%s} is not a legal ip address!' % (one_str))
16. 資料庫左連線和右連線有什麼區別,結果上有什麼不同。
答:左連線是以左表為基準,右連線是以右表為基準。結果看具體情況,相同的是不足的地方會顯示為 NULL
17. 給一個二叉樹,演算法實現樹的先序、中序後序
答:先序:根左右;中序:左根右;後序:左右根
// 輸出
void Visit(BiTree T){
if(T->data != '#'){
printf("%c ",T->data);
}
}
// 先序遍歷
void PreOrder(BiTree T){
if(T != NULL){
// 訪問根節點
Visit(T);
// 訪問左子結點
PreOrder(T->lchild);
// 訪問右子結點
PreOrder(T->rchild);
}
}
// 中序遍歷
void InOrder(BiTree T){
if(T != NULL){
// 訪問左子結點
InOrder(T->lchild);
// 訪問根節點
Visit(T);
// 訪問右子結點
InOrder(T->rchild);
}
}
// 後序遍歷
void PostOrder(BiTree T){
if(T != NULL){
// 訪問左子結點
PostOrder(T->lchild);
// 訪問右子結點
PostOrder(T->rchild);
// 訪問根節點
Visit(T);
}
}
18. 說出 selenium 的原理
答:
1) selenium1.0 + webdriver = selenium2.0
2) selenium1.0 = selenium IDE + seleniumRC + selenium Grid
原理:
1) 啟動瀏覽器後, selenium-webdriver 會將目標瀏覽器繫結到特定的埠,啟動後的瀏覽器則作為 webdriver 的 remote server 。
2) 客戶端 ( 也就是測試指令碼 ) ,藉助 ComandExecutor 傳送 HTTP 請求給 sever 端 ( 指瀏覽器 ) 。
3)Sever 端需要依賴原生的瀏覽器元件,轉化 Web Service 的命令為瀏覽器 native 的呼叫來完成操作。
19. 說說你平常工作流程?你認為哪裡有缺陷。
答:
20. 簡要說明你在過去的工作中的亮點
答:
21. 說說過去為什麼要跳槽
答:個人發展、公司前景或其他因素
22 . 有什麼要問我的
注:這裡一定要問,我之前在其他地方看到有同學是這樣問的 “ 如果我有幸收到貴公司的 offer ,那麼有什麼知識或技能是要我在入職前一定了解或是掌握的? ” 或是 “ 如果我有幸收到貴公司的 offer ,那麼我將會被分在哪個組,主要的工作內容是什麼? ”
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69942496/viewspace-2653348/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 納尼,Java 存在記憶體洩洩洩洩洩洩漏嗎?Java記憶體
- 小白觀察:Firefox 推出密碼洩露檢測服務Firefox密碼
- 活動 | 美團外賣業務資訊洩露專場,提情報拿獎勵!
- 有效防止u盤洩密的方法,u盤防洩密軟體推薦
- 如何避免員工洩密
- 面試:為了進阿里,死磕了ThreadLocal記憶體洩露原因面試阿里thread記憶體洩露
- ElasticSearch伺服器洩露 5700萬個人資料外洩Elasticsearch伺服器
- 從索尼洩密看雲端計算安全
- 原始碼防洩密討論原始碼
- 原始碼防洩密需求分析原始碼
- Java面試題:細數ThreadLocal大坑,記憶體洩露本可避免Java面試題thread記憶體洩露
- 聊聊GenericObjectPool的洩露檢測Object
- 活動 | 專項測試,美團外賣來了!
- 資訊洩露之web原始碼洩露Web原始碼
- 分析記憶體洩漏和goroutine洩漏記憶體Go
- 前端面試題51----JS記憶體洩露前端面試題JS記憶體洩露
- Android面試被問到記憶體洩漏了咋整?Android面試記憶體
- 關於原始碼防洩密的本質問題原始碼
- 還在擔心資料丟失和洩密?試試企業雲盤吧
- dp洩露
- 程式碼伺服器防洩密伺服器
- 原始碼防洩密解決之道原始碼
- 解決記憶體洩漏(1)-ApacheKylin InternalThreadLocalMap洩漏問題分析記憶體Apachethread
- 記憶體洩漏問題分析之非託管資源洩漏記憶體
- 電腦防洩密軟體的工作原理
- 原始碼防洩密的底層安全基石原始碼
- 【教程】原始碼加密、防洩密軟體原始碼加密
- 原始碼防洩密解決之道(二)原始碼
- [CTFHUB]SVN洩露
- go timer 洩漏Go
- 什麼是資料洩露?哪些問題可導致資料洩露
- 遠端辦公防洩密技巧
- iOS檢測記憶體洩漏iOS記憶體
- java面試官:程式設計師,請你告訴我是誰把公司面試題洩露給你的?Java程式設計師面試題
- 資料洩密的危害,原因,與應對策略
- 沙盒原始碼防洩密的安全機制原始碼
- 程式碼安全測試第十一期:記憶體洩漏漏洞記憶體
- 阿里二面:談談ThreadLocal的記憶體洩漏問題?問麻了。。。。阿里thread記憶體