• 高级测试岗位面试题---MARK


    1. 直接手写一个python类
    2. 直接手写一个构造函数
    3. 紧接着上面的代码,直接手写,补充完整代码,要求对列表中的人进行排序,并筛选出分数大于80的人的名单,组成一个新的列表显示出来。
    class Person:
    def __init__(self, name, gender, age):
    self.name = name
    self.gender = gender
    self.age = age


    class Student(Person):
    def __init__(self, name, gender, age,score):
    super(Student, self).__init__(name, gender, age)
    self.score = score

    People = [kathy, Jim, John, Alice, Leo]

    python的高阶函数有哪些,分别都有什么作用?

    高阶函数:把函数作为参数传入,或者把函数作为返回值返回,这样的函数称为高阶函数,函数式编程就是指这种高度抽象的编程范式。
    
    1. map()函数,函数接收两个参数,一个是函数,一个是序列,map将传入的函数依次作用到序列的每个元素,并把结果作为新的list返回。
    def f(x):
         return x * x
    
    >>> map(f, [1, 2, 3, 4, 5, 6, 7, 8, 9])
    [1, 4, 9, 16, 25, 36, 49, 64, 81]
    
    2.reduce()的用法。reduce把一个函数作用在一个序列[x1, x2, x3...]上,这个函数必须接收两个参数,reduce把结果继续和序列的下一个元素做累积计算,其效果就是:
    
    reduce(f, [x1, x2, x3, x4]) = f(f(f(x1, x2), x3), x4)
    比方说对一个序列求和,就可以用reduce实现:
    
    >>> def add(x, y):
    ...     return x + y
    ...
    >>> reduce(add, [1, 3, 5, 7, 9])
    25
    
    3. Python内置的sorted()函数就可以对list进行排序:
    
    >>> sorted([36, 5, 12, 9, 21])
    [5, 9, 12, 21, 36]
    此外,sorted()函数也是一个高阶函数,它还可以接收一个比较函数来实现自定义的排序。比如,如果要倒序排序,我们就可以自定义一个reversed_cmp函数:
    
    def reversed_cmp(x, y):
        if x > y:
            return -1
        if x < y:
            return 1
        return 0
    传入自定义的比较函数reversed_cmp,就可以实现倒序排序:
    
    >>> sorted([36, 5, 12, 9, 21], reversed_cmp)
    [36, 21, 12, 9, 5]

    简单说说生成器,迭代器,装饰器是什么,都有哪些作用?

    迭代器;任何对象,如果它实现了next方法和iter方法,就是迭代器。
    next方法要么返回迭代中的下一项,要么返回一个stapIteration异常,iter方法要返回一个迭代器对象,而它本身就是一个迭代器对象,所有返回自己本身。 作用:像我们提供一个中间人即迭代器帮助我们迭代遍历使用 for循环其实就实现了迭代器的功能,在遍历list,string,dict,tuple这些容器时,在 for语句对容器对象调用的iter()方法返回一个定义next()方法的迭代器对象,
    它在函数中逐个访问容器内的元素,next和iter都是python内置函数。 生成器:生成器是一种特殊的迭代器,在函数中有yield关键字就可以说是生成器。 怎么用:调用next(),就会返回yield后面的值,生成器挂起,再次使用next就从上次停止的位置继续执行。 作用:延迟计算,一次返回一个结果。当我们需要结果的时候才会调用,而不是一次返回所有的结果。 也就是说,它不会一次生成所有的结果,
    这对于大数据量处理,将会非常有用。 创建方法:
    1.把列表生成式的[ ]改为()就是一个简单的列表生成器 2.使用yield关键字 生成器和迭代器的区别:生成器能做到迭代器能做到的所有事,因为自动创建iter方法和next方法,显的比较简洁,高效。
    使用生成器表达式比列表解析要节省内存(前者是需要的时候才调用next返回一个值,后者直接返回一个列表),自动抛出StopIteration异常 装饰器:在不改变已存在的对象的功能情况下添加额外的功能
    def set_fun(func): call_fun(*arge,**kwargs): reurn func(*arge,**kwargs) return call_fun 作用:引用日志,函数执行预计时间,权限校验,缓存等

    Python中,如何将字符串转化为整型?

    def to_int(str):
        try:
            int(str)
            return int(str)
        except ValueError: #报类型错误,说明不是整型的
            try:
                float(str) #用这个来验证,是不是浮点字符串
                return int(float(str))
            except ValueError:  #如果报错,说明即不是浮点,也不是int字符串。   是一个真正的字符串
                return False

    TCP 三次握手和四次挥手,请分别直接写出来

    客户端向服务端发送一个请求, syn -----服务端返回一个 应答 ack+syn  -----客户端收到后返回一个确认 ack

    客户端向服务器发送一个关闭连接请求 fin  m----服务端应答返回ack m+1---服务端返回一个fin n ----客户端收到后发一个确认---ack n+1

    HTTP常见的状态码有哪些?都是什么含义?

    200 - 请求成功
    301 - 资源(网页等)被永久转移到其它URL
    404 - 请求的资源(网页等)不存在
    500 - 内部服务器错误

    webdriver的核心原理是什么?

    1.测试人员运行脚本,由于客户端脚本(java, python, ruby)不能直接与浏览器通信,这时候webdriver启动了一个remote-WebService当做一个翻译器,
    它可以把客户端代码翻译成浏览器可以识别的代码(比如js)。webdriver 通过浏览器监听这个端口。
    2.客户端(也就是测试脚本)创建1个session,
    在该session中通过http请求向WebService发送restful的请求,WebService翻译成浏览器懂得脚本传给浏览器,
    3.浏览器把执行的结果返回给WebService,WebService把返回的结果做了一些封装(一般都是json格式),
    然后返回给client,根据返回值就能判断对浏览器的操作是不是执行成功

    总结: webdriver就是基于Http 协议来进行底层的客户端与服务端通信的。

    appium是什么?主要用来做什么的?它的核心原理是什么?

    略,appium client   appium server   bootstrap.js/bootstrap.jar

    selenium1和selenium2的区别是什么,为何要抛弃selenium1?它有什么缺陷?

    常见的元素定位方法有哪些?

    by  id,classname, name ,xpath,linktext 等等

    直接手写一个冒泡排序和快速排序,时间复杂度是多少?空间复杂度是多少?是否稳定?

    //时间复杂度:O(n²)  空间复杂度:空间复杂度为O(1) 典型的用时间换空间的算法
    public
    class poup{ int[] arr={6,3,8,2,9,1};     System.out.println("排序前数组为:");     for(int num:arr){       System.out.print(num+" ");     }     for(int i=0;i<arr.length-1;i++){//外层循环控制排序趟数       for(int j=0;j<arr.length-1-i;j++){//内层循环控制每一趟排序多少次         if(arr[j]>arr[j+1]){           int temp=arr[j];           arr[j]=arr[j+1];           arr[j+1]=temp;         }       }     }     System.out.println();     System.out.println("排序后的数组为:");     for(int num:arr){       System.out.print(num+" ");     }   } }

    如何查询Linux后台日志,直接写出命令

    cat demo.log

    more demo.log

    // 查询包含关键字`123456`且包含`aa`的日志内容

    grep "123456" demo.log | grep "aa"

    如何查看当前进程?

    netstat

    Dockerfile是什么?如何去创建一个Dockerfile?

    Dockerfile 是一个文本文件,其内包含了一条条的指令(Instruction),每一条指令构建一层,因此每一条指令的内容,就是描述该层应当如何构建。
    
      此处以定制 nginx 镜像为例,使用 Dockerfile 来定制。
    
      在一个空白目录中,建立一个文本文件,并命名为 Dockerfile :
    
    $ mkdir mynginx
    $ cd mynginx
    $ touch Dockerfile
    
    其内容为:
    
    FROM nginx
    RUN echo '<h1>Hello, Docker!</h1>' > /usr/share/nginx/html/index.html
    
    
    这个 Dockerfile 很简单,一共就两行。涉及到了两条指令, FROM 和 RUN 。

    Python有没有垃圾回收机制?它又是通过什么来的?

    Python中的垃圾回收是以引用计数为主,分代收集为辅。引用计数的缺陷是循环引用的问题。

    https://www.cnblogs.com/pinganzi/p/6646742.html

    熟悉TESTNG,那请说一下TESTNG的用法?

    略, 大致是testsuite,testcase,  testng.xml , 基本注解, listener(Listener包括ISuiteListenerITestListenerIInvokedMethodListener,他们可以在suite级别、test级别和test method一些执行点执行一些自定义操作,如打印日志。因)

    熟悉JAVA,那请直接手写一个单例模式?

    // 饱汉
    // UnThreadSafe
    public class Singleton1 {
      private static Singleton1 singleton = null;
      private Singleton1() {
      }
      public static Singleton1 getInstance() {
        if (singleton == null) {
          singleton = new Singleton1();
        }
        return singleton;
      }
    }

    数据库增删改查,手写SQL

    略, 注意join , group by , having, count(ll)

    redis是做什么用的?elasticsearch是什么?做什么用的?

    Redis是一个开源的key—value型数据库,支持string、list、set、zset和hash类型数据。对这些数据的操作都是原子性的,redus为了保证效率会定期持久化数据。
    使用场景:
    
    1.配合关系型数据库做高速缓存
    
    2.缓存高频次访问的数据,降低数据库io
    
    3.分布式架构,做session共享
    
    4.可以持久化特定数据。
    
    5.利用zset类型可以存储排行榜
    
    6.利用list的自然时间排序存储最新n个数据

    ElasticSearch是一个基于Lucene的搜索服务器。它提供了一个分布式多用户能力的全文搜索引擎,基于RESTful web接口。
    Elasticsearch是用Java开发的,并作为Apache许可条款下的开放源码发布,是当前流行的企业级搜索引擎。设计用于云计算中,
    能够达到实时搜索,稳定,可靠,快速,安装使用方便。

    接口测试怎么做的?如果存在接口依赖关系,怎么做?

    略, 注意http/https接口,get/post, 参数的差异(json, url等等) 写一个传参函数,将需要传递的参数存储起来供下一条接口使用

    元祖和列表的区别是什么?

    元祖 tuple是有序列表 初始化之后,不能更改,元祖转换为列表:tuple-->list  list(tuple)

    列表list 

    函数:len()、append()、remove()移除列表中某个值的第一个匹配项、insert()、pop()、sort()、del、list()、reverse()、index()从列表中找出某个值第一个匹配项的索引位置、count()统计某个元素在列表中出现的次数、extend()在列表末尾一次性追加另一个序列中的多个值(用新列表扩展原来的列表)

    删除:del list1[0]

    Python中,arg和*kwarg分别代表什么含义,都有哪些作用?

    https://www.jianshu.com/p/e0d4705e8293

    当不确定函数传递多少个参数的时候,使用*arg, **kwarg

    • *arg会把多出来的位置参数转化为tuple
    • **kwarg会把关键字参数转化为dict

    写过爬虫,那请说一下常见的反爬机制有哪些?如果是动态加载的页面,看不到数据,如何去进行爬取?

    加入图片识别 ,使用代理,更新IP; 使用cookie登陆 

    一般动态加载的数据都以json形式存储,在Filter里填json过滤,可以更加快速地寻找到想要的文件,但不是所有的网站都适用

  • 相关阅读:
    Slimer软工课设日报-2016年6月30日
    Slimer软工课设日报-2016年6月29日
    软件工程个人总结
    什么是Bug
    构建之法读后感----第1章 绪论
    7.4
    7.1-7.3
    6.29
    软件工程课设 第二天
    软工总结 作业
  • 原文地址:https://www.cnblogs.com/Ronaldo-HD/p/9871177.html
Copyright © 2020-2023  润新知