当前位置: 首页 > news >正文

教材管理系统设计与实现

教材管理系统设计与实现

在这里插入图片描述

1. 系统概述

教材管理系统是一个基于PHP和SQL的Web应用程序,旨在为学校提供一个高效的教材管理平台。该系统可以帮助管理员录入教材信息、教师查询和申请教材、学生查询教材信息,提高教材管理的效率和透明度。

2. 技术栈
  • 前端:HTML5, CSS3, JavaScript, jQuery, Bootstrap
  • 后端:PHP
  • 数据库:MySQL
  • 服务器:Apache
3. 系统功能模块
  1. 用户管理

    • 用户注册与登录
    • 用户信息管理
    • 角色权限管理(管理员、教师、学生)
  2. 教材管理

    • 教材信息录入
    • 教材信息查询
    • 教材信息修改
    • 教材信息删除
  3. 申请管理

    • 教师申请教材
    • 管理员审批申请
  4. 库存管理

    • 教材库存查询
    • 教材库存更新
  5. 系统设置

    • 数据备份与恢复
    • 系统日志管理
    • 参数配置
4. 数据库设计
4.1 数据库表结构
  1. 用户表(users)

    • id (INT, 主键)
    • username (VARCHAR, 用户名)
    • password (VARCHAR, 密码)
    • role (VARCHAR, 角色)
    • created_at (DATETIME, 创建时间)
    • updated_at (DATETIME, 更新时间)
  2. 教材表(textbooks)

    • id (INT, 主键)
    • title (VARCHAR, 教材名称)
    • author (VARCHAR, 作者)
    • publisher (VARCHAR, 出版社)
    • isbn (VARCHAR, ISBN编号)
    • quantity (INT, 库存数量)
    • created_at (DATETIME, 创建时间)
    • updated_at (DATETIME, 更新时间)
  3. 申请表(applications)

    • id (INT, 主键)
    • user_id (INT, 外键,关联用户表)
    • textbook_id (INT, 外键,关联教材表)
    • quantity (INT, 申请数量)
    • status (VARCHAR, 申请状态)
    • created_at (DATETIME, 创建时间)
    • updated_at (DATETIME, 更新时间)
5. 系统架构设计
5.1 层次结构
  1. 表现层(Presentation Layer)

    • 负责接收用户的请求,并返回处理结果。
    • 使用PHP和HTML/CSS/JavaScript实现。
  2. 业务逻辑层(Business Logic Layer)

    • 负责处理具体的业务逻辑。
    • 使用PHP实现。
  3. 数据访问层(Data Access Layer)

    • 负责与数据库交互,执行增删改查操作。
    • 使用PHP的PDO扩展实现。
5.2 控制器(Controller)

控制器负责处理用户的请求,并调用相应的模型方法。示例如下:

<?php
session_start();// 连接数据库
$host = 'localhost';
$db = 'textbook_management';
$user = 'root';
$pass = '';try {$pdo = new PDO("mysql:host=$host;dbname=$db;charset=utf8", $user, $pass);$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
} catch (PDOException $e) {die("Could not connect to the database $db :" . $e->getMessage());
}// 用户登录
if (isset($_POST['login'])) {$username = $_POST['username'];$password = $_POST['password'];$stmt = $pdo->prepare("SELECT * FROM users WHERE username = :username AND password = :password");$stmt->execute(['username' => $username, 'password' => $password]);$user = $stmt->fetch();if ($user) {$_SESSION['user'] = $user;header('Location: dashboard.php');} else {echo "Invalid username or password.";}
}
?>
5.3 模型(Model)

模型负责处理数据的存取操作。示例如下:

<?php
class Textbook {private $pdo;public function __construct($pdo) {$this->pdo = $pdo;}public function getAllTextbooks() {$stmt = $this->pdo->query("SELECT * FROM textbooks");return $stmt->fetchAll(PDO::FETCH_ASSOC);}public function addTextbook($title, $author, $publisher, $isbn, $quantity) {$stmt = $this->pdo->prepare("INSERT INTO textbooks (title, author, publisher, isbn, quantity) VALUES (:title, :author, :publisher, :isbn, :quantity)");$stmt->execute(['title' => $title, 'author' => $author, 'publisher' => $publisher, 'isbn' => $isbn, 'quantity' => $quantity]);}public function getTextbookById($id) {$stmt = $this->pdo->prepare("SELECT * FROM textbooks WHERE id = :id");$stmt->execute(['id' => $id]);return $stmt->fetch(PDO::FETCH_ASSOC);}public function updateTextbook($id, $title, $author, $publisher, $isbn, $quantity) {$stmt = $this->pdo->prepare("UPDATE textbooks SET title = :title, author = :author, publisher = :publisher, isbn = :isbn, quantity = :quantity WHERE id = :id");$stmt->execute(['id' => $id, 'title' => $title, 'author' => $author, 'publisher' => $publisher, 'isbn' => $isbn, 'quantity' => $quantity]);}public function deleteTextbook($id) {$stmt = $this->pdo->prepare("DELETE FROM textbooks WHERE id = :id");$stmt->execute(['id' => $id]);}
}
?>
5.4 视图(View)

视图负责显示数据。示例如下:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>教材列表</title><link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.5.2/css/bootstrap.min.css">
</head>
<body><div class="container"><h1>教材列表</h1><table class="table table-striped"><thead><tr><th>教材名称</th><th>作者</th><th>出版社</th><th>ISBN编号</th><th>库存数量</th><th>操作</th></tr></thead><tbody><?php foreach ($textbooks as $textbook): ?><tr><td><?php echo $textbook['title']; ?></td><td><?php echo $textbook['author']; ?></td><td><?php echo $textbook['publisher']; ?></td><td><?php echo $textbook['isbn']; ?></td><td><?php echo $textbook['quantity']; ?></td><td><a href="edit-textbook.php?id=<?php echo $textbook['id']; ?>" class="btn btn-primary">编辑</a><a href="delete-textbook.php?id=<?php echo $textbook['id']; ?>" class="btn btn-danger">删除</a></td></tr><?php endforeach; ?></tbody></table><a href="add-textbook.php" class="btn btn-success">添加教材</a></div>
</body>
</html>
6. 功能实现
6.1 用户注册与登录
  • 注册页面(register.php)
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>注册</title><link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.5.2/css/bootstrap.min.css">
</head>
<body><div class="container"><h1>注册</h1><form action="register.php" method="post"><div class="form-group"><label for="username">用户名</label><input type="text" class="form-control" id="username" name="username" required></div><div class="form-group"><label for="password">密码</label><input type="password" class="form-control" id="password" name="password" required></div><div class="form-group"><label for="role">角色</label><select class="form-control" id="role" name="role" required><option value="admin">管理员</option><option value="teacher">教师</option><option value="student">学生</option></select></div><button type="submit" name="register" class="btn btn-primary">注册</button></form></div>
</body>
</html>
  • 注册处理(register.php)
<?php
session_start();// 连接数据库
$host = 'localhost';
$db = 'textbook_management';
$user = 'root';
$pass = '';try {$pdo = new PDO("mysql:host=$host;dbname=$db;charset=utf8", $user, $pass);$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
} catch (PDOException $e) {die("Could not connect to the database $db :" . $e->getMessage());
}if (isset($_POST['register'])) {$username = $_POST['username'];$password = $_POST['password'];$role = $_POST['role'];$stmt = $pdo->prepare("INSERT INTO users (username, password, role) VALUES (:username, :password, :role)");$stmt->execute(['username' => $username, 'password' => $password, 'role' => $role]);echo "注册成功!";
}
?>
  • 登录页面(login.php)
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>登录</title><link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.5.2/css/bootstrap.min.css">
</head>
<body><div class="container"><h1>登录</h1><form action="login.php" method="post"><div class="form-group"><label for="username">用户名</label><input type="text" class="form-control" id="username" name="username" required></div><div class="form-group"><label for="password">密码</label><input type="password" class="form-control" id="password" name="password" required></div><button type="submit" name="login" class="btn btn-primary">登录</button></form></div>
</body>
</html>
  • 登录处理(login.php)
<?php
session_start();// 连接数据库
$host = 'localhost';
$db = 'textbook_management';
$user = 'root';
$pass = '';try {$pdo = new PDO("mysql:host=$host;dbname=$db;charset=utf8", $user, $pass);$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
} catch (PDOException $e) {die("Could not connect to the database $db :" . $e->getMessage());
}if (isset($_POST['login'])) {$username = $_POST['username'];$password = $_POST['password'];$stmt = $pdo->prepare("SELECT * FROM users WHERE username = :username AND password = :password");$stmt->execute(['username' => $username, 'password' => $password]);$user = $stmt->fetch();if ($user) {$_SESSION['user'] = $user;header('Location: dashboard.php');} else {echo "Invalid username or password.";}
}
?>
6.2 教材管理
  • 添加教材页面(add-textbook.php)
<?php
session_start();if (!isset($_SESSION['user']) || $_SESSION['user']['role'] !== 'admin') {header('Location: login.php');exit;
}$pdo = new PDO("mysql:host=localhost;dbname=textbook_management;charset=utf8", "root", "");if (isset($_POST['submit'])) {$title = $_POST['title'];$author = $_POST['author'];$publisher = $_POST['publisher'];$isbn = $_POST['isbn'];$quantity = $_POST['quantity'];$textbook = new Textbook($pdo);$textbook->addTextbook($title, $author, $publisher, $isbn, $quantity);header('Location: manage-textbooks.php');
}
?>
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>添加教材</title><link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.5.2/css/bootstrap.min.css">
</head>
<body><div class="container"><h1>添加教材</h1><form action="add-textbook.php" method="post"><div class="form-group"><label for="title">教材名称</label><input type="text" class="form-control" id="title" name="title" required></div><div class="form-group"><label for="author">作者</label><input type="text" class="form-control" id="author" name="author" required></div><div class="form-group"><label for="publisher">出版社</label><input type="text" class="form-control" id="publisher" name="publisher" required></div><div class="form-group"><label for="isbn">ISBN编号</label><input type="text" class="form-control" id="isbn" name="isbn" required></div><div class="form-group"><label for="quantity">库存数量</label><input type="number" class="form-control" id="quantity" name="quantity" min="0" required></div><button type="submit" name="submit" class="btn btn-primary">添加</button></form></div>
</body>
</html>
6.3 教材申请管理
  • 教师申请教材页面(apply-textbook.php)
<?php
session_start();if (!isset($_SESSION['user']) || $_SESSION['user']['role'] !== 'teacher') {header('Location: login.php');exit;
}$pdo = new PDO("mysql:host=localhost;dbname=textbook_management;charset=utf8", "root", "");$textbook = new Textbook($pdo);
$textbooks = $textbook->getAllTextbooks();if (isset($_POST['submit'])) {$user_id = $_SESSION['user']['id'];$textbook_id = $_POST['textbook_id'];$quantity = $_POST['quantity'];$stmt = $pdo->prepare("INSERT INTO applications (user_id, textbook_id, quantity, status) VALUES (:user_id, :textbook_id, :quantity, 'pending')");$stmt->execute(['user_id' => $user_id, 'textbook_id' => $textbook_id, 'quantity' => $quantity]);header('Location: my-applications.php');
}
?>
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>申请教材</title><link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.5.2/css/bootstrap.min.css">
</head>
<body><div class="container"><h1>申请教材</h1><form action="apply-textbook.php" method="post"><div class="form-group"><label for="textbook_id">教材</label><select class="form-control" id="textbook_id" name="textbook_id" required><?php foreach ($textbooks as $textbook): ?><option value="<?php echo $textbook['id']; ?>"><?php echo $textbook['title']; ?> (库存: <?php echo $textbook['quantity']; ?>)</option><?php endforeach; ?></select></div><div class="form-group"><label for="quantity">申请数量</label><input type="number" class="form-control" id="quantity" name="quantity" min="1" required></div><button type="submit" name="submit" class="btn btn-primary">申请</button></form></div>
</body>
</html>
7. 安全性设计

为了保证系统的安全性,需要实现以下功能:

  • 用户认证:使用PHP会话管理进行用户认证和授权。
  • 数据校验:在控制器层进行输入参数的校验,防止SQL注入等攻击。
  • 日志记录:记录关键操作的日志,便于审计和故障排查。
8. 测试与部署
  • 单元测试:使用PHPUnit进行单元测试,确保各个模块的功能正确。
  • 集成测试:进行集成测试,确保各个模块之间的协同工作正常。
  • 部署:将应用程序部署到Apache服务器上,确保在生产环境中运行稳定。
9. 源代码

由于篇幅限制,无法完整展示所有源代码。以下是部分核心代码示例:

9.1 教材申请实体类(Application.php)
<?php
class Application {private $pdo;public function __construct($pdo) {$this->pdo = $pdo;}public function getAllApplications() {$stmt = $this->pdo->query("SELECT a.*, u.username, t.title FROM applications a JOIN users u ON a.user_id = u.id JOIN textbooks t ON a.textbook_id = t.id");return $stmt->fetchAll(PDO::FETCH_ASSOC);}public function getApplicationsByUserId($user_id) {$stmt = $this->pdo->prepare("SELECT a.*, t.title FROM applications a JOIN textbooks t ON a.textbook_id = t.id WHERE a.user_id = :user_id");$stmt->execute(['user_id' => $user_id]);return $stmt->fetchAll(PDO::FETCH_ASSOC);}public function approveApplication($id) {$stmt = $this->pdo->prepare("UPDATE applications SET status = 'approved' WHERE id = :id");$stmt->execute(['id' => $id]);}public function rejectApplication($id) {$stmt = $this->pdo->prepare("UPDATE applications SET status = 'rejected' WHERE id = :id");$stmt->execute(['id' => $id]);}
}
?>
9.2 查看我的申请页面(my-applications.php)
<?php
session_start();if (!isset($_SESSION['user'])) {header('Location: login.php');exit;
}$pdo = new PDO("mysql:host=localhost;dbname=textbook_management;charset=utf8", "root", "");$application = new Application($pdo);
$applications = $application->getApplicationsByUserId($_SESSION['user']['id']);
?>
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>我的申请</title><link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.5.2/css/bootstrap.min.css">
</head>
<body><div class="container"><h1>我的申请</h1><table class="table table-striped"><thead><tr><th>教材名称</th><th>申请数量</th><th>申请状态</th><th>操作</th></tr></thead><tbody><?php foreach ($applications as $application): ?><tr><td><?php echo $application['title']; ?></td><td><?php echo $application['quantity']; ?></td><td><?php echo $application['status']; ?></td><td><?php if ($application['status'] === 'pending'): ?><a href="cancel-application.php?id=<?php echo $application['id']; ?>" class="btn btn-danger">取消申请</a><?php endif; ?></td></tr><?php endforeach; ?></tbody></table><a href="apply-textbook.php" class="btn btn-primary">申请教材</a></div>
</body>
</html>

相关文章:

教材管理系统设计与实现

教材管理系统设计与实现 1. 系统概述 教材管理系统是一个基于PHP和SQL的Web应用程序&#xff0c;旨在为学校提供一个高效的教材管理平台。该系统可以帮助管理员录入教材信息、教师查询和申请教材、学生查询教材信息&#xff0c;提高教材管理的效率和透明度。 2. 技术栈 前端…...

软考(中级-软件设计师)数据库篇(1101)

第6章 数据库系统基础知识 一、基本概念 1、数据库 数据库&#xff08;Database &#xff0c;DB&#xff09;是指长期存储在计算机内的、有组织的、可共享的数据集合。数据库中的数据按一定的数据模型组织、描述和存储&#xff0c;具有较小的冗余度、较高的数据独立性和扩展…...

安装nscd及glibc包冲突降级【centos7】

安装nscd及glibc包冲突降级【centos7】 一、查看当前glibc版本二、查找可用的glibc版本三、备份系统和数据四、降级glibc五、验证降级是否成功六、解决其他依赖问题七、测试和验证八、考虑使用容器技术endl [08:41:07 rootcentos7 ~]# yum -y install nscd Loaded plugins: fas…...

Qt字符编码

目前字符编码有以下几种&#xff1a; 1、UTF-8 UTF-8编码是Unicode字符集的一种编码方式(CEF)&#xff0c;其特点是使用变长字节数(即变长码元序列、变宽码元序列)来编码。一般是1到4个字节&#xff0c;当然&#xff0c;也可以更长。 2、UTF-16 UTF-16是Unicode字符编码五层次…...

Ubuntu用docker安装AWVS和Nessus(含破解)

Ubuntu安装AWVS(更多搜索&#xff1a;超详细Ubuntu用docker安装AWVS和Nessus) 首先安装docker&#xff0c;通过dockers镜像安装很方便&#xff0c;且很快&#xff1b;Docker及Docker-Compose-安装教程。 1.通过docker search awvs命令查看镜像&#xff1b; docker search awvs…...

tauri开发中如果取消了默认的菜单项,复制黏贴撤销等功能也就没有了,解决办法

取消默认的菜单项&#xff1a;清除tauri默认的菜单项&#xff0c;让顶部的菜单menu不显示-CSDN博客 就是通过配置空菜单&#xff0c;让菜单不显示&#xff0c;但是这个引发的问题就是复制黏贴撤销等功能也就没有了&#xff0c;解决办法&#xff1a; 新增加编辑下的子菜单&…...

HNU-小学期-专业综合设计

写在前面 选题&#xff1a;大数据技术-智慧交通预测系统 项目github地址&#xff08;如果有用麻烦点个star与follow&#xff09;&#xff1a;https://github.com/wolfvoid/HNU-ITPS &#xff08;全部代码以及如何部署参见README&#xff09; 项目报告&#xff1a;如下&…...

Linux安装es和kibana

安装Elasticsearch 参考文档&#xff1a;https://www.elastic.co/guide/en/elasticsearch/reference/current/targz.html#targz-enable-indices 基本步骤下载包&#xff0c;解压&#xff0c;官网提示&#xff1a; wget https://artifacts.elastic.co/downloads/elasticsearc…...

第二十六章 Vue之在当前组件范围内获取dom元素和组件实例

目录 一、概述 二、获取dom 2.1. 具体步骤 2.2. 完整代码 2.2.1. main.js 2.2.2. App.vue 2.3. BaseChart.vue 三、获取组件实例 3.1. 具体步骤 3.2. 完整代码 3.2.1. main.js 3.2.2. App.vue 3.2.3. BaseForm.vue 3.3. 运行效果 一、概述 我们过去在想要获取一…...

Markdown 区块

再段落开头&#xff0c;使用>符号&#xff0c;在符号后面按空格&#xff0c;效果图是最左侧有一条灰色的粗线&#xff0c;这是一级区块 二级区块和三级区块只需要在一级的后面加>符号&#xff0c;就可以进入二级区块&#xff0c;效果如下图 还可以在区块内部签到无序列表…...

ctf文件上传题小总结与记录

解题思路&#xff1a;先看中间件&#xff0c;文件上传点&#xff08;字典扫描&#xff0c;会员中心&#xff09;&#xff0c;绕过/验证&#xff08;黑名单&#xff0c;白名单&#xff09;&#xff0c;解析漏洞&#xff0c;cms&#xff0c;编辑器&#xff0c;最新cve 文件上传漏…...

什么是QAM

什么是调制呢&#xff1f; 调制就是把信号形式转换成适合在信道中传输的一个过程。可分为基带调制和载波调制。我们这里所说的调制都是载波调制。 什么是载波调制呢&#xff1f; 就是把调制信号骑到载波上&#xff0c;方法就是用调制信号去控制载波的参数&#xff0c;使载波…...

GraphQL 与 Elasticsearch 相遇:使用 Hasura DDN 构建可扩展、支持 AI 的应用程序

作者&#xff1a;来自 Elastic Praveen Durairaju GraphQL 提供了一种高效且灵活的数据查询方式。本博客将解释 Hasura DDN 如何与 Elasticsearch 配合使用&#xff0c;以实现高性能和元数据驱动的数据访问。 此示例的代码和设置可在此 GitHub 存储库 - elasticsearch-subgraph…...

面试题整理 3

总结了某公司面试遇到的值得整理记录的面试题&#xff0c;比较侧重于Redis方面。 目录 Redis持久化配置 RDB AOF Redis rdb日志文件路径编辑 命令行参数设置 Redis事务 Redis事务介绍 Redis事务阶段 watch监听 Mysql隔离级别 1.READ UNCOMMITTED 2.READ COMMITTED …...

数据结构(Java)—— 认识泛型

1. 包装类 在学习泛型前我们需要先了解一下包装类 在 Java 中&#xff0c;由于基本类型不是继承自 Object &#xff0c;为了在泛型代码中可以支持基本类型&#xff0c; Java 给每个基本类型都对应了一个包装类型。 1.1 基本数据类型和对应的包装类 基本数据类型包装类byteByt…...

处理后的视频如何加上音频信息?

总方案:原来模型对图像进行每帧处理,保留后的视频自然失去了audio信息,因此先用ffmpeg处理得到audio,原输出video加上audio即可,也采用ffmpeg处理。 imageio库用于读取和写入视频文件,并且你正在使用img_cartoon模型处理每一帧图像。然而,这段代码只处理了视频的图像部…...

02LangChain 实战课——安装入门

LangChain安装入门 一、大语言模型简介 大语言模型是利用深度学习技术&#xff0c;尤其是神经网络&#xff0c;来理解和生成人类语言的人工智能模型。这些模型因其庞大的参数数量而得名&#xff0c;能够理解和生成复杂的语言模式。它们通过预测下一个词来训练&#xff0c;基于…...

Python函数中关键字参数、位置参数、默认参数有何不同

在Python中&#xff0c;函数的参数分为三种类型&#xff1a;关键字参数&#xff08;key arguments&#xff09;、位置参数&#xff08;positional arguments&#xff09;和默认参数&#xff08;default arguments&#xff09;。它们的主要区别在于调用时如何传递值&#xff0c;…...

PNG 格式和 JPG 格式都什么时候用

通常我们都知道&#xff0c;如果是针对网络传输或者网站的格式&#xff0c;我们多会使用 PNG 格式。 如果是照片&#xff0c;大部分都是 JPG 格式的。 那么我们网站常用的截图应该保存为什么格式呢&#xff1f; 照片截图 照片截图应该保存为 JPG 格式。 虽然现在我们多存储…...

Qt 练习做一个登录界面

练习做一个登录界面 效果 UI图 UI代码 <?xml version"1.0" encoding"UTF-8"?> <ui version"4.0"><class>Dialog</class><widget class"QDialog" name"Dialog"><property name"ge…...

Prompt Tuning、P-Tuning、Prefix Tuning的区别

一、Prompt Tuning、P-Tuning、Prefix Tuning的区别 1. Prompt Tuning(提示调优) 核心思想:固定预训练模型参数,仅学习额外的连续提示向量(通常是嵌入层的一部分)。实现方式:在输入文本前添加可训练的连续向量(软提示),模型只更新这些提示参数。优势:参数量少(仅提…...

工业安全零事故的智能守护者:一体化AI智能安防平台

前言&#xff1a; 通过AI视觉技术&#xff0c;为船厂提供全面的安全监控解决方案&#xff0c;涵盖交通违规检测、起重机轨道安全、非法入侵检测、盗窃防范、安全规范执行监控等多个方面&#xff0c;能够实现对应负责人反馈机制&#xff0c;并最终实现数据的统计报表。提升船厂…...

模型参数、模型存储精度、参数与显存

模型参数量衡量单位 M&#xff1a;百万&#xff08;Million&#xff09; B&#xff1a;十亿&#xff08;Billion&#xff09; 1 B 1000 M 1B 1000M 1B1000M 参数存储精度 模型参数是固定的&#xff0c;但是一个参数所表示多少字节不一定&#xff0c;需要看这个参数以什么…...

在HarmonyOS ArkTS ArkUI-X 5.0及以上版本中,手势开发全攻略:

在 HarmonyOS 应用开发中&#xff0c;手势交互是连接用户与设备的核心纽带。ArkTS 框架提供了丰富的手势处理能力&#xff0c;既支持点击、长按、拖拽等基础单一手势的精细控制&#xff0c;也能通过多种绑定策略解决父子组件的手势竞争问题。本文将结合官方开发文档&#xff0c…...

MODBUS TCP转CANopen 技术赋能高效协同作业

在现代工业自动化领域&#xff0c;MODBUS TCP和CANopen两种通讯协议因其稳定性和高效性被广泛应用于各种设备和系统中。而随着科技的不断进步&#xff0c;这两种通讯协议也正在被逐步融合&#xff0c;形成了一种新型的通讯方式——开疆智能MODBUS TCP转CANopen网关KJ-TCPC-CANP…...

今日学习:Spring线程池|并发修改异常|链路丢失|登录续期|VIP过期策略|数值类缓存

文章目录 优雅版线程池ThreadPoolTaskExecutor和ThreadPoolTaskExecutor的装饰器并发修改异常并发修改异常简介实现机制设计原因及意义 使用线程池造成的链路丢失问题线程池导致的链路丢失问题发生原因 常见解决方法更好的解决方法设计精妙之处 登录续期登录续期常见实现方式特…...

使用LangGraph和LangSmith构建多智能体人工智能系统

现在&#xff0c;通过组合几个较小的子智能体来创建一个强大的人工智能智能体正成为一种趋势。但这也带来了一些挑战&#xff0c;比如减少幻觉、管理对话流程、在测试期间留意智能体的工作方式、允许人工介入以及评估其性能。你需要进行大量的反复试验。 在这篇博客〔原作者&a…...

uniapp 开发ios, xcode 提交app store connect 和 testflight内测

uniapp 中配置 配置manifest 文档&#xff1a;manifest.json 应用配置 | uni-app官网 hbuilderx中本地打包 下载IOS最新SDK 开发环境 | uni小程序SDK hbulderx 版本号&#xff1a;4.66 对应的sdk版本 4.66 两者必须一致 本地打包的资源导入到SDK 导入资源 | uni小程序SDK …...

WebRTC调研

WebRTC是什么&#xff0c;为什么&#xff0c;如何使用 WebRTC有什么优势 WebRTC Architecture Amazon KVS WebRTC 其它厂商WebRTC 海康门禁WebRTC 海康门禁其他界面整理 威视通WebRTC 局域网 Google浏览器 Microsoft Edge 公网 RTSP RTMP NVR ONVIF SIP SRT WebRTC协…...

flow_controllers

关键点&#xff1a; 流控制器类型&#xff1a; 同步&#xff08;Sync&#xff09;&#xff1a;发布操作会阻塞&#xff0c;直到数据被确认发送。异步&#xff08;Async&#xff09;&#xff1a;发布操作非阻塞&#xff0c;数据发送由后台线程处理。纯同步&#xff08;PureSync…...