基于Java+Springboot+Vue前后端分离的商品库存销售管理系统

✌全网粉丝20W+,csdn特邀作者、博客专家、CSDN新星计划导师、java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌

🍅文末获取项目下载方式🍅


一、项目背景介绍:

当今社会,随着电子商务行业的快速发展和商品交易的日益增长,对商品进销存的管理需求也愈加迫切。传统的手工记录和管理方式已经无法满足高效、准确的需求,因此,研发一款基于Java+Springboot+Vue前后端分离的商品进销存管理系统具有重要的实际意义。

研究背景主要体现在以下几个方面:

提升管理效率:传统的商品进销存管理方式依赖于人工的物料统计、录入和查询等操作,存在着大量的人力资源浪费、信息不及时等问题。而基于Java+Springboot+Vue前后端分离的系统,能够通过自动化的数据处理和快速的查询功能,大幅提升管理效率,提供实时、准确的数据支持。

降低人为错误率:手工记录和处理数据往往容易出现疏漏、错误等问题,给企业带来了诸多风险,尤其是在大规模商品交易和库存管理时。而使用自动化系统进行商品进销存管理,可以有效减少人为因素的干扰,降低错误率,提高数据的准确性和可靠性。

支持决策分析:企业在商品进销存管理过程中,需要根据实时数据对市场需求、供应链等进行分析和决策。基于Java+Springboot+Vue前后端分离的系统,可以提供丰富的储备数据和灵活的数据分析工具,帮助企业进行市场预测、库存规划和销售策略等方面的决策。

实现信息共享与协作:商品进销存管理涉及到多个部门和角色之间的协作与沟通,传统的方式往往存在信息孤岛和沟通不畅的问题。而基于Java+Springboot+Vue前后端分离的系统,可以实现多部门间的信息共享和协作,提高组织内部工作效率,促进跨部门合作。

综上所述,通过研发基于Java+Springboot+Vue前后端分离的商品进销存管理系统,可以充分利用现代化信息技术手段,提升管理效率、降低错误率、支持决策分析、实现信息共享与协作,为企业实现精细化管理、高效运营提供有力支撑。

二、项目技术简介:

  1. JAVA:Java是一门面向对象编程语言,不仅吸收了C++语言的各种优点,还摒弃了C++里难以理解的多继承、指针等概念,因此Java语言具有功能强大和简单易用两个特征。Java语言作为静态面向对象编程语言的代表,极好地实现了面向对象理论,允许程序员以优雅的思维方式进行复杂的编程。
  2. Vue:Vue (发音为 /vjuː/,类似 view) 是一款用于构建用户界面的JavaScript框架。它基于标准HTML、CSS和JavaScript构建,并提供了一套声明式的、组件化的编程模型,帮助开发者高效地开发用户界面。
    Vue是一个独立的社区驱动的项目,它是由尤雨溪在2014年作为其个人项目创建, 是一个成熟的、经历了无数实战考验的框架,它是目前生产环境中使用最广泛的JavaScript框架之一,可以轻松处理大多数web应用的场景,并且几乎不需要手动优化,并且Vue完全有能力处理大规模的应用。
  3. Element-UI:Element,一套为开发者、设计师和产品经理准备的基于 Vue 2.0 的桌面端组件库。
  4. SpringBoot:Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Spring应用的初始搭建以及开发过程。该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置。通过这种方式,Spring Boot致力于在蓬勃发展的快速应用开发领域(rapid application development)成为领导者。
  5. Mybatis:MyBatis本是apache的一个开源项目iBatis,2010年这个项目由apache software foundation迁移到了google code,并且改名为MyBatis。2013年11月迁移到Github。
    iBATIS一词来源于“internet”和“abatis”的组合,是一个基于Java的持久层框架。iBATIS提供的持久层框架包括SQL Maps和Data Access Objects(DAOs)。

三、系统功能模块介绍:

请添加图片描述

四、数据库设计:

1:bjmd_note(bjmd_note)

字段名类型默认值列注释
idbigintNULL
user_namevarcharNULL用户名
titlevarcharNULL名称
contenttextNULL笔记内容
create_timedatetimeNULL创建时间
updata_timedatetimeNULL修改时间
remarkvarcharNULL备注

2:ckmd_depository(ckmd_depository)

字段名类型默认值列注释
idbigintNULLid
numbervarcharNULL仓库编号
namevarcharNULL仓库名称
headvarcharNULL仓库负责人
store_phonevarcharNULL仓库电话
addressvarcharNULL仓库地址
stock_totalbigintNULL库存总容量
surplusbigintNULL剩余容量
areavarcharNULL面积单位
statusintNULL0 正常 1 停用
build_datedatetimeNULL创建时间
remarkvarcharNULL备注

3:ckmd_depository_in(ckmd_depository_in)

字段名类型默认值列注释
idbigintNULLid
source_numberintNULL来源 可有也可无
in_idbigintNULL入库编号
depositoryvarcharNULL入库仓库名
shop_namevarcharNULL入库商名
shop_pricedecimalNULL入库商品单价
shop_numberbigintNULL入库商品数量
price_totaldecimalNULL入库商品总价
specsvarcharNULL单位规格 [个斤盒]
datedatetimeNULL入库日期
in_uservarcharNULL入库人
shop_suppliervarcharNULL供应商名
is_inspectionintNULL0已质检 1 未质检
statusintNULL0 已入库 1 未入库
create_datedatetimeNULL创建时间

4:ckmd_depository_out(ckmd_depository_out)

字段名类型默认值列注释
idbigintNULL出库id
source_numberbigintNULL来源 id
out_idbigintNULL出库编号
depositoryvarcharNULL出库仓库
shop_namevarcharNULL商品名称
shop_pricedecimalNULL出库价格
shop_numberbigintNULL商品数量
total_pricedecimalNULL商品总价
specsvarcharNULL规格
datedatetimeNULL出库时间
out_uservarcharNULL出库用户
shop_suppliervarcharNULL客户姓名
statusintNULL是否出库 0 出库 1不出库
out_inspectionintNULL0 审核 1表示未审核
create_datedatetimeNULL创建时间

5:‘库存清单’(ckmd_stock)

字段名类型默认值列注释
idbigintNULL序号 商品库存id
shopvarcharNULL商品
shop_typevarcharNULL商品类型
quantitybigintNULL库存量
specesvarcharNULL规格 斤 、千克、个
depositoryvarcharNULL仓库名
addressvarcharNULL地址
create_timedatetimeNULL创建时间
update_timedatetimeNULL修改时间
remarkvarcharNULL备注

6:jcmd_customer(jcmd_customer)

字段名类型默认值列注释
idbigintNULLid
namevarcharNULL客户姓名
phonevarcharNULL客户电话
addressvarcharNULL客户地址
emailvarcharNULL客户邮箱
faxvarcharNULL传真
branchvarcharNULL银行名
branch_novarcharNULL卡号
build_datedatetimeNULL创建时间
update_timedatetimeNULL更新时间
remarkvarcharNULL备注

7:jcmd_shop(jcmd_shop)

字段名类型默认值列注释
idbigintNULLid
namevarcharNULL商品名
parent_idbigintNULL商品科类
shop_numberbigintNULL商品数量
specsvarcharNULL规格
market_pricedecimalNULL市场价格
build_datedatetimeNULL创建时间
update_datedatetimeNULL更新时间
remarkvarcharNULL备注

8:jcmd_shop_type(jcmd_shop_type)

字段名类型默认值列注释
idintNULLid
class_idbigintNULL商品种类编号
shop_typevarcharNULL商品类型
infovarcharNULL商品信息

9:jcmd_supplier(jcmd_supplier)

字段名类型默认值列注释
idbigintNULLid
supplier_namevarcharNULL供应商名
headvarcharNULL负责人
phonevarcharNULL供应商电话
addressvarcharNULL地址
shop_namevarcharNULL商品名称
branchvarcharNULL银行
branch_accountvarcharNULL银行账号
supplier_proxyvarcharNULL供应商法人代表
create_datedatetimeNULL创建时间
update_timedatetimeNULL更新时间
othervarcharNULL其他

10:jxmd_purchase(jxmd_purchase)

字段名类型默认值列注释
idbigintNULLid
numbervarcharNULL采购编号
purchase_uservarcharNULL采购人
shopvarcharNULL采购商品
shop_typevarcharNULL商品所属类
suppliervarcharNULL采购供应商
quantitybigintNULL采购数量
pricedecimalNULL采购价格
total_pricedecimalNULL总价
timedatetimeNULL采购时间
statusintNULL状态 0 完成 1进行中
remarkvarcharNULL备注
specsvarcharNULL单位规格 个斤盒
is_destroyintNULL0存在 1退货,退货后不显示,可增加查询按钮
imagesvarcharNULL图片地址
value_attributeintNULL增值比

11:jxmd_purchase_exit(jxmd_purchase_exit)

字段名类型默认值列注释
idbigintNULLid
numbervarcharNULL采购编号
exit_numbervarcharNULL退采编号
numintNULL退采数量
pricedecimalNULL单价
total_pricedecimalNULL总价
timedatetimeNULL日期
reasonvarcharNULL原因
statusintNULL状态 0 完成 1进行中
remarkvarcharNULL备注
specsvarcharNULL单位规格 个斤盒

12:‘销售表’(jxmd_sale)

字段名类型默认值列注释
idbigintNULL主键
sale_NumbervarcharNULL销售编号
sale_uservarcharNULL销售人
shopvarcharNULL销售商品
shop_typevarcharNULL商品所属类
suppliervarcharNULL销售客户,需要改成客户英文名
numbigintNULL数量
specsvarcharNULL单位规格 个斤盒
pricedecimalNULL价格
total_pricedecimalNULL总价
timedatetimeNULL销售时间
statusintNULL状态 0 完成 1进行中
remarkvarcharNULL备注

13:‘销售退货表’(jxmd_sale_exit)

字段名类型默认值列注释
idbigintNULL主键
numbervarcharNULL销售编号
exit_numbervarcharNULL退购编号
numbigintNULL退购数量
pricedecimalNULL价格
total_pricedecimalNULL总价
timedatetimeNULL日期
reasonvarcharNULL退购原因
statusintNULL状态 0 完成 1进行中
remarkvarcharNULL备注

14:qjmd_table_list(qjmd_table_list)

字段名类型默认值列注释
idbigintNULL
tableNamevarcharNULL表名
mdvarcharNULL业务模块
describevarcharNULL描述
sortbigintNULL表的顺序即业务-菜单显示顺序
childrenbigintNULL模块业务的子业务显示顺序
remarkvarcharNULL备注

15:xtmd_admin(xtmd_admin)

字段名类型默认值列注释
idbigintNULL用户id
deptvarcharNULL部门id或者名称
user_namevarcharNULL账户
true_namevarcharNULL真实姓名
passwordvarcharNULL密码
saltvarcharNULL盐值
iconvarcharNULL头像路径
statusintNULL0正常 1停用
e_mailvarcharNULL邮箱
phonevarcharNULL电话
create_timedatetimeNULL创建时间
login_ipvarcharNULL最后登录ip
login_datedatetimeNULL最后登录时间
sexintNULL0男 1女
remarkvarcharNULL备注

16:xtmd_admin_dept_relation(xtmd_admin_dept_relation)

字段名类型默认值列注释
idbigintNULL
role_idbigintNULL角色id
dept_idbigintNULL部门id

17:xtmd_admin_role_relation(xtmd_admin_role_relation)

字段名类型默认值列注释
idbigintNULL
admin_idbigintNULL用户id
role_idbigintNULL角色id

18:‘部门表’(xtmd_dept)

字段名类型默认值列注释
idbigintNULLid
parent_idbigintNULL父部门id
dept_namevarcharNULL部门名称
order_numvarcharNULL显示顺序
leadervarcharNULL负责人
phonevarcharNULL联系电话
statusintNULL部门状态(0正常 1停用)
del_flagcharNULL删除标志(0代表存在 2代表删除)
create_byvarcharNULL创建者
create_timedatetimeNULL创建时间
update_byvarcharNULL更新者
update_timedatetimeNULL更新时间

19:xtmd_log(xtmd_log)

字段名类型默认值列注释
idintNULL主键
namevarcharNULL用户名
operationvarcharNULL操作
methodvarcharNULL请求方法
paramsvarcharNULL请求参数
timebigintNULL执行时长(毫秒)
create_datedatetimeNULL创建时间

20:‘后台菜单表’(xtmd_menu)

字段名类型默认值列注释
idbigintNULLid
titlevarcharNULL菜单名称 label
parent_idbigintNULL父级ID
levelintNULL菜单级数
sortintNULL菜单排序
namevarcharNULL前端名称
iconvarcharNULL前端图标
create_timedatetimeNULL创建时间
hiddenintNULL状态 0正常 1隐藏
urlvarcharNULL访问地址
pathvarcharNULLvue路径

21:‘角色信息表’(xtmd_role)

字段名类型默认值列注释
role_idbigintNULL角色ID
role_namevarcharNULL角色名称
descriptionvarcharNULL角色描述
statusintNULL角色状态(0正常 1停用)
del_flagcharNULL删除标志(0代表存在 1代表删除)
build_uservarcharNULL创建者
create_timedatetimeNULL创建时间
update_uservarcharNULL更新者
update_timedatetimeNULL更新时间
remarkvarcharNULL备注

22:xtmd_role_menu_relation(xtmd_role_menu_relation)

字段名类型默认值列注释
idbigintNULL
role_idbigintNULL角色id
menu_idbigintNULL菜单id

五、功能模块:

  1. 运营驾驶舱:在运营驾驶舱可以看到整个系统的数据统计信息

    image-20231020090932829

  2. 客户资料:用户可以在客户资料模块看到系统内的客户资料信息并且还能对其进行管理与新增等操作

    image-20231020090950137

  3. 商品资料:用户可以在客户资料模块看到系统内的商品资料信息并且还能对其进行管理与新增等操作

    image-20231020091002158

  4. 部门资料:用户可以在客户资料模块看到系统内的部门资料信息并且还能对其进行管理与新增等操作

    image-20231020091040690

  5. 供应商资料:用户可以在客户资料模块看到系统内供应商资料信息并且还能对其进行管理与新增等操作

    image-20231020091051677

  6. 笔记:用户可以在笔记模块添加自己的笔记信息,在后续可以继续进行查看

    image-20231020091109092

  7. 采购:

    入库:弹窗选择入库仓库,判断容量是否充足 充足则后台生成入库清单,并更新当前状态为完成
    退货:判断当前状态 完成则 {弹框 取消采购的原因,后台生成出库清单(此时需要仓库人员审核) } 否则直接退货成功,更改状态为完成
    质检逻辑: 判断对应仓库是否有充足的库存

    image-20231020091118318

  8. 采购退货:

    image-20231020091125987

  9. 销售:

    出库:出库成功更新状态为完成且-备注 ,生成出库清单 某个仓库的商品及其数量存在且充足 否则失败
    回收:弹框出 客户退货原因 更新采购单的备注及其状态为完成,后台生成入库清单(此时需要仓库人员审核)

    image-20231020091133711

  10. 销售退货:

    回收:

    生成销售退货单,并添加退货原因 销售单是进行中则 销售退货单状态为完成 ;若销售单是完成 0,则生成的销售退货单是进行中

    1.生成入库清单
    2.判断是否出库(出库-就需要生成:【销售退货+入库单】,未出库则直接生成:【销售退货】),
    判断其状态是否完成 (完成:表示已到客户手中,需要【入库清单,销售退货单】; 未完成:直接生成【销售退货单】)

    增加销售单后 状态为:进行中 出库:状态为完成 并且生成出库清单 ------销售环节结束–>转为快递送货环节

    回收:

    进行中:则未生成出库清单 完成则是生成的出库清单

    完成的意思是已经入库了 那么就从入库清单中查对应的信息出来然后再生成出库信息。

    image-20231020091139091

  11. 员工管理:用户可以在员工管理模块对员工进行管理,还能给他们分配不同的员工角色,不同的角色可以拥有不同的菜单

    image-20231020091148371

  12. 角色管理:用户可以在员工管理模块对员工进行管理,还能给他们分配不同的员工角色,不同的角色可以拥有不同的菜单,菜单对应的角色管理中的不同的角色

    image-20231020091159520

  13. 部门管理:

    image-20231020091205564

  14. 系统日志:

    image-20231020091212926

六、代码示例:

/**
生成验证码*/
@GetMapping("/captchaImage")
public AjaxResult getCode(HttpServletResponse response) throws IOException
{AjaxResult ajax = AjaxResult.success();boolean captchaEnabled = configService.selectCaptchaEnabled();ajax.put("captchaEnabled", captchaEnabled);if (!captchaEnabled){return ajax;}// 保存验证码信息String uuid = IdUtils.simpleUUID();String verifyKey = CacheConstants.CAPTCHA_CODE_KEY + uuid;String capStr = null, code = null;BufferedImage image = null;// 生成验证码String captchaType = RuoYiConfig.getCaptchaType();if ("math".equals(captchaType)){String capText = captchaProducerMath.createText();capStr = capText.substring(0, capText.lastIndexOf("@"));code = capText.substring(capText.lastIndexOf("@") + 1);image = captchaProducerMath.createImage(capStr);}else if ("char".equals(captchaType)){capStr = code = captchaProducer.createText();image = captchaProducer.createImage(capStr);}redisCache.setCacheObject(verifyKey, code, Constants.CAPTCHA_EXPIRATION, TimeUnit.MINUTES);// 转换流信息写出FastByteArrayOutputStream os = new FastByteArrayOutputStream();try{ImageIO.write(image, "jpg", os);}catch (IOException e){return AjaxResult.error(e.getMessage());}ajax.put("uuid", uuid);ajax.put("img", Base64.encode(os.toByteArray()));return ajax;
}
/**
通用的本地文件上传@param multipartFile 文件对象
@return 文件访问链接URL/
@PostMapping("/file")
public SimpleResponse uploadImg(@RequestParam("file") MultipartFile file) {// 文件后缀String suffix = file.getOriginalFilename().substring(file.getOriginalFilename().lastIndexOf(".") + 1);File savePathFile = new File(newTomcatFolder);if (!savePathFile.exists()) {// 若不存在该目录,则创建目录savePathFile.mkdir();}// 通过UUID生成唯一文件名String filename = UUID.randomUUID() + "." + suffix;try {// 将文件保存指定目录file.transferTo(new File(newTomcatFolder + filename));} catch (Exception e) {e.printStackTrace();return SimpleResponse.error("保存文件异常");}// 返回访问链接return SimpleResponse.success(newTomcatHost + filename);
}
/*
用户登录*/
@PostMapping("/login")
public ReturnMsg manageLogin(@RequestBody Map<String, String> param) {if (StrUtil.isEmpty(param.get("username")) || StrUtil.isEmpty(param.get("password"))) {return ReturnMsg.error("用户名或密码错误!");}ManageDTO manageDTO = new ManageDTO();manageDTO.setUserName(param.get("username"));manageDTO.setPassWord(param.get("password"));QueryWrapper manageDTOQueryWrapper = new QueryWrapper<>(manageDTO);manageDTOQueryWrapper.last("limit 1");ManageDTO adminDTOS = manageService.getOne(manageDTOQueryWrapper);if (adminDTOS == null) return ReturnMsg.error("用户名或密码错误!");Map<String, Object> map = new HashMap<>();map.put("avatar", StrUtil.isNotBlank(adminDTOS.getPhotoImg()) ? adminDTOS.getPhotoImg() : "https://wpimg.wallstcn.com/f778738c-e4f8-4870-b634-56703b4acafe.gif");map.put("introduction", adminDTOS.getName() + ",你好!");map.put("name", adminDTOS.getName());map.put("roles", Arrays.asList("admin"));map.put("type", adminDTOS.getStatus());Map<String, String> returnMap = new HashMap<>();String uuid = UUID.randomUUID().toString();returnMap.put("token", uuid);userInfoMap.put(uuid, JSON.toJSONString(map));return ReturnMsg.ok(returnMap);
}

七、项目总结:

通过对基于Java+Springboot+Vue前后端分离的商品进销存管管理系统的开发,让我深刻明白开发一个程序软件需要经历的流程,当确定要开发一个基于Java+Springboot+Vue前后端分离的商品进销存管管理系统的程序时,
我在开发期间,对其功能进行合理的需求分析,然后才是程序软件的功能的框架设计,数据库的实体与数据表设计,
程序软件的功能详细界面实现,以及程序的功能测试等进行全方位的细致考虑,虽然在此过程中,各个环节都遇到了大大小小的困难,但是通过对这些问题进行反复的分析,深入的思考,
借助各种相关文献资料提供的方法与解决思路成功解决面临的各个问题,最后成功的让我开发的基于Java+Springboot+Vue前后端分离的商品进销存管管理系统得以正常运行。
基于Java+Springboot+Vue前后端分离的商品进销存管管理系统在功能上面是基本可以满足用户对系统的操作,但是这个程序软件也有许多方面是不足的,因此,在下一个时间阶段,有几点需要改进的地方需要提出来,它们分别是:
(1)操作页面可以满足用户简易操作的要求,但是在页面多样化设计层面上需要把一些比较丰富的设计结构考虑进来。
(2)程序软件的总体安全性能需要优化,例如程序的退出安全性,以及程序的并发性等问题都需要进行安全性升级,让开发的基于Java+Springboot+Vue前后端分离的商品进销存管管理系统中的相关网站更贴合。
(3)需要对程序的数据结构方面,程序的代码方面等进行优化,让运行起来的程序可以保持稳定运行,也让程序能够保证短时间内处理相关事务,节省处理事务的时间,提高事务处理的效率,
同时对服务器上资源占用的比例进行降低。
基于Java+Springboot+Vue前后端分离的商品进销存管管理系统的开发一方面是对自身专业知识技能进行最终考核,另一方面也是让自己学会独立解决程序开发过程中所遇到的问题,掌握将理论知识运用于程序开发实践的方法。
基于Java+Springboot+Vue前后端分离的商品进销存管管理系统的开发最终目标就是让系统更具人性化,同时在逻辑设计上,让系统能够更加的严谨。

八、源码获取:

大家点赞、收藏、关注、评论啦 、查看👇🏻👇🏻👇🏻获取项目下载链接,博主联系方式👇🏻👇🏻👇🏻

链接点击直达:下载链接

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/113314.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Python--循环中的两大关键词 break 与 continue

在Python循环中&#xff0c;经常会遇到两个常见的关键词&#xff1a;break 与 continue break&#xff1a;代表终止整个循环结构 continue&#xff1a;代表中止当前本次循环&#xff0c;继续下一次循环 break&#xff1a; 英 /breɪk/ v. 打破&#xff0c;打碎&#xff0c…

看《软能力》的读后感

最近在图书大夏看了一本书的一部分&#xff0c;书名是《软能力》。本人看到了几个有意思的观点。一是接一些兼职项目。 二是分享自己的技术&#xff0c;让同事能干自己的工作&#xff0c;让自己的工作变得别人也能干&#xff0c;才有机会让自己的职位提升。 三是让手动操作变…

使用imx 8m 测试matter协议功能

参考网址&#xff1a; https://github.com/nxp-imx/meta-matter 请使用Ubuntu-20.04。18.04python版本太老 注意repo会出现此报错&#xff0c;可以无视&#xff1a; git checkout imx_matter_2023_q3 这一步在这个目录下操作 项目交流、学习、开发&#xff0c;欢迎私信。

【RNA biology】RNA的多功能性与早期生命进化

文章目录 RNARNA plays core functions in Central Dogma of BiologyrRNAsnRNA RNA worldReplication催化作用感知环境变化并作出响应 来自Manolis Kellis教授&#xff08;MIT计算生物学主任&#xff09;的课 油管链接&#xff1a;6.047/6.878 Lecture 7 - RNA folding, RNA wo…

TCP和UDP的原理及其区别(三次握手、四次挥手)

TCP和UDP都是在传输层上工作的协议&#xff0c;用于在网络中传输数据。 1、TCP和UDP之间的区别 TCP和UDP的主要区别在于它们提供的服务和特性。TCP提供可靠的、有序的、基于连接的数据传输&#xff0c;适用于对数据完整性和可靠性要求较高的应用&#xff08;邮件、短信&#xf…

Java多线程编程

文章目录 Java多线程编程线程概念线程常用方法线程创建线程优先级终止线程等待线程线程状态线程安全synchronizedvolatilewait和notify方法ThreadLocal的使用标准库线程安全类 Java多线程编程 线程概念 线程概念&#xff1a; 一个线程就是一个 “执行流”. 每个线程之间都可…

Springboot-案例 增删改查二

准备 前端程序、后端工程&#xff08;web/mybatis/mysql/lombok&#xff09;、数据库 开发规范 GET&#xff1a;查询 POST&#xff1a;新增 PUT&#xff1a;修改 DELETE&#xff1a;删除 Result.java Data NoArgsConstructor AllArgsConstructor public class Result {pri…

偶数科技发布实时湖仓数据平台Skylab 5.3版本

近日&#xff0c; 偶数发布了最新的实时湖仓数据平台 Skylab 5.3 版本。Skylab包含七大产品&#xff0c;分别为云原生分布式数据库 OushuDB、数据分析与应用平台 Kepler、数据资产管理平台 Orbit、自动化机器学习平台 LittleBoy、数据工厂 Wasp、数据开发与调度平台 Flow、系统…

鸿蒙HarmonyOS应用开发:扫描仪文件扫描

华为鸿蒙HarmonyOS已经发展到4.0&#xff0c;使用ArkTS作为开发语言。这篇文章结合Dynamsoft Service开发一个简单的鸿蒙应用&#xff0c;用来获取办公室里连接PC的扫描仪(惠普&#xff0c;富士通&#xff0c;爱普生&#xff0c;等)&#xff0c;把文档扫描到手机里。 准备工作…

DevExpress WPF Pivot Grid组件,可轻松实现多维数据分析!(二)

在上文中&#xff08;点击这里回顾>>&#xff09;我们主要为大家介绍了DevExpress WPF Pivot Grid组件的超快速枢轴分析功能、Microsoft分析服务等&#xff0c;本文将继续介绍图表透视数据的处理、MVVM支持等。欢迎持续关注我们&#xff0c;探索更多新功能哦~ P.S&#…

【异步爬虫】requests和aiohttp中代理IP的使用

前言 在进行爬虫开发时&#xff0c;我们常常需要使用代理IP来隐藏自己的真实IP地址&#xff0c;以避免被一些网站限制或封禁。requests和aiohttp是两个非常常用的工具&#xff0c;本文将分别介绍如何在它们中使用代理IP&#xff0c;希望可以帮助大家更好地进行异步爬虫开发。 …

电容屏物体识别手工制作

电容屏识别物体效果2 电容屏识别物体效果1 电容屏识别物体效果3 电容屏识别物体效果4 电容识别物理效果5 我们感兴趣的是找到让我们的平面屏幕与物理三维物体和表面交互的方法。 触摸屏无处不在&#xff0c;成千上万的应用程序中有多种设备和屏幕格式&#xff0c;但我们只找到…

STM32的hex文件格式的分析

前言 最近研究Bootloader&#xff0c;通过串口实现STM32程序的更新。需要学习了解STM32的Hex文件格式。在这进行一下总结。 HEX文件格式 我们通过文本形式打开hex文件&#xff0c;可以看到&#xff1a; 这一行就是一条指令数据&#xff0c;这里对数据帧格式进行说明&#xff…

elementui select组件下拉框底部增加自定义按钮

elementui select组件下拉框底部增加自定义按钮 el-select组件的visible-change 事件&#xff08;下拉框出现/隐藏时触发&#xff09; <el-selectref"select":value"value"placeholder"请选择"visible-change"visibleChange">&…

Kotlin笔记(六):泛型的高级特性

前面学习了Kotlin中的泛型的基本用法,跟Java中的泛型大致相同&#xff0c;Kotlin在泛型方面还提供了不少特有的功能&#xff0c;掌握了这些功能&#xff0c;你将可以更好玩转Kotlin&#xff0c;同时还能实现一些不可思议的语法特性&#xff0c;那么我们自然不能错过这部分内容了…

2023-10-19 LeetCode每日一题(同积元组)

2023-10-19每日一题 一、题目编号 1726. 同积元组二、题目链接 点击跳转到题目位置 三、题目描述 给你一个由 不同 正整数组成的数组 nums &#xff0c;请你返回满足 a * b c * d 的元组 (a, b, c, d) 的数量。其中 a、b、c 和 d 都是 nums 中的元素&#xff0c;且 a ! b…

LiveGBS流媒体平台GB/T28181常见问题-安全控制HTTP接口鉴权勾选流地址鉴权后401Unauthorized如何播放调用接口

LiveGBS流媒体平台GB/T28181常见问题-安全控制HTTP接口鉴权勾选流地址鉴权后401 Unauthorized如何播放调用接口&#xff1f; 1、安全控制1.1、HTTP接口鉴权1.2、流地址鉴权 2、401 Unauthorized2.1、携带token调用接口2.1.1、获取鉴权token2.1.2、调用其它接口2.1.2.1、携带 Co…

DNS压测工具-dnsperf的安装和使用(centos)

系统调优 系统调优脚本&#xff0c;保存为sh文件&#xff0c;chmod提权后执行即可 #!/bin/sh #系统全局允许分配的最大文件句柄数&#xff1a; sysctl -w fs.file-max2097152 sysctl -w fs.nr_open2097152 echo 2097152 > /proc/sys/fs/nr_open #允许当前会话 / 进程打开文…

【论文笔记】Far3D: Expanding the Horizon for Surround-view 3D Object Detection

原文链接&#xff1a;https://arxiv.org/pdf/2308.09616.pdf 1. 引言 目前的环视图图像3D目标检测方法分为基于密集BEV的方法和基于稀疏查询的方法。前者需要较高的计算量&#xff0c;难以扩展到长距离检测。后者全局固定的查询不能适应动态场景&#xff0c;通常会丢失远距离…

竞赛选题 深度学习YOLO抽烟行为检测 - python opencv

文章目录 1 前言1 课题背景2 实现效果3 Yolov5算法3.1 简介3.2 相关技术 4 数据集处理及实验5 部分核心代码6 最后 1 前言 &#x1f525; 优质竞赛项目系列&#xff0c;今天要分享的是 &#x1f6a9; 基于深度学习YOLO抽烟行为检测 该项目较为新颖&#xff0c;适合作为竞赛课…