项目实战のCollection和Map

2024-05-24 16:32
文章标签 实战 项目 map collection

本文主要是介绍项目实战のCollection和Map,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前面两篇文章讲了collection的list应用和set的应用

根据单列值和双列值分为collection和map然后根据是否有序将collection分为list和set。

Collection(单列值)

List(有序)

set(无序)

Map(键值对)

应用:collection适合进行显示和遍历,但是如果对数据进行操作的话用map的键值对很方便。以前只是做过相关的demo,现在项目中用到了,可以更淋漓尽致的理解理论知识,进行数据结构的选型:

购物车:包含很多个购物项的例子

package cn.itcast.shop.cart.vo;import cn.itcast.shop.product.vo.Product;
/** 购物项* **/
public class CartItem {public Product getProduct() {return product;}public int getCount() {return count;}public void setProduct(Product product) {this.product = product;}public void setCount(int count) {this.count = count;}public void setSubtotal(double subtotal) {this.subtotal = subtotal;}//小计自动计算public double getSubtotal() {return count*product.getShop_price();}private Product product;private int count;//某种商品数量private double subtotal;//小计}

package cn.itcast.shop.cart.vo;import java.util.Collection;
import java.util.LinkedHashMap;
import java.util.Map;/** 购物车* **/
public class Cart {//购物项集合:Map的key是商品pid,value是购物项。hashMap是无序的private Map<Integer, CartItem> map= new LinkedHashMap<Integer, CartItem>();//购物总金额private double total;//购物车的功能public Collection<CartItem> getCartItems(){return map.values();//返回值是一个collection,取得是map的值的集合}//1将购物项添加到购物车public void addCart(CartItem cartItem){/*判断购物车是否存在购物项*	*若存在:*		*数量增加*		*总计+=购物项*	*若不存在*		*向map中增加购物项*		*总计+=购物项* * * *///获得商品idInteger pid= cartItem.getProduct().getPid();//判断购物车中是否存在购物项if(map.containsKey(pid)){//存在CartItem _cartItem=map.get(pid);//原来的购物项_cartItem.setCount(_cartItem.getCount()+cartItem.getCount());}else{//不存在map.put(pid, cartItem);}total+=cartItem.getSubtotal();}public double getTotal() {return total;}//2从购物车移除购物项public void removeCart(Integer pid){//将购物项移除购物车map.remove()的时候返回的是移除的购物项CartItem cartItem= map.remove(pid);//总结-=移除的购物项的小计total-=cartItem.getSubtotal();}//3清空购物车public void clearCart(){//将所有的购物项清空map.clear();//将总计设置成0total=0;}
}




这篇关于项目实战のCollection和Map的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/998929

相关文章

用Microsoft.Extensions.Hosting 管理WPF项目.

首先引入必要的包: <ItemGroup><PackageReference Include="CommunityToolkit.Mvvm" Version="8.2.2" /><PackageReference Include="Microsoft.Extensions.Hosting" Version="8.0.0" /><PackageReference Include="Serilog

eclipse运行springboot项目,找不到主类

解决办法尝试了很多种,下载sts压缩包行不通。最后解决办法如图: help--->Eclipse Marketplace--->Popular--->找到Spring Tools 3---->Installed。

vue项目集成CanvasEditor实现Word在线编辑器

CanvasEditor实现Word在线编辑器 官网文档:https://hufe.club/canvas-editor-docs/guide/schema.html 源码地址:https://github.com/Hufe921/canvas-editor 前提声明: 由于CanvasEditor目前不支持vue、react 等框架开箱即用版,所以需要我们去Git下载源码,拿到其中两个主

React+TS前台项目实战(十七)-- 全局常用组件Dropdown封装

文章目录 前言Dropdown组件1. 功能分析2. 代码+详细注释3. 使用方式4. 效果展示 总结 前言 今天这篇主要讲全局Dropdown组件封装,可根据UI设计师要求自定义修改。 Dropdown组件 1. 功能分析 (1)通过position属性,可以控制下拉选项的位置 (2)通过传入width属性, 可以自定义下拉选项的宽度 (3)通过传入classN

vue3项目将所有访问后端springboot的接口统一管理带跨域

vue3项目将所有访问后端springboot的接口统一管理带跨域 一、前言1.安装Axios2.创建Axios实例3.创建API服务文件4.在组件中使用API服务 二、跨域三、总结 一、前言 在Vue 3项目中,统一管理所有访问后端Spring Boot接口的最佳实践是创建一个专门的API服务层。这可以让你的代码更加模块化、可维护和集中管理。你可以使用Axios库作为HTT

vscode-创建vue3项目-修改暗黑主题-常见错误-element插件标签-用法涉及问题

文章目录 1.vscode创建运行编译vue3项目2.添加项目资源3.添加element-plus元素4.修改为暗黑主题4.1.在main.js主文件中引入暗黑样式4.2.添加自定义样式文件4.3.html页面html标签添加样式 5.常见错误5.1.未使用变量5.2.关闭typescript检查5.3.调试器支持5.4.允许未到达代码和未定义代码 6.element常用标签6.1.下拉列表

PyTorch模型_trace实战:深入理解与应用

pytorch使用trace模型 1、使用trace生成torchscript模型2、使用trace的模型预测 1、使用trace生成torchscript模型 def save_trace(model, input, save_path):traced_script_model = torch.jit.trace(model, input)<

局域网内vue2 配置本地IP地址访问项目

在日常开发中同事可能需要访问你的前端项目,可以通过配置实现通过ip访问 一.首先找到config文件夹目录下的 index.js文件             将此处的host的值修改为0.0.0.0(即 host: 0.0.0.0) // Various Dev Server settings//host: 'localhost' //将localhost进行替换成 0.0.0.0host:

把Tiled中做出的地图弄到项目中~~就是懒,为了以后直接复制写过来

1.现在.h中声明private: cocos2d::CCSprite* ninja; cocos2d::CCTMXTiledMap*  tileMap; 然后.cpp中加入tileMap = CCTMXTiledMap::create("MyTileMap.tmx"); CCTMXLayer* backLayer = tileMap->layerNamed("Tile L

CocoStudio中的UI弄到项目中

1、   与alpah版相比,beta版中更改了创建的脚本,可以自定义项目的目录,接下来我们看看。先上图: 2、项目创建     找到 cocos2dx根目录/tools/project-creator/create_project.py文件,双击运行即可。如果未安装python环境,则需要下载安装。脚本运行起来,会显示一个图形界面,用以设置相应的项目