SSM-SpringMVC+Spring+Mybatis

news2024/11/17 4:53:01
创建项目

创建好 项目后, 项目目录分析

数据库设计

我们采用员工表 Employee 与 部门表 Department

部门表 表设计---

员工表 --表设计

因为有文件上传操作,因此 建立 info表

(其中 员工只能隶属一个部门,因此 两张表之间 有外键关系)

java 代码 设计

数据库建立完毕后,需要为 每张表添加 3-4条数据

建立 entity 实体层

建立实体层: 注意事项

 # 实体层 注意事项
 ​
 类名    --- 与表名  相对应 , java 中规定 类名首字母必须为大写字母
 属性名   ----- 与 列名 相对应,且 属性类型 与列名对应类型一致,
               属性名 采用小驼峰命名发, 列名 不区分大小写
               例如    表中 列 为 stuno 则属性为 stuNo
               
 实体类中 必须包含无参数的构造方法

建立mapper层 数据访问层

因为 我们使用的mybatis,因此 包名为mapper 当然也可以为dao

mybatis中 规定 接口与映射文件放在一起,并一一对应,

不仅名称一致,还需要再 xxxMapper.xml 配置 namespace, 指向 对应的接口

 <?xml version="1.0" encoding="UTF-8" ?>
 <!DOCTYPE mapper
         PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
         "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> 
 <mapper namespace="mapper.EmployeeMapper">
 ​
 </mapper>
建立service层 业务层

添加Spring 依赖

编写 pom.xml

  <!--spring aop 依赖 jar-->
     <!-- https://mvnrepository.com/artifact/org.aspectj/aspectjweaver -->
     <dependency>
       <groupId>org.aspectj</groupId>
       <artifactId>aspectjweaver</artifactId>
       <version>1.9.7</version>
       <scope>runtime</scope>
     </dependency>
  <!-- https://mvnrepository.com/artifact/org.springframework/spring-webmvc -->
     <dependency>
       <groupId>org.springframework</groupId>
       <artifactId>spring-webmvc</artifactId>
       <version>5.2.9.RELEASE</version>
     </dependency>
     <dependency>
       <groupId>org.springframework</groupId>
       <artifactId>spring-jdbc</artifactId>
       <version>5.2.9.RELEASE</version>
     </dependency>
     <dependency>
       <groupId>org.springframework</groupId>
       <artifactId>spring-core</artifactId>
       <version>5.2.9.RELEASE</version>
     </dependency>
 ​
     <dependency>
       <groupId>org.springframework</groupId>
       <artifactId>spring-beans</artifactId>
       <version>5.2.9.RELEASE</version>
     </dependency>
 ​

添加mybatis 依赖

编写 pom.xml

  
 <!-- mbatis 分页插件-->
     <dependency>
       <groupId>com.github.pagehelper</groupId>
       <artifactId>pagehelper</artifactId>
       <version>5.2.0</version>
     </dependency>
 ​
 ​
     <!--mybatis-spring 依赖-->
     <!-- https://mvnrepository.com/artifact/org.mybatis/mybatis-spring -->
     <dependency>
       <groupId>org.mybatis</groupId>
       <artifactId>mybatis-spring</artifactId>
       <version>2.0.6</version>
     </dependency>
     <!--引入mybatis.jar-->
     <dependency>
       <groupId>org.mybatis</groupId>
       <artifactId>mybatis</artifactId>
       <version>3.4.6</version>
     </dependency>
添加其他一些依赖

添加 mysql 数据库依赖 及 log4j

 
 <!--mysql-->
     <!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java -->
     <dependency>
       <groupId>mysql</groupId>
       <artifactId>mysql-connector-java</artifactId>
       <version>8.0.26</version>
     </dependency>
 ​
     <!--log4j-->
     <!-- https://mvnrepository.com/artifact/log4j/log4j -->
     <dependency>
       <groupId>log4j</groupId>
       <artifactId>log4j</artifactId>
       <version>1.2.17</version>
     </dependency>

添加数据源 依赖

 
 <!-- https://mvnrepository.com/artifact/com.alibaba/druid -->
     <dependency>
       <groupId>com.alibaba</groupId>
       <artifactId>druid</artifactId>
       <version>1.2.5</version>
     </dependency>

jsp 需要引入 jstl

  
<!--jstl 依赖 -->
     <!-- https://mvnrepository.com/artifact/jstl/jstl -->
     <dependency>
       <groupId>jstl</groupId>
       <artifactId>jstl</artifactId>
       <version>1.2</version>
     </dependency>
 ​

文件上传和下载

 <!-- https://mvnrepository.com/artifact/commons-io/commons-io -->
     <dependency>
       <groupId>commons-io</groupId>
       <artifactId>commons-io</artifactId>
       <version>2.6</version>
     </dependency>
     <!-- https://mvnrepository.com/artifact/commons-fileupload/commons-fileupload -->
     <dependency>
       <groupId>commons-fileupload</groupId>
       <artifactId>commons-fileupload</artifactId>
       <version>1.4</version>
     </dependency>
 ​
     <dependency>
       <groupId>javax.servlet</groupId>
       <artifactId>servlet-api</artifactId>
       <version>2.5</version>
       <scope>provided</scope>
     </dependency>
 ​
为pom.xml 增加 build
 
 <!--资源-->
 <build>
       <resources>
 ​
         <resource>
           <!--目录-->
           <directory>src/main/java</directory>
           <!--包含-->
           <includes>
             <include>mapper/**.xml</include>
           </includes>
         </resource>
         <resource>
           <!--目录-->
           <directory>src/main/resources</directory>
           <!--包含-->
           <includes>
             <include>**.*</include>
           </includes>
         </resource>
       </resources>
 </build>
编写 数据库配置文件

如果 mysql版本 为 5.0 ,则 driver 应该为 com.mysql.jdbc.Driver

 文件名  db.properties
 # mysql 为8.0 配置
 uname=自己mysql的用户名
 password=mysql的密码
 driver=com.mysql.cj.jdbc.Driver
 url=jdbc:mysql://localhost:3306/数据库名称?serverTimezone=GMT

编写日志配置文件
  文件名  log4j.properties
 ​
 ### 设置###
 log4j.rootLogger = debug,stdout
 ### 输出信息到控制抬 ###
 log4j.appender.stdout = org.apache.log4j.ConsoleAppender
 log4j.appender.stdout.Target = System.out
 log4j.appender.stdout.layout = org.apache.log4j.PatternLayout
 log4j.appender.stdout.layout.ConversionPattern = [%-5p] %d{yyyy-MM-dd HH:mm:ss,SSS} method:%l%n%m%n

编写spring 配置文件

spring.xml

 <?xml version="1.0" encoding="UTF-8"?>
 ​
 <beans xmlns="http://www.springframework.org/schema/beans"
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xmlns:context="http://www.springframework.org/schema/context"
        xmlns:tx="http://www.springframework.org/schema/tx"
        xmlns:aop="http://www.springframework.org/schema/aop"
        xsi:schemaLocation="http://www.springframework.org/schema/beans
        http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
        http://www.springframework.org/schema/context
        http://www.springframework.org/schema/context/spring-context-3.0.xsd
        http://www.springframework.org/schema/tx
        http://www.springframework.org/schema/tx/spring-tx-3.0.xsd
         http://www.springframework.org/schema/aop
        http://www.springframework.org/schema/aop/spring-aop-3.0.xsd
 ">
       <!--spring 加载 db.properties -->
        <context:property-placeholder location="classpath:db.properties"/>
        <!-- 第一步   spring 管理 数据源 (以前mybatis自己管理)  -->
        <bean id="ds" class="com.alibaba.druid.pool.DruidDataSource"  >
            <property name="driverClassName" value="${driver}"/>
            <property name="url" value="${url}"/>
            <property name="username" value="${uname}"/>
            <property name="password" value="${password}"/>
         </bean>
       <!-- 第二步      将mybatis中 SqlSessionFactory 交由 spring-->
        <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
            <!--配置数据源属性-->
            <property name="dataSource"  ref="ds"/>
            <!-- 单独写了 mybatis的配置文件 , 使用以下方式引入 -->
            <property name="configLocation" value="classpath:mybatis.xml"/>
             <!-- 配置 mybatis 中的 别名 -->
            <property name="typeAliasesPackage" value="entity"/>
            <!--配置 mybatis 中的 映射器-->
            <property name="mapperLocations" value="classpath:mapper/*.xml"/>
            <!--配置分页mybati 插件-->
            <property name="plugins">
                <array>
                    <bean class="com.github.pagehelper.PageInterceptor">
                        <property name="properties">
                            <!--使用下面的方式配置参数,一行配置一个 -->
                            <value>
                                helperDialect=mysql
                                reasonable=true
                            </value>
                        </property>
                    </bean>
                </array>
            </property>
        </bean>
     <!--第三步  配置 mapper 的扫描-->
        <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
            <!--配置 sqlSessionFactoryBeanName -->
            <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/>
            <!-- 配置 扫描 mapper-->
            <property name="basePackage" value="mapper"/>
        </bean>
        <!--扫描 service 包 , 因为 我们会对 service 做 事务管理-->
        <context:component-scan base-package="service"/>
 ​
 ​
     <!-- 配置 文件 上传 需要 解析器-->
        <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
            <!--设置 最大上传 为10M -->
            <property name="maxUploadSize" value="10240000000" />
            <!--默认编码为 utf-8 处理中文-->
            <property name="defaultEncoding" value="utf-8"/>
        </bean>
 ​
 ​
     <!--配置 事务 -->
      <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
          <!--配置数据源-->
          <property name="dataSource" ref="ds"/>
      </bean>
 ​
     <!-- 使用 tx 之前 先 引入 命名空间  tx-->
     <tx:advice id="txAdvice" transaction-manager="transactionManager">
         <tx:attributes>
             <tx:method name="insert*" propagation="REQUIRED"/>
             <tx:method name="save*" propagation="REQUIRED"/>
             <tx:method name="create*" propagation="REQUIRED"/>
             <tx:method name="add*" propagation="REQUIRED"/>
             <tx:method name="update*" propagation="REQUIRED"/>
             <tx:method name="delete*" propagation="REQUIRED"/>
             <tx:method name="del*" propagation="REQUIRED"/>
             <tx:method name="select*" propagation="SUPPORTS" read-only="true"/>
             <tx:method name="find*" propagation="SUPPORTS" read-only="true"/>
             <tx:method name="search*" propagation="SUPPORTS" read-only="true"/>
             <tx:method name="query*" propagation="SUPPORTS" read-only="true"/>
         </tx:attributes>
     </tx:advice>
 ​
     <!--定义切面, 应用 通知-->
     <aop:config>
         <aop:advisor advice-ref="txAdvice"
                      pointcut="execution(* service.*.*(..))"/>
     </aop:config>
 ​
 ​
 ​
 ​
 </beans>
编写 springmvc 配置文件

springmvc.xml

 <?xml version="1.0" encoding="UTF-8"?>
 ​
 <beans xmlns="http://www.springframework.org/schema/beans"
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xmlns:context="http://www.springframework.org/schema/context"
        xmlns:mvc="http://www.springframework.org/schema/mvc"
        xsi:schemaLocation="http://www.springframework.org/schema/beans
        http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
        http://www.springframework.org/schema/context
        http://www.springframework.org/schema/context/spring-context-3.0.xsd http://www.springframework.org/schema/mvc https://www.springframework.org/schema/mvc/spring-mvc.xsd">
 ​
     <!--扫描 controller 包 -->
     <context:component-scan base-package="controller"/>
     <!--配置  视图 解析器-->
     <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
         <!--前缀-->
         <property name="prefix" value="/WEB-INF/"/>
         <!--后缀-->
         <property name="suffix" value=".jsp"/>
     </bean>
     <mvc:annotation-driven/>
 </beans>

编写mybatis配置文件

如果 mybatis 里面什么也 没有,可以 不配置改文件

 <?xml version="1.0" encoding="UTF-8" ?>
 <!DOCTYPE configuration
         PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
         "http://mybatis.org/dtd/mybatis-3-config.dtd">
 <configuration>
 ​
     <settings>
         <!--增加 日志的输出  这样 控制台 就可以看到 sql-->
         <setting name="logImpl" value="LOG4J"/>
     </settings>
 ​
 </configuration>

编写web.xml 文件
 <?xml version="1.0" encoding="UTF-8"?>
 ​
 <web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
          xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
          xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee
           http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
          version="4.0" metadata-complete="false">
 ​
   <display-name>Archetype Created Web Application</display-name>
   <!-- 加载 spring 配置文件  -->
   <context-param>
     <param-name>contextConfigLocation</param-name>
     <param-value>classpath:spring.xml</param-value>
   </context-param>
   <!--  监听器 -->
   <listener>
     <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
   </listener>
 ​
   <!--过滤器 处理中文-->
   <filter>
     <filter-name>encodingFilter</filter-name>
     <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
     <init-param>
       <param-name>encoding</param-name>
       <param-value>utf-8</param-value>
     </init-param>
   </filter>
   <filter-mapping>
     <filter-name>encodingFilter</filter-name>
     <url-pattern>/*</url-pattern>
   </filter-mapping>
 ​
 ​
 ​
   <!-- 配置 springmvc的 DispatcherServlet-->
   <servlet>
     <servlet-name>springmvc</servlet-name>
     <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
     <!--配置 初始化 参数 ,自动加载 springmvc.xml-->
     <init-param>
       <param-name>contextConfigLocation</param-name>
       <param-value>classpath:springmvc.xml</param-value>
     </init-param>
   </servlet>
   <servlet-mapping>
     <servlet-name>springmvc</servlet-name>
     <url-pattern>/</url-pattern>
   </servlet-mapping>
 </web-app>
 ​
编写需求功能(这里以部门为例)
分页查询
编写mapper 接口 DepartmentMapper.java
    ```java
    
        List<Department> findAll();
     
    ```
编写mapper的xml 文件DepartmentMapper.xml
 ​
     <select id="findAll" resultType="department" >
 ​
         select * from department
     </select>

编写 service及实现类

DepService.java

  List<Department> findAll();

DepServiceImpl.java

 @Service
 public class DepServiceImpl  implements DepService {
 ​
 ​
     @Autowired
     private DepartmentMapper departmentMapper;
 ​
 ​
     @Override
     public List<Department> findAll() {
         return departmentMapper.findAll();
     }
 ​
 }
 ​

编写 controller

 @Controller
 public class DepController {
 ​
     @Autowired
     private DepService depService;
 ​
     private  final int PAGESIZE=3; // 定义 每页显示的 条数
     
      /**
      * 分页查询
      * @return
      */
     @RequestMapping("/page")
     public String pageList(int current,Model model){
      //判断页码
      if(current==0){
          current =1; // 从第一页开始
      }
     // 分页处理
      PageHelper.startPage(current,PAGESIZE);
      // 获得全部数据
      List<Department> list = depService.searchInfo();
      // 创建 PageInfo 对象
      PageInfo<Department> pageInfo = new PageInfo<>(list);
      // 将 数据返回到 jsp
       model.addAttribute("pageInfo",pageInfo);
 ​
       return "listPage";
     }
 ​
 ​
 }

编写jsp页面

任意jsp页面

 <a href="/page?current=1"> 点我 分页查询 部门信息</a>

listPage.jsp

 ​

 <%@ page contentType="text/html;charset=UTF-8" language="java"  isELIgnored="false" %>
 <%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
 <html>
 <head>
     <title>部门列表----分页查询</title>
 </head>
 <body>
   <h2>部门名称                部门主管 </h2>
    <ul>
 ​
     <c:if test="${pageInfo.list !=null && pageInfo.list.size()>0 }">
           <c:forEach items="${pageInfo.list}" var="dep" >
               <li>
                   ${dep.depName}  -  ${dep.depEmpName}
               </li>
 ​
           </c:forEach>
 ​
      </c:if>
    </ul>
 ​
   <div>
 ​
       <c:if test="${pageInfo.isFirstPage}">
       <%--   <a href="javascript:void(0)" disabled="disabled" >上一页</a>--%>
           <button disabled >上一页</button>
       </c:if>
       <c:if test="${! pageInfo.isFirstPage}">
         <%--  <a href="/page?current=${pageInfo.pageNum-1}">上一页</a>--%>
           <button onclick="window.location.href='/page?current=${pageInfo.pageNum-1}'" >上一页</button>
       </c:if>
 ​
 ​
       <c:if test="${pageInfo.isLastPage}">
         <%--  <a href="javascript:void(0)" disabled="disabled" >下一页</a>--%>
           <button disabled >下一页</button>
       </c:if>
       <c:if test="${! pageInfo.isLastPage}">
          <%-- <a href="/page?current=${pageInfo.pageNum+1}">下一页</a>--%>
           <button onclick="window.location.href='/page?current=${pageInfo.pageNum+1}'" >下一页</button>
       </c:if>
 ​
        共${pageInfo.pages} 页 ,当前是 第${pageInfo.pageNum}页
 ​
   </div>
 </body>
 </html>
 ​

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

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

相关文章

自定义数据实现SA3D

SA3D&#xff1a;Segment Anything in 3D with NeRFs 实现了3D目标分割 原理是利用SAM(segment anything) 模型和Nerf分割渲染3D目标&#xff0c; SAM只能分块&#xff0c;是没有语义标签的&#xff0c;如何做到语义连续&#xff1f; SA3D中用了self-prompt, 根据前一帧的mask…

C#编程-了解线程的优先级

了解线程的优先级 控制线程行为的一个属性是它的优先级。.NET运行时环境基于它们的优先级执行线程。CPU一次仅执行一个线程。因此,处于执行的可运行状态的线程,排队等待轮到被处理器执行。线程是固定优先级调度的。带有优先级的每个线程在处理器的线程队列中有自己的位置。 …

Java面试之虚拟机

1、前言 本篇的面试题基于网络整理&#xff0c;和自己编辑。在不断的完善补充哦。 2、什么是虚拟机&#xff1f; Java 虚拟机&#xff0c;是一个可以执行 Java 字节码的虚拟机进程。Java 源文件被编译成能被 Java 虚拟机执行的字节码文件( .class )。 Java 被设计成允许应用程…

老胡的周刊(第124期)

老胡的信息周刊[1]&#xff0c;记录这周我看到的有价值的信息&#xff0c;主要针对计算机领域&#xff0c;内容主题极大程度被我个人喜好主导。这个项目核心目的在于记录让自己有印象的信息做一个留存以及共享。 &#x1f3af; 项目 QAnything[2] 开源的企业级本地知识库问答解…

Java入门IDEA基础语法

1&#xff1a;Java入门 1.1 Java简介 Java是什么&#xff1a; Java是一门非常优秀的计算机语言 语言&#xff1a;人与人交流沟通的表达方式 计算机语言&#xff1a;人与计算机之间进行信息交流沟通的一种特殊语言 Java之父&#xff1a;詹姆斯高斯林&#xff08;James Gosli…

深入理解计算机系统(2):信息的表示和处理

信息存储 大多数计算机使用 8 位的块&#xff0c;或者字节(byte)&#xff0c;作为最小的可寻址的内存单位&#xff0c;而不是访问内存中单独的位。机器级程序将内存视为一个非常大的字节数组&#xff0c;称为虚拟内存(virtual memory)。内存的每个字节都由一个唯一的数字来标识…

Elasticsearch:是时候离开了! - 在 Elasticsearch 文档上使用 TTL

作者&#xff1a;来自 Elastic David Pilato 想象一下&#xff0c;圣诞老人必须向世界上所有的孩子们分发礼物。 他有很多工作要做&#xff0c;他需要保持高效。 他有一份所有孩子的名单&#xff0c;并且知道他们住在哪里。 他很可能会将礼物按区域分组&#xff0c;然后再交付。…

2024上半年教资笔试报名详细教程1月12日开始报名啦

重点提醒&#xff1a; 1、注册开放时间&#xff1a;2024年1月10日开始。 &#xff08;参加过笔试的考生&#xff0c;需要重新注册&#xff0c; 不影响已获得的笔试成绩。名额少的考点建议提前注册抢名额&#xff09; 2、网上报名时间&#xff1a;2024年1月12日至15日。 千万不…

【IDEA--dubug相关】-- 1. 取消debug的所有断点 2. debug侧边栏消失问题

下面是一些经常在日常debug时用到的场景&#xff0c;方便查看、与君共勉&#xff01; 文章目录 1. 如何取消所有断点2. debug底部左边侧边栏消失 1. 如何取消所有断点 如图我们可能在项目中给很多代码行添加了断点&#xff0c;一个一个点取消麻烦 在debug运行中点击选中底部…

《C语言学习》---郝斌版---笔记

简介 学习计算机&#xff0c;离不开C语言的学习&#xff0c;而C语言学习过程中的视频课教程&#xff0c;目前来说&#xff0c;如果郝斌老师的C语言排第二&#xff0c;没有人敢排第一 郝斌老师的C语言教程&#xff0c;通俗易懂&#xff0c;引人发思&#xff0c;特别适合新手入门…

深度探析卷积神经网络(CNN)在图像视觉与自然语言处理领域的应用与优势

目录 前言1 CNN网络结构与工作原理1.1 输入层1.2 卷积层1.3 最大池化层1.4 全连接层 2 应用领域2.1 图像视觉领域中CNN的应用2.2 NLP领域中CNN的应用 3 CNN的限制与未来展望3.1 CNN的挑战3.2 CNN的展望 结语 前言 卷积神经网络&#xff08;CNN&#xff09;作为一种强大的深度学…

2023一带一路暨金砖国家技能发展与技术创新大赛“网络安全”赛项省选拔赛样题卷①

2023金砖国家职业技能竞赛"网络安全" 赛项省赛选拔赛样题 2023金砖国家职业技能竞赛 省赛选拔赛样题第一阶段&#xff1a;职业素养与理论技能项目1. 职业素养项目2. 网络安全项目3. 安全运营 第二阶段&#xff1a;安全运营项目1. 操作系统安全配置与加固任务一Linux …

DNS解析和主从复制

一、DNS名称解析协议 二、DNS正向解析 三、DNS主从复制 主服务器 从服务器

2024年湖北职称评审对论文的要求

1.期刊发表版面的时间节点2024年12月及之前 2.期刊是正规的期刊&#xff0c;有国内刊号 3.期刊能在国家出版社总署检索到 4.文章内容查重符合知网查重标准 5.论文方向和申报专业方向一致 6.必须要是第一作者或者独著 7.评正高的人才们要准备中文核心论文两篇或出版专业学术论著…

人工智能的现状及今后发展趋势展望

人工智能&#xff08;Artificial Intelligence, AI&#xff09;作为当今科学技术领域的一个热门话题&#xff0c;已经逐渐影响到了人们的生活方方面面。在过去的几十年里&#xff0c;人工智能领域取得了巨大的发展&#xff0c;并且展现出了巨大的潜力。然而&#xff0c;随着时间…

【Python】新鲜出炉的海洋捕食者算法Python版本

2020年发表的海洋捕食者算法《Marine Predators Algorithm: A nature-inspired metaheuristic》。 作者只在原论文中给出了MATLAB代码&#xff0c;网上也没有Python版本&#xff0c;我自己用Python重写了MATLAB代码。 """2020海洋捕食者算法 """…

Python元组(tuple)

目录 元组元组的创建和删除访问元组元素修改元组元组方法 元组 元组是有序且不可更改的集合。在 Python 中&#xff0c;元组是用圆括号编写的。 元组的创建和删除 实例 创建元组&#xff1a; thistuple ("a", "b", "c") print(thistuple)删除…

微软等开源评估ChatGPT、Phi、Llma等,统一测试平台

微软亚洲研究院、中国科学院自动化研究所、中国科学技术大学和卡内基梅隆大学联合开源了&#xff0c;用于评估、分析大语言模型的统一测试平台——PromptBench。 Prompt Bench支持目前主流的开源、闭源大语言模型&#xff0c;例如&#xff0c;ChatGPT、GPT-4、Phi、Llma1/2、G…

Ps:操控变形

Ps菜单&#xff1a;编辑/操控变形 Edit/Puppet Warp 操控变形 Puppet Warp命令能够借助网格随意扭曲特定图像区域&#xff0c;同时可保持其他区域不变。 其应用范围小至精细的图像修饰&#xff08;如发型设计&#xff09;&#xff0c;大至总体的变换&#xff08;如重新定位手臂…

【J-Flash基本使用总结】

【J-Flash基本使用总结】 VX&#xff1a;hao541022348 ■ 烧录文件■ 创建新的工程■ 烧录模式-SWD模式■ 烧录 ■ 读单片机Flash数据■ 设置或解除读保护 ■ 烧录文件 ■ 创建新的工程 接着点击 Options –> Project Settings…&#xff0c;选择CPU > Device &#xff…