一、背景介绍
在计算机专业的面试中,面试官往往会针对者的专业知识和技术能力进行提问。是一道业务上BUG的面试题目,我们将通过案例分析的来解答这个。
二、
假设你正在参与一个在线书店项目的开发,项目要求用户可以在线购买书籍。系统设计了一个购物车功能,允许用户将书籍加入购物车,在结账时计算出总金额。是一个简单的购物车类的设计:
python
class ShoppingCart:
def __init__(self):
self.items = []
def add_item(self, item):
self.items.append(item)
def calculate_total(self):
return sum(item.price for item in self.items)
在这个类中,`item` 是一个包含书籍信息的对象,有一个属性 `price` 表示书籍的价格。面试官提出了
:在上述购物车类中,用户将同一本书多次加入购物车,计算总金额时会出现什么?请并提出解决方案。
三、分析
在上述购物车类中,用户将同一本书多次加入购物车,每次加入都会调用 `add_item` 方法将这本书的对象添加到 `items` 列表中。由于 `calculate_total` 方法是通过遍历 `items` 列表并计算每个对象的 `price` 属性来得到总金额的,同一本书多次加入购物车,其价格会被多次累加,导致计算出的总金额错误。
四、解答
针对上述我们可以从几个方面进行解答:
1. :当同一本书多次加入购物车时,`calculate_total` 方将这本书的价格多次累加到总金额中,导致总金额计算错误。
2. 解决方案:
– 去重:在 `add_item` 方法中加入去重逻辑,确保同一本书只被添加一次。
– 去重实现:可以使用一个集合(set)来存储已经添加过的书籍的标识(书籍的ID),在添加新书籍时检查该标识是否已存在。
是修改后的购物车类代码:
python
class ShoppingCart:
def __init__(self):
self.items = []
self.item_ids = set() # 用于存储已经添加过的书籍ID
def add_item(self, item):
if item.id not in self.item_ids:
self.items.append(item)
self.item_ids.add(item.id)
def calculate_total(self):
return sum(item.price for item in self.items)
3. 测试验证:在实际开发中,我们需要对修改后的代码进行充分的测试,以确保去重逻辑能够正确工作。是一些测试用例:
– 添加同一本书两次,确保只添加一次。
– 添加不同书籍,确保总金额计算正确。
– 添加同一本书多次,确保总金额计算正确。
通过上述分析和解决方案,我们可以有效地解决购物车类中由于重复添加同一本书而导致的BUG。仅体现了计算机专业者的技术能力,也展示了其在实际项目中解决的能力。
还没有评论呢,快来抢沙发~