美团外卖服务端的测试面试题居然泄……泄……泄……泄密了

上一篇 / 下一篇  2018-06-22 10:11:22 / 个人分类:第二博客


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.如何查看LinuxCPU信息

答: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)

 

print(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__":

    print(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);

    }

}

//先序遍历


TAG:

 

评分:0

我来说两句

显示全部

:loveliness: :handshake :victory: :funk: :time: :kiss: :call: :hug: :lol :'( :Q :L ;P :$ :P :o :@ :D :( :)

binning_001

binning_001

因为不是天生丽质,所以必须天生励志

我的栏目

日历

« 2020-06-17  
 123456
78910111213
14151617181920
21222324252627
282930    

数据统计

  • 访问量: 42934
  • 日志数: 66
  • 建立时间: 2008-04-20
  • 更新时间: 2019-02-23

RSS订阅

Open Toolbar