【面试】测试/测开(ING3)

这篇具有很好参考价值的文章主要介绍了【面试】测试/测开(ING3)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

190. 栈和堆在内存管理上的区别


  1. 1) 栈是由系统自动分配和回收的内存。
    2)栈的存储地址是由高地址向低地址扩展的。
    3)栈是一个先进后出的结构。
    4)栈的空间大小是一个在编译时确定常数,即栈的大小是有限制的,当申请的空间大小超限时会提示overflow。
    5) 栈:就是那些由编译器在需要的时候分配,在不需要的时候自动清除的变量的存储区。里面的变量通常是局部变量、函数参数等。
    6) 栈可以视为一个临时存储空间,这种临时存放数据的特性,使得它经常用来存储局部变量,函数参数,上下文环境等。
    7)栈的效率比较高:计算机分配专门的寄存器存放栈的地址,压栈出栈都有专门的指令执行,这就决定了栈的效率比较高。
    【面试】测试/测开(ING3),面试,职场和发展


  2. 1)堆区是向上生长的用于分配程序员申请的空间。
    2)在操作系统中有记录空闲内存地址的链表(也有可能是位图等其他方式),当系统受到程序的申请时就会遍历该链表寻找第一个大于该申请空间堆(假设是FIFS,当然也有可能是其他的如段进程优先等),然后将该节点从链表中删除,并将该节点的空间分配给程序;另外,对于大多数系统,会在这块内存空间中的首地址处记录本次分配的大小,这样,代码中的delete语句才能正确的释放本内存空间。若找到的堆节点的空间大小大于所申请的空间,则系统会自动将多余的空间重新放入空闲链表中,也就是说堆在进行空间分配后还要做一些后续工作就会引入效率问题。
    3)栈是系统自动申请和释放的,而堆更加强调的是手动控制,需要手动申请和释放空间。
    4)堆可分配的空间更大,但是也有较大的开销
    5)堆是在程序执行的过程中动态分配的,它最大的特性就是动态性。堆就是那些由new分配的内存块,他们的释放编译器不去管,由我们的应用程序去控制,一般一个new就要对应一个delete。如果程序员没有释放掉,那么在程序结束后,操作系统会自动回收。
    【面试】测试/测开(ING3),面试,职场和发展

  3. 其他存储区
    1) 静态存储区
    静态变量和全局变量都存储于静态存储区。

2)常量存储区
这是一块比较特殊的存储区,他们里面存放的是常量,不允许修改。
常量字符串都存放在静态存储区,返回的是常量字符串的首地址。

  1. 堆和栈的比较
    【面试】测试/测开(ING3),面试,职场和发展
  2. 数据结构中的堆和栈
    1)栈
    ① 栈是先进后出的数据结构
    ② 是一种运算受限的线性表
    ③ 只能够在栈顶进行插入和删除元素(栈顶即高地址位置)
    2)堆
    ① 通常可以被看作一棵树的数组对象
    ② 堆中某个结点的值总是不大于或不小于其父结点的值;
    ③ 堆总是一棵完全二叉树。

191. 完全二叉树和二叉树的区别 以及在使用上的优劣

参考:完全二叉树和满二叉树

  1. 完全二叉树
    1)除了最后一层外,每一层的节点都被填满。
    2)如果最后一层存在节点,那么这些节点从左到右依次填充,不留空缺。
    3)完全二叉树的高度通常较小,具有良好的平衡性。
    4)完全二叉树在堆数据结构中广泛应用,如二叉最小堆和二叉最大堆,堆排序和优先级队列等。

【面试】测试/测开(ING3),面试,职场和发展

  1. 满二叉树
    1)满二叉树是特殊的完全二叉树
    2)所有层的节点都被填满。
    3)满二叉树的高度是固定的,由节点数量决定。
    4)满二叉树在一些特定的数据存储和检索算法中有用,但相对较少见。
    【面试】测试/测开(ING3),面试,职场和发展

  2. 最优二叉树
    1)最优二叉树,也叫哈夫曼树,是指带权路径长度最小的二叉树。在哈夫曼树中,带权路径长度等于树中所有叶子节点的权值乘以它们到根节点的路径长度之和。在构造哈夫曼树的过程中,节点的权值越大,它距离根节点就越近
    2)完全二叉树的构造不需要根据节点权值来确定,而是按照深度优先的原则,一层一层从左到右地填充节点。最优二叉树的构造则是基于贪心算法,按照节点权值从小到大的顺序来构造。
    3)完全二叉树中,任何一个节点的左右子节点,如果存在,一定是连续的;而最优二叉树中,同一个节点的左右子节点可能会不连续。
    4)最优二叉树则更多地用于信息编码和压缩等领域,比如哈夫曼编码。

  3. 完全二叉树在存储和定位节点上具有优势,但在插入和删除节点时可能会增加复杂度。
    ① 完全二叉树可以使用数组来表示,不需要使用指针来表示节点之间的关系,节省了存储空间
    ② 使用数组的下标可以快速定位到某个节点
    ③ 插入和删除节点时需要将其调整成完全二叉树,调整的过程会增加操作的复杂度。

  4. 二叉树不适合存储规模太大的数据(结构相对复杂),且会出现不平衡现象使得插删查操作减慢;另外,二叉树的存储需要额外的指针来连接节点,占用了额外的空间

192. 哈希表的底层原理

参考:哈希表机器底层原理

1)哈希表(Hash Table)是一种常用的数据结构,用于实现键值对映射关系。它支持在平均常数时间内进行插入、删除和查找操作
2)哈希表的底层原理是将每个键(key)通过一个哈希函数(Hash Function)转换成一个索引(index),然后将该键值对存储在对应索引的位置上。当需要查找一个键值对时,再通过哈希函数计算出该键对应的索引,并在该索引位置上查找该键值对,从而实现快速查找。即:f表示哈希函数,而将key作为其参数来计算f(key)索引位置,将value存储到该位置上
3)哈希函数通常是将键值映射到一段固定长度的数字串,这个数字串可以看做是该键的指纹(fingerprint),可以用来唯一地标识该键。一个好的哈希函数应该能够尽量避免键的碰撞(Collision),即不同的键映射到同一个索引上的情况,否则会影响哈希表的性能。
4)为了解决碰撞问题,哈希表通常采用开放地址法(Open Addressing)或链地址法(Chaining)等方法来解决。在开放地址法中,当发生碰撞时,会继续往下一个空闲位置插入,直到找到一个空闲位置;而在链地址法中,每个索引位置上存储的是一个链表,当发生碰撞时,会将新的键值对添加到链表的末尾。

193. Linux的软连接和硬链接

参考:Linux中的软连接和硬链接

在Linux的文件系统中,保存在磁盘分区中的文件不管是什么类型都给它分配一个编号,称为索引节点号inode

  1. 软连接
    1)软连接其实就类似于咱们的快捷方式
    2)每次软连接都是建立一个新的inode,文件的内容是指向源文件的指针
    3)当源文件被删除,软连接就会找不到该文件或目录
    4)软连接的建立: ln -s [filename] soft
    5)当源文件不存在时也是可以建立软连接的

  2. 硬链接
    1)硬链接必须源文件和inode存在,并且时共享一个inode,只是增加了连接数
    2)当删除源文件的时候,只要硬链接的数量大于等于1就不会真正删除源文件
    3)硬链接不可以跨文件系统
    4)硬链接相当于是给文件创建了一个别名,同一个inode说明是同一个文件
    5)硬链接的建立:ln [filename] hard

【面试】测试/测开(ING3),面试,职场和发展

194. 产品上线之后应该关注哪些问题

1)上线前进行回归测试,保证主流程的流通性
2)上线后进行灰度测试:使用少量的数据将所有的业务流程走完,保证数据的正确性和流程的畅通完整性
3)上线之后还要进行监控和故障排查,确保系统的稳定性和可靠性
4)还要收集用户的反馈,可用于进行下一次的迭代文章来源地址https://www.toymoban.com/news/detail-806728.html

195. 刷卡、输密码、取款、余额查询以及取卡操作就功能、性能、安全性、易用性、弱网以及高并发设计测试用例

到了这里,关于【面试】测试/测开(ING3)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 初级测开面试题分享(有文档)

    今天分享一下测试群友发出的面试,小伙伴可以看看自己能答出来几题,当然答案已经整理好了,直接点击文末小卡片就能领取了。 同时,我也为大家准备了一份软件测试视频教程(含面试、接口、自动化、性能测试等),就在下方,需要的可以直接去观看 软件测试视频教

    2024年02月09日
    浏览(39)
  • 阿里测开面试大全(一)附答案完整版

    万字长文,建议收藏 POM是Page Object Model的简称,它是一种设计思想,而不是框架。大概的意思是,把一个一个页面,当做一个对象,页面的元素和元素之间操作方法就是页面对象的属性和行为,所以自然而然就用了类的思想来组织我们的页面。一般一个页面写一个类文件,这

    2024年02月07日
    浏览(40)
  • 一些测开面试题及答案(个人梳理)

    测试程序的内部的逻辑,结构的实现,是否实现了相应的功能。 单元测试:Junit框架 语句覆盖 逻辑覆盖(判定覆盖,条件覆盖,判定组合,条件组合,判定和条件组合) 路径覆盖 循环覆盖 不关心软件内部代码的逻辑,结构实现,只关心输入和输出 等价类划分法,边界值分

    2024年02月05日
    浏览(35)
  • 【职业人生】如何有效的在职场当中避免工作失误和提高个人发展

         《左传·宣公二年》:“人谁无过,过而能改,善莫大焉。”古往今来,多少人犯过错误。强大如“智绝”的诸葛孔明,也有街亭之失。职场人更是难免会在工作中出现失误。     在职场生涯当中避免不了在工作当中带来的失误,在这过程当中,我们应当要学会怎么去

    2024年02月08日
    浏览(44)
  • [office] excel成绩表格数据排名次的教程 #职场发展#知识分享#媒体

    excel成绩表格数据排名次的教程 Excel 中经常需要使用到 排名 次的技巧,成绩表格数据具体该如何排名呢?接下来是小编为大家带来的excel成绩表格数据排名次的教程,供大家参考。 步骤1:不管在学校还是各个统计领域,排名应用随处可见,如果排序会打乱原有次序,那么好多

    2024年02月21日
    浏览(40)
  • 再也不去字节跳动面试了,6年测开经验的真实面试经历.....

    前几天我朋友跟我吐苦水,这波面试又把他打击到了,做了快6年软件测试员。。。为了进大厂,也花了很多时间和精力在面试准备上,也刷了很多题。但题刷多了之后有点怀疑人生, 不知道刷的这些题在之后的工作中能不能用到,如果只是为面试而刷题是不是在浪费人生呢

    2023年04月25日
    浏览(45)
  • 【展会直击】华秋慕尼黑上海电子展精彩ing,助力电子产业高质量发展!

    01相见,如约而至 7月11日,电子行业盛会慕尼黑上海电子展盛大开幕,如7月的骄阳似火,本届慕尼黑上海电子展在2022年空档期后,展商及观众热情高涨,现场人气爆棚。据悉,本届展会面积扩大至10万平方米,国内外1650+企业参展,预计吸引观众达7万人次。 华秋,作为全球

    2024年02月16日
    浏览(49)
  • 10年测开经验面试35K公司后,吐血整理出高频面试题和答案!

    在当今竞争激烈的职场环境中,拥有丰富的测试开发经验已成为众多企业青睐的重要条件之一。而在面试过程中,高频面试题更是能够考察应聘者的实际能力和知识水平。本文作者具备10年的测试开发经验,并通过面试获得了35K公司的职位,特意整理出了高频面试题及其答案

    2024年02月21日
    浏览(50)
  • 突破职场竞争,引领未来发展:考取《研发效能(DevOps)工程师职业技术认证》

    就业形势堪忧,什么最有保障?考个“国家级”证书傍身吧! 工信部教考中心作为中国领先的行业技能认证机构,其颁发的认证证书不仅代表了个人在信息技术领域的专业能力,更可以录入工业和信息化技术技能人才数据库,这是一个重要的信息资源平台,它可以帮助企业和

    2024年02月05日
    浏览(47)
  • 五月最近一次面试,被阿里P8测开虐惨了...

    都说金三银四涨薪季,我是着急忙慌的准备简历—— 5年软件测试经验,可独立测试大型产品项目,熟悉项目测试流程... 薪资要求? 5年测试经验起码能要个20K吧 我加班肝了一页半简历,投出去一周,面试电话倒是不少,自信满满去面试,现场被问了这么几个问题——— “会

    2024年02月06日
    浏览(46)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包