前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >点开瞅瞅,再来几道Python面试题吧,Python面试题No20

点开瞅瞅,再来几道Python面试题吧,Python面试题No20

作者头像
梦想橡皮擦
发布2019-06-02 21:42:58
4180
发布2019-06-02 21:42:58
举报
文章被收录于专栏:Python3爬虫100例教程

本面试题题库,由公号:非本科程序员 整理发布

第1题:如何理解 Django 被称为 MTV 模式?

这个题就是面向对象设计和设计模式的开始。 你可能比较熟悉的模式叫做: MVC。说是 Model View Controller,而在 Django 中因为 Template 来处理视图展现,所以称为: MTV。 接下里会问到的就是分层的概念,有句话叫:“没有什么问题是不能通过增加一层解决的,如果有,那就再加一层。”当然还会有设计模式的一些原则等着你,比如开-闭原则、单一职责原则等。

第2题:解释下什么是 ORM 以及它的优缺点是什么?

ORM:Object Relational Mapping(对象关系映射),它做的事就是帮我们封装一下对数据库的操作,避免我们来写不太好维护的 SQL 代码。

  • 优点就是让我们写的代码更容易维护,因为里面不用夹杂着各种 SQL 代码。
  • 缺点是失去了 SQL 的灵活,并且越是通用的 ORM 框架,性能损耗会越大。

说到性能损耗,可以接着聊的是 Django 中的 raw sql,也就是说 Model.objects.raw 这个方法的使用,它的作用、原理、性能提升等。还可以继续聊另外一个老生常谈的问题:N+1 的问题。

第3题:Django 系统中如何配置数据库的长连接?

这涉及到 Django 如何处理数据库连接细节的问题。默认情况下对于每一个请求 Django 都会建立一个新的数据库连接。这意味着当请求量过大时就会出现数据库(MySQL)的 Too many connection 的问题,对于这个问题,在其他的语言框架中有连接池这样的东西来减少数据库的连接数,来提升连接的使用效率。而在 Django中,为了处理这一问题,增加了一个配置:

CONN_MAX_AGE,在 settings 的 DATABASES 配置中。配置了该选项后,Django 会跟数据库保持链接(时长取决于 CONN_MAX_AGE 设定的值 ),不再会针对每个请求都创建新的连接了。

但是需要注意的是,这跟数据库连接池的概念还不太一样。

第4题: 请解释一下python的线程锁Lock和Rlock的区别,以及你曾经在项目中是如何使用的?

从原理上来说:在同一线程内,对RLock进行多次acquire()操作,程序不会阻塞。 资源总是有限的,程序运行如果对同一个对象进行操作,则有可能造成资源的争用,甚至导致死锁 也可能导致读写混乱

第5题:字典、列表查询时的时间复杂度是怎样的?  

列表是序列,可以理解为数据结构中的数组,字典可以理解为数据结构中的hashmap,python中list对象的存储结构采用的是线性表,因此其查询复杂度为O(n)。 而dict对象的存储结构采用的是散列表(hash表),其在最优情况下查询复杂度为O(1)。 dict的占用内存稍比list大,会在1.5倍左右。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2019-05-29 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 本面试题题库,由公号:非本科程序员 整理发布
  • 第1题:如何理解 Django 被称为 MTV 模式?
  • 第2题:解释下什么是 ORM 以及它的优缺点是什么?
  • 第3题:Django 系统中如何配置数据库的长连接?
  • 第4题: 请解释一下python的线程锁Lock和Rlock的区别,以及你曾经在项目中是如何使用的?
  • 第5题:字典、列表查询时的时间复杂度是怎样的?  
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档