高级软件工程师面试题(更新中)


Senior software engineer

Mar 2, 2016

高级软件工程师

下面的面试题不分语言,适用于所有编程语言,更多偏向设计。

设计一个分类功能

该功用于行政区域划分,商品分类,等等 例如中国->广东-深圳 …..

要求:

  1. 无限极分类,层次深度不限
  2. 快速检索,不能使用递归
  3. 只能使用一个数据库表实现
  4. 可以生成树形目录

商品以及属性功能的设计

一个商品有很多属性,例如尺寸,颜色这些属性有固定的值,而另一些属性如重量,体积是需要填写具体数值的,并且还有对应的单位。

要求:

  1. 商品分类(上一个问题中已经实现)
  2. 商品属性,有多个属性,且数目不确定,所以需要设计成可以无限添加
  3. 商品属性即可下拉选择,也可以填写具体数值

问题:

  1. 商品搜索怎么解决,包含商品名称,属性,属性值,描述的搜索
  2. 商品的库存怎么设计
  3. 分类搜索,怎样列出所有子分类以及子分类下的所有分类(无限深度)

用户注册的功能需求

场景模拟: 用户开户注册时常常填写了一部分资料,就离开了,有几种情况

  1. 用户放弃注册
  2. 网络连接失败
  3. 提交出错
  4. 其他链接吸引了用户点击

等等原因……

需求:

  1. 要求记录用户填写资料,再次回来(数日/数月后)点击注册的时候,用户不用重新填写所有资料,只需完成未完成的部分即可。
  2. 重要资料例如手机,电邮,即时通讯号码等等需要记录到数据库,已被公司回访客户。
  3. 在用户成功注册后应该删除之前保留在数据库中的手机,电邮,即时通讯等等。

请问如何实现?资料怎样保存?


事务处理相关

简述什么是事务处理?

在不能使用数据库的事务处理以及锁(表锁/行级锁)时,怎么保持数据一致性?怎么解决数据库并发操作?

  1. 怎样解决避免多个用户读读取同一条数据记录?
  2. 怎样避免多个用户更新同一条数据

开发框架

  1. 简述 MVC 原理以及实现
  2. 怎样实现 URL 路由
  3. 怎样实现类,方法访问权限控制

请问下面代码怎么实现?

用你最熟悉的语言实现。

DB db = new DB() db.select(new field("name","age"...)).from("user").where(new And("xxx=xx", "xxx=xxx")).limit(10).offset(10).orderby("id",DESC)

进程与多线程

  1. 什么是阻塞,什么是非阻塞?
  2. 什么是同步,什么是异步?
  3. 什么情况下使用线程锁?
  4. 进程与线程的区别?
  5. 进程间通信有那几种,线程通信有那几种,以及各自的优势?

消息队列

消息有哪些瓶颈?


CDN应用

  1. CDN 缓存的原理?
  2. CDN 都可能缓存那些内容?
  3. 网站首页90%的内容是静态的,但是用户登录状态,消息状态是动态的怎么解决?
  4. JSON 可能缓存吗?
  5. 浏览器缓存与CDN缓存的关系,怎样实现用户浏览器与CDN同时缓存?

先写到这里,后面会不断更新。。。。。


转载于:https://my.oschina.net/neochen/blog/648979

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值