- 浏览: 1363996 次
- 性别:
- 来自: 北京
-
文章分类
- 全部博客 (453)
- Struts2 (4)
- Struts1 (16)
- Spring (9)
- Hibernate (5)
- AJAX (16)
- MS Server (9)
- Oracle (35)
- 测试技术 (5)
- 其他 (37)
- JSF (1)
- EJB (5)
- ASP.NET (9)
- iBATIS (5)
- Struts Spring Hibernate (2)
- HTML (12)
- Eclipse使用 (5)
- 设计模式 (5)
- JSP (32)
- 正则表达式 (2)
- 服务器 (12)
- Java基础 (48)
- MySQL (4)
- 面试 (22)
- UML (1)
- 数据结构 (3)
- Ant (2)
- 规范 (4)
- JavaScript (29)
- 软件使用及技巧 (25)
- PHP (1)
- DWR (3)
- FreeMarker (1)
- ExtJs (17)
- JFreeChart (9)
- Reports (2)
- JavaException (1)
- Java Mail (1)
- Flex (9)
- 异常 (12)
- Log4j (2)
- WebService (1)
- jQuery (1)
- Sybase (2)
- myeclipse_plugin (2)
- Linux (5)
- jbpm (2)
- SCM (1)
- mongoDB (1)
最新评论
-
lihua2008love:
<typeAlias alias="User& ...
IBATIS简单操作 -
lihua2008love:
...
关于项目框架设计的一点学习 -
c_jinglin:
我使用<OBJECT CLASSID="cls ...
这就是个静态页面通过js控制mscomm对某com设备进行访问的例子. -
zlbjava:
赞,用了还不错
java获取请求的ip地址,并解析ip所属地区 -
完美天龙:
cs842813290 写道楼主,我明白的地方:在链表已有N个 ...
JAVA实现双向链表
问题:这里的plug-in标签的作用是什么?可以不写plugin-in这个标签吗?
1、其实plug-in只是为了装载Struts的ActionServlet用的,如果在web.xml的context-param中已经指定了这个Struts的ActionServlet配置文件,那么此时可以不写plug-in。
2、如果在web.xml的context-param中并没有指定这个Struts的ActionServlet配置文件,那么必须加上plug-in
3、plug-in中contextConfigLocation属性的作用是什么?可以不要这个属性吗?
如果用了plug-in,那么contextConfigLocation属性的作用是指定Struts的ActionServlet配置文件所在的位置;
如果去掉了contextConfigLocation属性,那么Struts的ActionServlet配置文件将被指定为/WEB-INF/{app}-servlet.xml文件,
({app}指的是web.xml中servlet-name的值,此处为"action"
- <!-- struts 的配置 -->
- <servlet>
- <servlet-name>action</servlet-name>
- <servlet-class>org.apache.struts.action.ActionServlet</servlet-class>
- <init-param>
- <param-name>config</param-name>
- <param-value>
- /WEB-INF/struts/struts-config.xml,
- /WEB-INF/struts/action/fileupload-action-config.xml,
- /WEB-INF/struts/action/demo-action-config.xml
- </param-value>
- </init-param>
- <load-on-startup>1</load-on-startup>
- </servlet>
- <servlet-mapping>
- <servlet-name>action</servlet-name>
- <url-pattern>*.do</url-pattern>
- </servlet-mapping>
<!-- struts 的配置 --> <servlet> <servlet-name>action</servlet-name> <servlet-class>org.apache.struts.action.ActionServlet</servlet-class> <init-param> <param-name>config</param-name> <param-value> /WEB-INF/struts/struts-config.xml, /WEB-INF/struts/action/fileupload-action-config.xml, /WEB-INF/struts/action/demo-action-config.xml </param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>action</servlet-name> <url-pattern>*.do</url-pattern> </servlet-mapping>
)
所以,这是就必须在/WEB-INF/下存在action-servlet.xml文件。
现在默认的/WEB-INF/action-servlet.xml文件或由plug-in的contextConfigLocation属性指定的/WEB-INF/struts/spring/demo-action.spring.xml文件内容应该结合
web.xml的struts配置中指定的config文件内容可以这样写:
- <?xml version="1.0" encoding="UTF-8"?>
- <!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.org/dtd/spring-beans.dtd">
- <beans>
- <bean name="/demo/list" parent="baseTxService">
- <property name="target">
- <bean class="com.ramix.demo.webapp.action.DemoListAction" autowire="byName">
- <property name="mgr" ref="parentManager"/>
- </bean>
- </property>
- </bean>
- <bean name="/demo/save" parent="baseTxService">
- <property name="target">
- <bean class="com.ramix.demo.webapp.action.DemoSaveAction" autowire="byName">
- <property name="mgr" ref="parentManager"/>
- </bean>
- </property>
- </bean>
- <bean name="/demo/client" class="com.ramix.demo.webapp.action.DemoClientAction">
- <property name="dws" ref="demoClient"/>
- </bean>
- <bean name="/demo/send" class="com.ramix.demo.webapp.action.DemoSendAction">
- <property name="mgr" ref="mailSendManager"/>
- </bean>
- <bean name="/demo/child/create" parent="baseTxService">
- <property name="target">
- <bean class="com.ramix.demo.webapp.action.DemoChildCreateAction" autowire="byName">
- <property name="mgr" ref="parentManager"/>
- </bean>
- </property>
- </bean>
- <bean name="/demo/child/save" parent="baseTxService">
- <property name="target">
- <bean class="com.ramix.demo.webapp.action.DemoChildSaveAction" autowire="byName">
- <property name="PMgr" ref="parentManager"/>
- <property name="CMgr" ref="childManager"/>
- </bean>
- </property>
- </bean>
- <bean name="/demo/child/list" parent="baseTxService">
- <property name="target">
- <bean class="com.ramix.demo.webapp.action.DemoChildListAction" autowire="byName">
- <property name="mgr" ref="childManager"/>
- </bean>
- </property>
- </bean>
- <bean name="/demo/ajax/child/list" parent="baseTxService">
- <property name="target">
- <bean class="com.ramix.demo.webapp.action.DemoAjaxChildListAction" autowire="byName">
- <property name="mgr" ref="jdbcManager"/>
- </bean>
- </property>
- </bean>
- <bean name="/demo/test" parent="baseTxService">
- <property name="target">
- <bean class="com.ramix.demo.webapp.action.Test" autowire="byName">
- </bean>
- </property>
- </bean>
- </beans>
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.org/dtd/spring-beans.dtd"> <beans> <bean name="/demo/list" parent="baseTxService"> <property name="target"> <bean class="com.ramix.demo.webapp.action.DemoListAction" autowire="byName"> <property name="mgr" ref="parentManager"/> </bean> </property> </bean> <bean name="/demo/save" parent="baseTxService"> <property name="target"> <bean class="com.ramix.demo.webapp.action.DemoSaveAction" autowire="byName"> <property name="mgr" ref="parentManager"/> </bean> </property> </bean> <bean name="/demo/client" class="com.ramix.demo.webapp.action.DemoClientAction"> <property name="dws" ref="demoClient"/> </bean> <bean name="/demo/send" class="com.ramix.demo.webapp.action.DemoSendAction"> <property name="mgr" ref="mailSendManager"/> </bean> <bean name="/demo/child/create" parent="baseTxService"> <property name="target"> <bean class="com.ramix.demo.webapp.action.DemoChildCreateAction" autowire="byName"> <property name="mgr" ref="parentManager"/> </bean> </property> </bean> <bean name="/demo/child/save" parent="baseTxService"> <property name="target"> <bean class="com.ramix.demo.webapp.action.DemoChildSaveAction" autowire="byName"> <property name="PMgr" ref="parentManager"/> <property name="CMgr" ref="childManager"/> </bean> </property> </bean> <bean name="/demo/child/list" parent="baseTxService"> <property name="target"> <bean class="com.ramix.demo.webapp.action.DemoChildListAction" autowire="byName"> <property name="mgr" ref="childManager"/> </bean> </property> </bean> <bean name="/demo/ajax/child/list" parent="baseTxService"> <property name="target"> <bean class="com.ramix.demo.webapp.action.DemoAjaxChildListAction" autowire="byName"> <property name="mgr" ref="jdbcManager"/> </bean> </property> </bean> <bean name="/demo/test" parent="baseTxService"> <property name="target"> <bean class="com.ramix.demo.webapp.action.Test" autowire="byName"> </bean> </property> </bean> </beans>
其实这样配置的目的也就是为了利用spring的依赖注入,能够使得Struts的servletAction自如的使用service层的bean。
这里需要关注的一点是:
请看/WEB-INF/struts/action/demo-action-config.xml中的
- <action path="/demo/test"
- type="com.ramix.demo.webapp.action.DemoListAction"
- parameter="method"
- scope="request"
- name="globalForm">
- <forward name="test" path="/WEB-INF/page/demo/test.jsp"/>
- </action>
<action path="/demo/test" type="com.ramix.demo.webapp.action.DemoListAction" parameter="method" scope="request" name="globalForm"> <forward name="test" path="/WEB-INF/page/demo/test.jsp"/> </action>
和/WEB-INF/struts/spring/demo-action.spring.xml中的
- <bean name="/demo/test" parent="baseTxService">
- <property name="target">
- <bean class="com.ramix.demo.webapp.action.Test" autowire="byName">
- </bean>
- </property>
- </bean>
<bean name="/demo/test" parent="baseTxService"> <property name="target"> <bean class="com.ramix.demo.webapp.action.Test" autowire="byName"> </bean> </property> </bean>
当url中执行..../demo/test.do时,将会是个什么样的过程?
首先会到/WEB-INF/struts/spring/demo-action.spring.xml中去找name为"/demo/test"的bean,
1、找到了,则执行target属性中指定的bean(此bean就是ServletAction类):com.ramix.demo.webapp.action.Test的execute方法,并通过autowire="byName"对该类的set方法进行依赖注入。
2、没找到,才会去/WEB-INF/struts/action/demo-action-config.xml中去找/demo/test.do,
并执行type属性中指定的ServletAction:com.ramix.demo.webapp.action.DemoListAction的execute方法
提问:servletAction中必须要写execute方法吗?
如果真的写了execute方法,那么就失去了parameter="method"的意义,如果这样做的话,那势必每个功能(通过页面操作增删改查)都需要写一个action类,这样会导致action类数量的急剧膨胀。
其实,struts的DispatchAction的execute方法被执行时,他的机制是去获得method参数,如果该参数有值,那么会去执行这个元素对应的方法。比如url是这样的.../demo/test.do?method=test
就会去执行对应的servletAction类中的test方法;如果method参数没有值,则会去执行unspecified方法。
这样我们可以通过在servletAction中多写几个方法就能很好的解决这个action类急剧膨胀的问题,从管理上看还能更加的简介。
所以如果重写了execute方法,那么就失去了这些功能。
现在可以看看com.ramix.demo.webapp.action.Test类可以怎么写了:
- package com.ramix.demo.webapp.action;
- import javax.servlet.http.HttpServletRequest;
- import javax.servlet.http.HttpServletResponse;
- import org.apache.struts.action.ActionForm;
- import org.apache.struts.action.ActionForward;
- import org.apache.struts.action.ActionMapping;
- import com.ramix.common.webapp.action.BaseAction;
- public class Test extends BaseAction {
- @Override
- public ActionForward unspecified(ActionMapping mapping, ActionForm form,
- HttpServletRequest request, HttpServletResponse response) {
- request.setAttribute("test", "test");
- return mapping.findForward("test");
- }
- public ActionForward test(ActionMapping mapping, ActionForm form,
- HttpServletRequest request, HttpServletResponse response) {
- request.setAttribute("test", request.getParameter("test"));
- return mapping.findForward("test");
- }
- }
package com.ramix.demo.webapp.action; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.apache.struts.action.ActionForm; import org.apache.struts.action.ActionForward; import org.apache.struts.action.ActionMapping; import com.ramix.common.webapp.action.BaseAction; public class Test extends BaseAction { @Override public ActionForward unspecified(ActionMapping mapping, ActionForm form, HttpServletRequest request, HttpServletResponse response) { request.setAttribute("test", "test"); return mapping.findForward("test"); } public ActionForward test(ActionMapping mapping, ActionForm form, HttpServletRequest request, HttpServletResponse response) { request.setAttribute("test", request.getParameter("test")); return mapping.findForward("test"); } }
unspecified是不带method参数是执行的方法
test是method参数值为test是执行的方法
当然如果应用很简单的,你并不需要parameter="method"的话,你非要写上execute方法也没有关系,就像下面代码这样:
- package com.ramix.demo.webapp.action;
- import javax.servlet.http.HttpServletRequest;
- import javax.servlet.http.HttpServletResponse;
- import org.apache.struts.action.ActionForm;
- import org.apache.struts.action.ActionForward;
- import org.apache.struts.action.ActionMapping;
- import com.ramix.common.webapp.action.BaseAction;
- public class Test extends BaseAction {
- public ActionForward execute(ActionMapping mapping, ActionForm form,
- HttpServletRequest request, HttpServletResponse response)
- throws Exception {
- System.out.println("ok");
- System.out.println("ok1");
- return null;
- }
- }
- 说明:这里的BaseAction只是对org.springframework.web.struts.DispatchActionSupport做了封装,代码如下:
- package com.ramix.common.webapp.action;
- import com.ramix.common.util.RequestParamUtil;
- import org.apache.log4j.Logger;
- import org.apache.struts.action.ActionForward;
- import org.apache.struts.action.ActionMapping;
- import org.springframework.context.ApplicationContext;
- import org.springframework.web.context.support.WebApplicationContextUtils;
- import org.springframework.web.struts.DispatchActionSupport;
- import javax.servlet.http.HttpServletRequest;
- import javax.servlet.http.HttpSession;
- import java.util.Map;
- /**
- * 基础的Action,提供一些action中最基本的方法
- *
- * @author: Feng
- * @since: 2007-11-30
- */
- public class BaseAction extends DispatchActionSupport {
- // 用来输出log。
- protected final Logger log = Logger.getLogger(this.getClass());
- // 默认分页个数
- protected static final int DEF_PAGE_SIZE = 10;
- // 默认错误页
- protected static final String DEF_VIEW_PAGE = "view";
- // 默认错误页
- protected static final String DEF_ERROR_PAGE = "globalError";
- // 默认成功页
- protected static final String DEF_SUCCESS_PAGE = "globalSuccess";
- // 令牌名称
- protected static final String TOKEN_KEY = "RIMAX_TOKEN";
- /**
- * 用来得到spring注入的bean。
- *
- * @param beanName 在spring配置文件中定义的bean的名字。
- * @return 从ApplicationContext中得到的bean对象。
- */
- protected Object getBean(String beanName) {
- ApplicationContext ctx = WebApplicationContextUtils.getRequiredWebApplicationContext(servlet.getServletContext());
- return ctx.getBean(beanName);
- }
- /**
- * 从request取得目标页码,没有设置,默认显示第一页
- *
- * @param request HttpServletRequest
- * @return 目标页码
- */
- protected int getPageNum(HttpServletRequest request) {
- return RequestParamUtil.getIntParam(request, "pageNum", 1);
- }
- /**
- * 从request取得目标页码,没有设置,默认显示第一页
- *
- * @param request HttpServletRequest
- * @return 目标页码
- */
- protected int getPageSize(HttpServletRequest request) {
- return RequestParamUtil.getIntParam(request, "pageSize", DEF_PAGE_SIZE);
- }
- /**
- * 转向错误页面
- *
- * @param mapping ActionMapping
- * @param request HttpServletRequest
- * @param message 显示信息
- * @param url 目标地址
- * @return ActionForward
- */
- protected ActionForward toGobalError(ActionMapping mapping, HttpServletRequest request, String message, String url) {
- request.setAttribute("url", url);
- request.setAttribute("message", message);
- return mapping.findForward(DEF_ERROR_PAGE);
- }
- /**
- * 转向全局成功页面
- *
- * @param mapping ActionMapping
- * @param request HttpServletRequest
- * @param message 显示信息
- * @param url 目标地址
- * @return ActionForward
- */
- protected ActionForward toGobalSuccess(ActionMapping mapping, HttpServletRequest request, String message, String url) {
- request.setAttribute("url", url);
- request.setAttribute("message", message);
- return mapping.findForward(DEF_SUCCESS_PAGE);
- }
- /**
- * 验证当前提交的令牌,并不重置令牌
- *
- * @param request HttpServletRequest
- * @return 令牌是否有效
- */
- protected boolean validCurToken(HttpServletRequest request) {
- HttpSession session = request.getSession();
- if (session == null) {
- return false;
- }
- Map map = (Map) session.getAttribute(TOKEN_KEY);
- if (map == null) {
- return true;
- }
- String strToken = request.getParameter(TOKEN_KEY);
- if (strToken == null) {
- return false;
- }
- return map.containsKey(strToken);
- }
- /**
- * 删除当前令牌
- *
- * @param request HttpServletRequest
- */
- protected void removeCurToken(HttpServletRequest request) {
- HttpSession session = request.getSession();
- if (session == null) {
- return;
- }
- Map map = (Map) session.getAttribute(TOKEN_KEY);
- if (map == null) {
- return;
- }
- String strToken = request.getParameter(TOKEN_KEY);
- if (strToken == null) {
- return;
- }
- map.remove(strToken);
- }
- }
发表评论
-
Spring 配置文件的加载情况
2009-04-20 13:02 1391package com.wangyu.util; i ... -
spring propertyplaceholderconfigurer
2009-01-12 08:34 23003Spring的框架中为您提供了一个 BeanFactoryPo ... -
Quartz调度任务
2008-07-11 11:29 1984package example.chapter9; ... -
配置邮件服务mail
2008-07-11 10:47 2451ApplicationContext.xml <?xm ... -
struts与spring如何整合(1)
2008-07-02 23:25 1892一、struts与spring如何整合 线索从web.xml看 ... -
定时器quartz的应用
2008-07-02 23:14 2811用quartz可以实现web或非web模式的定时器 1、配置 ... -
SpringAOP
2008-06-07 22:34 1256package com.wangyu02; public ... -
Spring XML配置的12个技巧
2008-04-27 20:14 2261Spring是一个强有力的java程序框架,其被广泛应用于ja ...
相关推荐
重点:所有项目均附赠详尽的SQL文件,这一细节的处理,让我们的项目相比其他博主的作品,严谨性提升了不止一个量级!更重要的是,所有项目源码均经过我亲自的严格测试与验证,确保能够无障碍地正常运行。 1.项目适用场景:本项目特别适用于计算机领域的毕业设计课题、课程作业等场合。对于计算机科学与技术等相关专业的学生而言,这些项目无疑是一个绝佳的选择,既能满足学术要求,又能锻炼实际操作能力。 2.超值福利:所有定价为9.9元的项目,均包含完整的SQL文件。如需远程部署可随时联系我,我将竭诚为您提供满意的服务。在此,也想对一直以来支持我的朋友们表示由衷的感谢,你们的支持是我不断前行的动力! 3.求关注:如果觉得我的项目对你有帮助,请别忘了点个关注哦!你的支持对我意义重大,也是我持续分享优质资源的动力源泉。再次感谢大家的支持与厚爱! 4.资源详情:https://blog.csdn.net/2301_78888169/article/details/144929660 更多关于项目的详细信息与精彩内容,请访问我的CSDN博客!
2024年AI代码平台及产品发展简报-V11
蓝桥杯算法学习冲刺(主要以题目为主)
QPSK调制解调技术研究与FPGA实现:详细实验文档的探索与实践,基于FPGA实现的QPSK调制解调技术:实验文档详细解读与验证,QPSK调制解调 FPGA设计,有详细实验文档 ,QPSK调制解调; FPGA设计; 详细实验文档,基于QPSK调制的FPGA设计与实验文档
PID、ADRC和MPC轨迹跟踪控制器在Matlab 2018与Carsim 8中的Simulink仿真研究,PID、ADRC与MPC轨迹跟踪控制器在Matlab 2018与Carsim 8中的仿真研究,PID, ADRC和MPC轨迹跟踪控制器Simulink仿真模型。 MPC用于跟踪轨迹 ADRC用于跟踪理想横摆角 PID用于跟踪轨迹 轨迹工况有双移线,避障轨迹,正弦轨迹多种 matlab版本为2018,carsim版本为8 ,PID; ADRC; MPC; 轨迹跟踪控制器; Simulink仿真模型; 双移线; 避障轨迹; 正弦轨迹; MATLAB 2018; CarSim 8,基于Simulink的PID、ADRC与MPC轨迹跟踪控制器仿真模型研究
重点:所有项目均附赠详尽的SQL文件,这一细节的处理,让我们的项目相比其他博主的作品,严谨性提升了不止一个量级!更重要的是,所有项目源码均经过我亲自的严格测试与验证,确保能够无障碍地正常运行。 1.项目适用场景:本项目特别适用于计算机领域的毕业设计课题、课程作业等场合。对于计算机科学与技术等相关专业的学生而言,这些项目无疑是一个绝佳的选择,既能满足学术要求,又能锻炼实际操作能力。 2.超值福利:所有定价为9.9元的项目,均包含完整的SQL文件。如需远程部署可随时联系我,我将竭诚为您提供满意的服务。在此,也想对一直以来支持我的朋友们表示由衷的感谢,你们的支持是我不断前行的动力! 3.求关注:如果觉得我的项目对你有帮助,请别忘了点个关注哦!你的支持对我意义重大,也是我持续分享优质资源的动力源泉。再次感谢大家的支持与厚爱! 4.资源详情:https://blog.csdn.net/2301_78888169/article/details/144486173 更多关于项目的详细信息与精彩内容,请访问我的CSDN博客!
内容概要:本文档详细介绍了一个利用Matlab实现Transformer-Adaboost结合的时间序列预测项目实例。项目涵盖Transformer架构的时间序列特征提取与建模,Adaboost集成方法用于增强预测性能,以及详细的模型设计思路、训练、评估过程和最终的GUI可视化。整个项目强调数据预处理、窗口化操作、模型训练及其优化(包括正则化、早停等手段)、模型融合策略和技术部署,如GPU加速等,并展示了通过多个评估指标衡量预测效果。此外,还提出了未来的改进建议和发展方向,涵盖了多层次集成学习、智能决策支持、自动化超参数调整等多个方面。最后部分阐述了在金融预测、销售数据预测等领域中的广泛应用可能性。 适合人群:具有一定编程经验的研发人员,尤其对时间序列预测感兴趣的研究者和技术从业者。 使用场景及目标:该项目适用于需要进行高质量时间序列预测的企业或机构,比如金融机构、能源供应商和服务商、电子商务公司。目标包括但不限于金融市场的波动性预测、电力负荷预估和库存管理。该系统可以部署到各类平台,如Linux服务器集群或云计算环境,为用户提供实时准确的预测服务,并支持扩展以满足更高频率的数据吞吐量需求。 其他说明:此文档不仅包含了丰富的理论分析,还有大量实用的操作指南,从项目构思到具体的代码片段都有详细记录,使用户能够轻松复制并改进这一时间序列预测方案。文中提供的完整代码和详细的注释有助于加速学习进程,并激发更多创新想法。
液滴穿越障碍:从文献到案例的复现研究,液滴破裂与障碍物穿越:文献复现案例研究,液滴生成并通过障碍物破裂。 该案例是文献复现,文献与案例一起。 ,液滴生成; 障碍物破裂; 文献复现; 案例研究,液滴破裂:障碍挑战的文献复现案例
蓝桥杯算法学习冲刺(主要以题目为主)
蓝桥杯算法学习冲刺(主要以题目为主)
基于最小递归二乘法的MPC自适应轨迹跟踪控制优化 针对轮胎刚度时变特性提升模型精度与鲁棒性,仿真验证满足车辆低速高精度跟踪与高速稳定性提升。,基于变预测时域MPC自适应轨迹跟踪控制与轮胎侧偏刚度优化提升模型精度和鲁棒性,基于变预测时域的MPC自适应轨迹跟踪控制,针对轮胎刚度时变的特点造成控制模型精度降低,基于最小递归二乘法(RLS)估算的轮胎侧偏刚度,提升了模型的控制精度和鲁棒性,通过carsim与simulink联合仿真结果发现,改进后的轨迹跟踪控制器既满足了车辆低速行驶下的轨 迹跟踪精度,也一定程度上克服了高速下车辆容易失去稳定性的问题。 有详细的lunwen分析说明和资料,以及本人的,仿真包运行。 ,基于变预测时域的MPC; 自适应轨迹跟踪控制; 轮胎刚度时变; 控制模型精度降低; 最小递归二乘法(RLS)估算; 模型控制精度和鲁棒性提升; carsim与simulink联合仿真; 轨迹跟踪控制器; 车辆稳定性。,基于变预测时域MPC的轮胎刚度自适应轨迹跟踪控制策略研究
GMSK调制解调技术研究:基于FPGA设计与实验详解,GMSK调制解调技术详解:基于FPGA设计的实验文档与实践应用,GMSK调制解调 FPGA设计,有详细实验文档 ,GMSK调制解调; FPGA设计; 详细实验文档; 实验结果分析,GMSK调制解调技术:FPGA设计与实验详解
# 基于Arduino和Python的Cansat卫星系统 ## 项目简介 本项目是一个Cansat卫星系统,旨在设计和实现一个小型卫星模型,通过火箭发射至1公里高空,并使用地面站接收其传输的数据。项目涉及Arduino编程、Python数据处理和可视化。 ## 主要特性和功能 1. 硬件组件 使用Arduino Nano作为Cansat的微控制器。 搭载BMP 280温度和压力传感器、ATGM336H GPS模块、LoRa通信模块等。 地面站使用Arduino Uno和LoRa通信模块接收数据。 2. 数据处理 使用Python进行数据处理和可视化,包括数据清洗、计算风速、绘制温度、压力、风速和海拔随时间变化的图表等。 3. 通信与控制 通过LoRa模块实现Cansat与地面站之间的数据传输。 提供实时监视和记录数据的脚本。 ## 安装和使用步骤 ### 1. 硬件准备
U9300C 龙尚4G模块安装后模块才能正常使用,win7 win10驱动程序,支持USB转接板。
# 基于Arduino平台的物联网温湿度监控系统 ## 项目简介 这是一个基于Arduino平台的物联网温湿度监控项目,旨在通过简单的硬件设备实现环境数据的实时监测与远程管理。该项目适用于智能家居、农业种植等领域。 ## 项目的主要特性和功能 1. 温湿度数据采集通过Arduino板连接温湿度传感器,实时采集环境数据。 2. 数据传输将采集到的数据通过无线网络模块发送到服务器或远程终端。 3. 数据可视化可在电脑或移动设备端展示实时的温湿度数据。 4. 报警功能当温湿度数据超过预设阈值时,自动触发报警通知。 ## 安装使用步骤 前提假设用户已经下载了本项目的源码文件。以下是简单明了的安装使用步骤 1. 环境准备安装Arduino开发环境,配置必要的硬件接口。 2. 硬件连接将Arduino板与温湿度传感器、无线网络模块连接。 3. 代码上传将本项目提供的Arduino代码上传至Arduino板。
基于需求响应与清洁能源接入的配电网重构优化:综合成本与混合整数凸规划模型分析(matlab实现),基于需求响应与清洁能源接入的配电网重构算法研究:网损与成本优化的仿真分析,高比例清洁能源接入下计及需求响应的配电网重构(matlab代码) 该程序复现《高比例清洁能源接入下计及需求响应的配电网重构》,以考虑网损成本、弃风弃光成本和开关操作惩罚成本的综合成本最小为目标,针对配电网重构模型的非凸性,引入中间变量并对其进行二阶锥松弛,构建混合整数凸规划模型,采用改进的 IEEE33 节点配电网进行算例仿真,分析了需求响应措施和清洁能源渗透率对配电网重构结果的影响。 该程序复现效果和出图较好(详见程序结果部分),注释清楚,方便学习 ,高比例清洁能源; 需求响应; 配电网重构; 二阶锥松弛; 综合成本最小化; MATLAB代码; IEEE33节点配电网; 复现效果; 出图; 注释清楚。,Matlab代码复现:高比例清洁能源接入下的配电网重构模型与需求响应分析
# 基于C++的RapidJSON库测试项目 ## 项目简介 本项目是一个基于C++的RapidJSON库测试项目,主要用于测试RapidJSON库的功能正确性、性能以及稳定性。RapidJSON是一个高效的C++ JSON解析生成库,广泛应用于各种场景。本项目通过编写一系列的单元测试,覆盖了RapidJSON库的主要功能点,包括JSON解析、生成、内存管理、编码转换等,以确保RapidJSON库在各种情况下都能正确、稳定地工作。 ## 项目的主要特性和功能 1. 单元测试框架使用Google Test测试框架进行单元测试,确保测试的可靠性和可扩展性。 2. 全面测试覆盖覆盖了RapidJSON库的主要功能点,包括JSON解析、生成、内存管理、编码转换等,以及针对各种输入数据的测试。 3. 性能测试通过性能基准测试,评估RapidJSON库在处理不同规模和类型的JSON数据时的性能表现。
蓝桥杯算法学习冲刺(主要以题目为主)
内容概要:本文详细介绍如何安装和初步使用 VMware 虚拟机,从下载安装 VMware 到创建和配置新的虚拟机。主要内容包括:软件选择和安装步骤、虚拟机的新建配置、操作系统安装及初始化设置、安装 VMware Tools 提升性能以及一些常用的 VMWare 功能,如虚拟网络的不同连接方式及其应用场景。同时介绍了 VMware 软件在网络连接管理和服务配置方面的一些要点,确保虚拟机正常运行。 适用人群:计算机操作较为熟练、有意搭建不同操作系统测试环境的技术人员,以及想要了解虚拟机基本概念及应用的学生。 使用场景及目标:适合于个人用户进行系统兼容性和安全性的验证;适用于企业或开发者做软件测试、模拟复杂环境下作业,确保不影响宿主机正常工作的前提下完成多种任务;适用于教学培训环境中部署实验平台。此外,还可以用来隔离特定业务流程(比如银行工具)、探索不同类型操作系统的特点。 其他说明:需要注意的是,为了避免安装过程中出现问题,建议暂时关闭杀毒软件和防火墙。安装 VMware 需要接受许可协议,同时可以选择安装路径和安装类型(典型/自定义)。最后,对于网络设置,默认提供的三种模式——桥接模式、仅主机模式和 NAT 模式,可以帮助用户根据不同需求灵活调整网络连接方式。
java毕业设计源码