springmvc02——例子-02(共两个)

本文介绍SpringMVC中使用注解的方式进行开发的过程。包括配置文件简化、控制器类及方法上的注解使用,以及@RequestMapping注解的详细属性说明。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

我们可以使用注解的方式进行开发上一次的例子

1.创建项目,导包(和以前一样)
2.web.xml文件也没有什么变化,直接copy
3.在spring.xml添加前面的那些东西,不过东西还是那些东西(无论怎么开发,springmvc工作流程都是相同的),但是有种鸟枪换炮的感觉
整个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:mvc="http://www.springframework.org/schema/mvc"
	xsi:schemaLocation="
        http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
        http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd
        http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd">
        	
	<!-- 注解开发 -->
	<!-- 支持注解的处理器映射器 
		 支持的注解为:@RequestMapping-->
	<bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping"></bean>
	
	<!-- 支持注解的 处理器适配器 -->
	<bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter"></bean>
	
	<!-- 注解使用controller-->
	<context:component-scan base-package="com.cbb.controller"></context:component-scan>
	
	<!--视图解析器:作用:解析成真正的视图 
		InternalResourceViewResolver 作用:解析jsp视图的
	-->
	<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
		<property name="prefix" value="/WEB-INF/jsps/"></property>
		<property name="suffix" value=".jsp"></property>
	</bean>
</beans>

前三者都换成了可以使用注解,视图解析器没有变化。
4.控制器不需要继承了,只需要进行注解
要将他注解为springmvc的bean,要加@controller注释在类头上

package com.cbb.controller;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.servlet.ModelAndView;

/** 
 * 类描述:controller类
 * 作者: 地铁与人海
 * 创建日期:2019年3月14日
 * 修改人:
 * 修改日期:
 * 修改内容:
 * 版本号: 1.0.0   
 */
@Controller
public class FirstController {

	@RequestMapping(value="one.do")
	public ModelAndView one() {
		ModelAndView mv = new ModelAndView();
		mv.addObject("msg","这是springmvc注解开发");
		mv.setViewName("user");
		
		return mv;
	}
}

5.jsp页面没有变化,直接copy,不过你可以加个<hr>之类的

最后就可以验证一下。
这是效果图
在这里插入图片描述

——————————————————————————————
还可以再进行省略

在DispatcherServlet里面有静态代码块,里面有默认的支持注解的处理器映射器、
处理器适配器连视图解析器都有,所以都可以不用写。

所以只需要配置一个

<context:component-scan base-package="com.cbb.controller"></context:component-scan>

即可,还是可以正常运行

在以后的开发项目中,我们还可以加一句这样的配置

<!-- 注解驱动
作用:会自动的注册一些bean ,其中包括支持注解开发的RequestMappingHandlerMapping和
RequestMappingHandlerAdapter
并且提供了数据绑定的支持、数据格式转换 和 读写json的支持。-->
<mvc:annotation-driven></mvc:annotation-driven>

最好还是加上视图解析器,因为可以让你设置视图的开头和结尾

对@requestMapping的一些解释
package com.cbb.controller;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.servlet.ModelAndView;

/** 
 * 类描述:controller类
 * 作者: 地铁与人海
 * 创建日期:2019年3月14日
 * 修改人:
 * 修改日期:
 * 修改内容:
 * 版本号: 1.0.0   
 */
@Controller
@RequestMapping(value="first")//相当于加一个前缀
public class FirstController {
	
	//配置的是映射路径 value="/one.do" 前面的/可加可不加,后面的.do可加可不加
	//可以注解到类上,(所有的方法都在此路径下)也可以注解到方法上
	@RequestMapping(value="one.do")
	public ModelAndView one() {
		ModelAndView mv = new ModelAndView();
		mv.addObject("msg","这是springmvc注解开发");
		mv.setViewName("user");
		
		return mv;
	}
}

路径改为了下面这样
在这里插入图片描述
(显示内容不要在意)

@requestMapping可以进行配置
在这里插入图片描述
我们学习两个

	//value: 映射路径,根据这个路径与请求url进行映射匹配,默认缺省就是value。
	//methode: 指定支持的请求类型。如果不写,则所有类型都支持,如果配置了则仅支持当前配置的这个请求类型
	@RequestMapping(value = "two",method = RequestMethod.POST)
	public ModelAndView two() {
		ModelAndView mv = new ModelAndView();
		mv.addObject("msg","这是springmvc注解开发");
		mv.setViewName("user");
		
		return mv;

————————————————————————————————

RequestMapping注解有六个属性,下面我们把她分成三类进行说明。

【1】value, method
value:指定请求的实际地址,指定的地址可以是URI Template 模式;
method: 指定请求的method类型, GET、POST、PUT、DELETE等;

【2】consumes,produces
consumes: 指定处理请求的提交内容类型(Content-Type),例如application/json, text/html;
produces: 指定返回的内容类型,仅当request请求头中的(Accept)类型中包含该指定类型才返回;

【3】params,headers
params: 指定request中必须包含某些参数值时,才让该方法处理。
headers: 指定request中必须包含某些指定的header值,才能让该方法处理请求。


作者:流烟默
来源:优快云 注解属性
原文:https://blog.youkuaiyun.com/J080624/article/details/55193269/
——————————————————————————————————

以上就是简单的注解开发过程
END

资源下载链接为: https://pan.quark.cn/s/9e7ef05254f8 行列式是线性代数的核心概念,在求解线性方程组、分析矩阵特性以及几何计算中都极为关键。本教程将讲解如何用C++实现行列式的计算,重点在于如何输出分数形式的结果。 行列式定义如下:对于n阶方阵A=(a_ij),其行列式由主对角线元素的乘积,按行或列的奇偶性赋予正负号后求和得到,记作det(A)。例如,2×2矩阵的行列式为det(A)=a11×a22-a12×a21,而更高阶矩阵的行列式可通过Laplace展开或Sarrus规则递归计算。 在C++中实现行列式计算时,首先需定义矩阵类或结构体,用二维数组存储矩阵元素,并实现初始化、加法、乘法、转置等操作。为支持分数形式输出,需引入分数类,包含分子和分母两个整数,并提供与整数、浮点数的转换以及加、减、乘、除等运算。C++中可借助std::pair表示分数,或自定义结构体并重载运算符。 计算行列式的函数实现上,3×3及以下矩阵可直接按定义计算,更大矩阵可采用Laplace展开或高斯 - 约旦消元法。Laplace展开是沿某行或列展开,将矩阵分解为多个小矩阵的行列式乘积,再递归计算。在处理分数输出时,需注意避免无限循环和除零错误,如在分数运算前先约简,确保分子分母互质,且所有计算基于整数进行,最后再转为浮点数,以避免浮点数误差。 为提升代码可读性和可维护性,建议采用面向对象编程,将矩阵类和分数类封装,每个类有明确功能和接口,便于后续扩展如矩阵求逆、计算特征值等功能。 总结C++实现行列式计算的关键步骤:一是定义矩阵类和分数类;二是实现矩阵基本操作;三是设计行列式计算函数;四是用分数类处理精确计算;五是编写测试用例验证程序正确性。通过这些步骤,可构建一个高效准确的行列式计算程序,支持分数形式计算,为C++编程和线性代数应用奠定基础。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值