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 ,那么我将会被分在哪个组,主要的工作内容是什么? ”