【JavaWeb】日程管理系统 项目搭建 第二期

文章目录

  • 一、数据库准备
  • 二、导入依赖 与 JDBC工具类
  • 三、pojo包处理
  • 四、dao
    • dao包工具类
  • 五、service
  • 六、controller
    • servlet 基类 反射
  • 七、加密工具类 MD5
  • 八、页面文件
  • 九、业务代码
    • 9.1 注册业务处理
    • 9.2 登录业务处理
  • 总结


一、数据库准备

创建数据库:
1

SET NAMES utf8mb4;
SET FOREIGN_KEY_CHECKS = 0;-- ----------------------------
-- 创建日程表
-- ----------------------------
DROP TABLE IF EXISTS `sys_schedule`;
CREATE TABLE `sys_schedule`  (`sid` int NOT NULL AUTO_INCREMENT,`uid` int NULL DEFAULT NULL,`title` varchar(20) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL,`completed` int(1) NULL DEFAULT NULL,PRIMARY KEY (`sid`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_0900_ai_ci ROW_FORMAT = Dynamic;-- ----------------------------
-- 插入日程数据
-- ------------------------------ ----------------------------
-- 创建用户表
-- ----------------------------
DROP TABLE IF EXISTS `sys_user`;
CREATE TABLE `sys_user`  (`uid` int NOT NULL AUTO_INCREMENT,`username` varchar(10) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL,`user_pwd` varchar(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL,PRIMARY KEY (`uid`) USING BTREE,UNIQUE INDEX `username`(`username`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_0900_ai_ci ROW_FORMAT = Dynamic;-- ----------------------------
-- 插入用户数据
-- ----------------------------
INSERT INTO `sys_user` VALUES (1, 'zhangsan', 'e10adc3949ba59abbe56e057f20f883e');
INSERT INTO `sys_user` VALUES (2, 'lisi', 'e10adc3949ba59abbe56e057f20f883e');SET FOREIGN_KEY_CHECKS = 1;

1

二、导入依赖 与 JDBC工具类

使用lombok处理 getter setter equals hashcode 构造器
1

导入JDBCUtil连接池工具类并准备jdbc.properties配置文件

package com.doug.wake.util;import com.alibaba.druid.pool.DruidDataSourceFactory;import javax.sql.DataSource;
import java.io.IOException;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.SQLException;
import java.util.Properties;/*** @Description: JDBCUtil连接池工具类*/
public class JDBCUtil {private static ThreadLocal<Connection> threadLocal =new ThreadLocal<>();private static DataSource dataSource;// 初始化连接池static{// 可以帮助我们读取.properties配置文件Properties properties =new Properties();InputStream resourceAsStream = JDBCUtil.class.getClassLoader().getResourceAsStream("jdbc.properties");try {properties.load(resourceAsStream);} catch (IOException e) {throw new RuntimeException(e);}try {dataSource = DruidDataSourceFactory.createDataSource(properties);} catch (Exception e) {throw new RuntimeException(e);}}/*1 向外提供连接池的方法*/public static DataSource getDataSource(){return dataSource;}/*2 向外提供连接的方法*/public static Connection getConnection(){Connection connection = threadLocal.get();if (null == connection) {try {connection = dataSource.getConnection();} catch (SQLException e) {throw new RuntimeException(e);}threadLocal.set(connection);}return connection;}/*定义一个归还连接的方法 (解除和ThreadLocal之间的关联关系) */public static void releaseConnection(){Connection connection = threadLocal.get();if (null != connection) {threadLocal.remove();// 把连接设置回自动提交的连接try {connection.setAutoCommit(true);// 自动归还到连接池connection.close();} catch (SQLException e) {throw new RuntimeException(e);}}}
}

1

driverClassName=com.mysql.cj.jdbc.Driver
url=jdbc:mysql://localhost:3306/schedule_system
username=root
password=root
initialSize=5
maxActive=10
maxWait=1000

三、pojo包处理

实体类:

使用lombok处理getter setter equals hashcode 构造器

implements Serializable : 习惯上要实现序列化接口,与缓存、分布式项目数据传递有关 将对象序列化 防止报错

@AllArgsConstructor // 全参构造
@NoArgsConstructor // 添加无参构造
@Data         //getter setter equals hashcode toString
public class SysUser implements Serializable {private int uid;private String username;private String userPwd;
}@AllArgsConstructor
@NoArgsConstructor
@Data
public class SysSchedule {private int sid;private int uid;private String title;private int completed;
}

四、dao

Data access Object 数据访问对象
该类中用于定义针对数据库表格CRUD的方法
DAO层一般需要定义接口和实现类

dao包工具类

package com.doug.wake.dao;import com.doug.wake.util.JDBCUtil;import java.lang.reflect.Field;
import java.sql.*;
import java.time.LocalDateTime;
import java.util.ArrayList;
import java.util.List;/*** @Description: Dao工具类*/
public class BaseDao {// 公共的查询方法  返回的是单个对象public <T> T baseQueryObject(Class<T> clazz, String sql, Object ... args) {T t = null;Connection connection = JDBCUtil.getConnection();PreparedStatement preparedStatement = null;ResultSet resultSet = null;int rows = 0;try {// 准备语句对象preparedStatement = connection.prepareStatement(sql);// 设置语句上的参数for (int i = 0; i < args.length; i++) {preparedStatement.setObject(i + 1, args[i]);}// 执行 查询resultSet = preparedStatement.executeQuery();if (resultSet.next()) {t = (T) resultSet.getObject(1);}} catch (Exception e) {e.printStackTrace();} finally {if (null != resultSet) {try {resultSet.close();} catch (SQLException e) {e.printStackTrace();}}if (null != preparedStatement) {try {preparedStatement.close();} catch (SQLException e) {e.printStackTrace();}}JDBCUtil.releaseConnection();}return t;}// 公共的查询方法  返回的是对象的集合public <T> List<T> baseQuery(Class clazz, String sql, Object ... args){List<T> list =new ArrayList<>();Connection connection = JDBCUtil.getConnection();PreparedStatement preparedStatement=null;ResultSet resultSet =null;int rows = 0;try {// 准备语句对象preparedStatement = connection.prepareStatement(sql);// 设置语句上的参数for (int i = 0; i < args.length; i++) {preparedStatement.setObject(i+1,args[i]);}// 执行 查询resultSet = preparedStatement.executeQuery();ResultSetMetaData metaData = resultSet.getMetaData();int columnCount = metaData.getColumnCount();// 将结果集通过反射封装成实体类对象while (resultSet.next()) {// 使用反射实例化对象Object obj =clazz.getDeclaredConstructor().newInstance();for (int i = 1; i <= columnCount; i++) {String columnName = metaData.getColumnLabel(i);Object value = resultSet.getObject(columnName);// 处理datetime类型字段和java.util.Data转换问题if(value.getClass().equals(LocalDateTime.class)){value= Timestamp.valueOf((LocalDateTime) value);}Field field = clazz.getDeclaredField(columnName);field.setAccessible(true);field.set(obj,value);}list.add((T)obj);}} catch (Exception e) {e.printStackTrace();} finally {if (null !=resultSet) {try {resultSet.close();} catch (SQLException e) {throw new RuntimeException(e);}}if (null != preparedStatement) {try {preparedStatement.close();} catch (SQLException e) {throw new RuntimeException(e);}}JDBCUtil.releaseConnection();}return list;}// 通用的增删改方法public int baseUpdate(String sql,Object ... args) {// 获取连接Connection connection = JDBCUtil.getConnection();PreparedStatement preparedStatement=null;int rows = 0;try {// 准备语句对象preparedStatement = connection.prepareStatement(sql);// 设置语句上的参数for (int i = 0; i < args.length; i++) {preparedStatement.setObject(i+1,args[i]);}// 执行 增删改 executeUpdaterows = preparedStatement.executeUpdate();// 释放资源(可选)} catch (SQLException e) {e.printStackTrace();} finally {if (null != preparedStatement) {try {preparedStatement.close();} catch (SQLException e) {throw new RuntimeException(e);}}JDBCUtil.releaseConnection();}// 返回的是影响数据库记录数return rows;}
}

基本按照这样写:

  • Dao 接口
/*** @Description: 日程表CRUD*/
public interface SysScheduleDao {/*** 用于向数据中增加一条日程记录* @param schedule 日程数据以SysSchedule实体类对象形式入参* @return 返回影响数据库记录的行数,行数为0增加失败,行数大于0增加成功*/int addSchedule(SysSchedule schedule);/*** 查找所有的日程信息* @return 返回全部日程数据*/List<SysSchedule> findSchedule();
}
public interface SysUserDao {/*** 向数据库表sys_user增加一条用户记录的方法* @param sysUser 要增加记录的username和usePwd 以SysUser对象的形式接收* @return 增加 成功返回 1, 失败0*/int addUser(SysUser sysUser);
}
  • Dao实现类:
public class SysScheduleDaoImpl extends BaseDao implements SysScheduleDao {@Overridepublic int addSchedule(SysSchedule schedule) {String sql = "insert into sys_schedule values(DEFAULT,?,?,?)";int rows = baseUpdate(sql, schedule.getUid(),schedule.getTitle(), schedule.getCompleted());return rows;}@Overridepublic List<SysSchedule> findSchedule() {String sql = "select sid,uid,title,completed from sys_schedule";List<SysSchedule> scheduleList = baseQuery(SysSchedule.class, sql);return scheduleList;}
}
public class SysUserDaoImpl extends BaseDao implements SysUserDao {@Overridepublic int addUser(SysUser sysUser) {String sql = "insert into sys_user values(DEFAULT,?,?);";int rows = baseUpdate(sql, sysUser.getUsername(), sysUser.getUserPwd());return rows;}
}

五、service

1
这样写: 写注释

/*** 该接口定义了以 sys_user 表 为核心的业务处理功能*/
public interface SysUserService {/*** 用户注册方法* @param sysUser 要注册的用户名和明文密码 以SysUser对象的形式接收* @return 注册 成功返回1 , 失败返回0*/int regist(SysUser sysUser);
}
public class SysUserServiceImpl implements SysUserService {private SysUserDao userDao = new SysUserDaoImpl();@Overridepublic int regist(SysUser sysUser) {//密码加密sysUser.setUserPwd(MD5Util.encrypt(sysUser.getUserPwd()));return userDao.addUser(sysUser);}
}

六、controller

前端 action 格式: servlet 的名字 + 方法名
user/add
user/remove …

  • 接收前端传来的URI【 /user/add 】截取后面的add 再定义同名方法,
  • 这样就自动invoke执行相同名字的方法
  • 不用自己手动去写ifelse( 加一个方法就得写一个
    2

servlet 基类 反射

/*** @Description: Controller servlet基类 使用反射调用方法*/
public class BaseController extends HttpServlet {@Overrideprotected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {//拿到方法的URI 格式:项目上下文Context 加上 后缀名 //举例项目Context设置为空时: /schedule/addString requestURI = req.getRequestURI();//拿到最后的 add 方法名String[] split = requestURI.split("/");String methodName = split[split.length - 1];//使用反射 获取所有的方法Class aClass = this.getClass();try {Method declaredMethod = aClass.getDeclaredMethod(methodName, HttpServletRequest.class, HttpServletResponse.class);//取消访问检查 防止方法为私有导致不能执行declaredMethod.setAccessible(true);//执行方法 传入参数declaredMethod.invoke(this, req, resp);} catch (Exception e) {e.printStackTrace();}}
}

这样只要 继承基类 定义 方法即可

@WebServlet("/schedule/*")
public class SysScheduleController extends BaseController{protected void add(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {System.out.println("add");}
}
@WebServlet("/user/*")
public class SysUserController extends BaseController{private SysUserService userService = new SysUserServiceImpl();/*** 接收用户注册的业务请求 处理方法* @param req* @param resp* @throws ServletException* @throws IOException*/protected void regist(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {String username = req.getParameter("username");String userPwd = req.getParameter("userPwd");SysUser sysUser = new SysUser(null, username, userPwd);int rows =  userService.regist(sysUser);if (rows > 0){resp.sendRedirect("/registSuccess.html");}else{resp.sendRedirect("/registFail.html");}}
}

七、加密工具类 MD5

public class MD5Util {public static String encrypt(String strSrc) {try {char hexChars[] = { '0', '1', '2', '3', '4', '5', '6', '7', '8','9', 'a', 'b', 'c', 'd', 'e', 'f' };byte[] bytes = strSrc.getBytes();MessageDigest md = MessageDigest.getInstance("MD5");md.update(bytes);bytes = md.digest();int j = bytes.length;char[] chars = new char[j * 2];int k = 0;for (int i = 0; i < bytes.length; i++) {byte b = bytes[i];chars[k++] = hexChars[b >>> 4 & 0xf];chars[k++] = hexChars[b & 0xf];}return new String(chars);} catch (NoSuchAlgorithmException e) {e.printStackTrace();throw new RuntimeException("MD5加密出错!!!");}}
}

八、页面文件

1
注册页面:
1
登录页面
2

九、业务代码

9.1 注册业务处理

controller (servlet)

@WebServlet("/user/*")
public class SysUserController extends BaseController{private SysUserService userService = new SysUserServiceImpl();/*** 接收用户注册的业务请求 处理方法* @param req* @param resp* @throws ServletException* @throws IOException*/protected void regist(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {String username = req.getParameter("username");String userPwd = req.getParameter("userPwd");SysUser sysUser = new SysUser(null, username, userPwd);int rows =  userService.regist(sysUser);if (rows > 0){resp.sendRedirect("/registSuccess.html");}else{resp.sendRedirect("/registFail.html");}}
}

service 业务代码

/*** 该接口定义了以 sys_user 表 为核心的业务处理功能*/
public interface SysUserService {/*** 用户注册方法* @param sysUser 要注册的用户名和明文密码 以SysUser对象的形式接收* @return 注册 成功返回1 , 失败返回0*/int regist(SysUser sysUser);
}
public class SysUserServiceImpl implements SysUserService {private SysUserDao userDao = new SysUserDaoImpl();@Overridepublic int regist(SysUser sysUser) {//密码加密sysUser.setUserPwd(MD5Util.encrypt(sysUser.getUserPwd()));return userDao.addUser(sysUser);}
}

dao 数据库

/*** @Description: 用户CRUD*/
public interface SysUserDao {/*** 向数据库表sys_user增加一条用户记录的方法* @param sysUser 要增加记录的username和usePwd 以SysUser对象的形式接收* @return 增加 成功返回 1, 失败0*/int addUser(SysUser sysUser);
}
public class SysUserDaoImpl extends BaseDao implements SysUserDao {@Overridepublic int addUser(SysUser sysUser) {String sql = "insert into sys_user values(DEFAULT,?,?);";int rows = baseUpdate(sql, sysUser.getUsername(), sysUser.getUserPwd());return rows;}
}

9.2 登录业务处理

controller :

 /*** 接收用户登录请求,完成登录业务接口* @param req* @param resp* @throws ServletException* @throws IOException*/protected void login(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {String username = req.getParameter("username");String userPwd = req.getParameter("userPwd");//通过用户名查找对象SysUser loginUser = userService.findUserByUsername(username);//用户为Null不存在if(null == loginUser){resp.sendRedirect("/loginUsernameError.html");//密码不匹配} else if (!MD5Util.encrypt(userPwd).equals(loginUser.getUserPwd())) {resp.sendRedirect("/loginUserPwdError.html");}else{resp.sendRedirect("/showSchedule.html");}}

service

    /*** 根据用户名查找完整的user对象* @param username 要查找的用户名* @return 查到返回SysUser对象,找不到返回Null*/SysUser findUserByUsername(String username);@Overridepublic SysUser findUserByUsername(String username) {return userDao.findUserByUsername(username);}

dao

    /*** 根据用户名查找完整的user对象* @param username 要查找的用户名* @return 查到返回SysUser对象,找不到返回Null*/SysUser findUserByUsername(String username);@Overridepublic SysUser findUserByUsername(String username) {String sql = "select uid,username,user_pwd as userPwd from sys_user where username=?;";List<SysUser> sysUserList = baseQuery(SysUser.class, sql, username);return sysUserList != null && sysUserList.size() > 0 ? sysUserList.get(0) : null;}

总结

开启注解处理:
1
测试类:
测试日程表的CRUD 调用DAO层方法

public class TestSysScheduleDao {private static SysScheduleDao sysScheduleDao;@BeforeClasspublic static void initSysScheduleDaoImpl(){sysScheduleDao = new SysScheduleDaoImpl();}@Testpublic void testAddSchedule(){int rows = sysScheduleDao.addSchedule(new SysSchedule(null, 2, "学习后端", 0));System.out.println(rows);}@Testpublic void testFindSchedule(){List<SysSchedule> scheduleList = sysScheduleDao.findSchedule();scheduleList.forEach(System.out::println);}
}

测试BaseDao工具类:

    private static BaseDao baseDao;@BeforeClasspublic static void initBaseDao(){baseDao = new BaseDao();}@Testpublic void testBaseUpdate(){String sql = "insert into sys_schedule values(DEFAULT,?,?,?)";int rows = baseDao.baseUpdate(sql, 1, "学习JS", 1);System.out.println(rows);}@Testpublic void testBaseQuery(){String sql = "select sid,uid,title,completed from sys_schedule";List<SysSchedule> listSchedules = baseDao.baseQuery(SysSchedule.class, sql);listSchedules.forEach(System.out::println);}@Testpublic void testBaseSingleQuery(){String sql = "select count(1) from sys_schedule";Long aLong = baseDao.baseQueryObject(Long.class, sql);System.out.println(aLong);}

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

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

相关文章

vue折叠展开transition动画使用keyframes实现

需求&#xff0c;我正常的菜单功能有隐藏与显示功能&#xff0c;需要增加动画 打开的时候宽度从0到300&#xff0c;关闭的时候&#xff0c;宽度从300到0 <template> <div id"app"> <button click"toggleLength">Toggle Length</bu…

骨传导耳机综评:透视南卡、韶音和墨觉三大品牌的性能与特点

在当前的蓝牙音频设备领域中&#xff0c;骨传导蓝牙运动耳机以其出色的安全特性和舒适的体验&#xff0c;受到了健身爱好者们的广泛好评。这类耳机不同于我们常见的入耳式耳机&#xff0c;它的工作方式是直接通过振动将声音传递到用户的耳骨中&#xff0c;这样既可以享受音乐&a…

【nowcoder】链表的回文结构

牛客题目链接 链表的回文结构 /* struct ListNode {int val;struct ListNode *next;ListNode(int x) : val(x), next(NULL) {} };*/ #include <cstdlib> // 建议大伙自己对照我的代码画下图&#xff0c;假设A链表是&#xff1a;1 2 3 2 1 class PalindromeList { publi…

【学网攻】 第(7)节 -- 生成树配置

文章目录 【学网攻】 第(1)节 -- 认识网络【学网攻】 第(2)节 -- 交换机认识及使用【学网攻】 第(3)节 -- 交换机配置聚合端口【学网攻】 第(4)节 -- 交换机划分Vlan【学网攻】 第(5)节 -- Cisco VTP的使用【学网攻】 第(6)节 -- 三层交换机实现VLAN间路由 前言 网络已经成为…

vscode 如何指定启动文件?

launch.json 里面可以指定&#xff0c;launch.json 在打开文件夹的时候可以创建&#xff0c;或者手动创建

不合格机器人工程讲师再读《悉达多》-2024-

一次又一次失败的经历&#xff0c;让我对经典书籍的认同感越来越多&#xff0c;越来越觉得原来的自己是多么多么的无知和愚昧。 ----zhangrelay 唯物也好&#xff0c;唯心也罢&#xff0c;我们都要先热爱这个世界&#xff0c;然后才能在其中找到自己所热爱的事业。 ----zh…

【OpenCV】P2 程序加载显示图片

目录 四个步骤读取图像创建窗口显示图像释放内存 完整代码 在 Opencv 中&#xff0c;如果想要加载展示一张图片&#xff0c;有以下几个步骤&#xff1a; 读取图像&#xff1a;根据指定路径读取图像&#xff0c;将图像转化为数字矩阵形式&#xff1b;创建窗口&#xff1a;创建图…

vue2项目打包到测试环境之后报错require is not defined

配置打包命令npm run build:test到测试环境之后报错&#xff0c;打包到生产环境没有问题&#xff0c;查找了项目中的require引入似乎也没啥有问题的地方&#xff0c;所以排除是require的原因 环境变量文件&#xff1a; 打包指令&#xff1a; 解决办法&#xff1a; 将.env.tes…

【vue开发示例介绍】

vue开发示例介绍 1. 开发示例1.1 做一个自定义组件Welcome1.2 增加“用户管理”和“关于我们”组件1.3 嵌套路由 1. 开发示例 1.1 做一个自定义组件Welcome 1&#xff09; 在components下创建一个Welcome.vue自定义组件 <template><div class"hello">…

九、C++结构体(1)

一、结构体概念 结构体属于用户自定义的数据类型&#xff0c;允许用户存储不同的数据类型 二、结构体定义和使用 语法&#xff1a; struct 结构体名 {结构体成员列表}; 通过结构体创建变量的方式有三种&#xff1a; 1、struct 结构体名 变量名 2、struct 结构体名 变量名…

[docker] Docker 网络和Cgroup

一、Docker 网络 1.1 Docker 网络实现原理 Docker使用Linux桥接&#xff0c;在宿主机虚拟一个Docker容器网桥(docker0)&#xff0c;Docker启动一个容器时会根据Docker网桥的网段分配给容器一个IP地址&#xff0c;称为Container-IP&#xff0c;同时Docker网桥是每个容器的默认…

go语言模板处理包text/template详解

本文对go语言内置模板处理包"text/template"常用操作汇总进行了详解&#xff0c;非常全面&#xff0c;一次搞定你的问题&#xff01;还不收藏等啥呢&#xff01; 目录 通用结构体定义 通用转换 1&#xff0c;基础操作 2&#xff0c;解析文件 3&#xff0c;自定义…

【C/C++】C/C++编程——C++ 开发环境搭建

C的开发环境种类繁多&#xff0c;以下是一些常见的C 集成开发环境&#xff1a; AppCode &#xff1a;构建与JetBrains’ IntelliJ IDEA 平台上的用于Objective-C&#xff0c;C,C&#xff0c;Java和Java开发的集成开发环境CLion&#xff1a;来自JetBrains的跨平台的C/C的集成开…

《动手学深度学习(PyTorch版)》笔记2

Chapter2 Preliminaries 2.1 Automatic Differentiation 让计算机实现微分功能&#xff0c; 有以下四种方式&#xff1a; - 手工计算出微分&#xff0c; 然后编码进代码 - 数值微分 (numerical differentiation) - 符号微分 (symbolic differentiation) - 自动微分&#xff0…

java web mvc-03-JFinal

拓展阅读 Spring Web MVC-00-重学 mvc mvc-01-Model-View-Controller 概览 web mvc-03-JFinal web mvc-04-Apache Wicket web mvc-05-JSF JavaServer Faces web mvc-06-play framework intro web mvc-07-Vaadin web mvc-08-Grails JFinal JFinal 是基于 Java 语言的极…

go语言基本类型

Golang 更明确的数字类型命名&#xff0c;支持 Unicode&#xff0c;支持常用数据结构。 类型长度(字节)默认值说明bool1falsebyte10uint8rune40Unicode Code Point, int32int, uint4或8032 或 64 位int8, uint810-128 ~ 127, 0 ~ 255&#xff0c;byte是uint8 的别名int16, uin…

Prompt Engineering

目录 什么是提示工程 什么是提示工程 在当今人工智能领域&#xff0c;提问大型语言模型&#xff08;Large Language Models&#xff0c;LLM&#xff09;已经成为一种常见的实践&#xff0c;但如何向这些模型提出问题&#xff0c;或者更准确地说&#xff0c;如何引导它们产生期…

Shell脚本③条件语句、if命令和case命令

目录 一.条件语句 1.test测试条件表达式 2.整数数值比较 &#xff08;1&#xff09;比较两个整数大小 &#xff08;2&#xff09;查看系统剩余内存是否低于1024M 3.逻辑测试 4.三元运算符 二.if命令 1.单分支结构 2.双分支结构 3.多分支结构 三.case语句 四.脚本 …

代码随想录算法训练营第十三天|层序遍历10,226.翻转二叉树,101.对称二叉树

系列文章目录 代码随想录算法训练营第一天|数组理论基础&#xff0c;704. 二分查找&#xff0c;27. 移除元素 代码随想录算法训练营第二天|977.有序数组的平方 &#xff0c;209.长度最小的子数组 &#xff0c;59.螺旋矩阵II 代码随想录算法训练营第三天|链表理论基础&#xff…

项目成本估算基准的常见步骤

项目成本估算基准是指在项目启动阶段确定的用于衡量和控制项目成本的基准。 基准成本是项目成本估算的依据&#xff0c;也是后续成本控制和决策的依据。它为管理层提供项目预算投资方案等关键投资依据&#xff0c;决定资源的分配情况&#xff0c;有助于优化资源使用效率&#x…