C 语言奇幻之旅 - 第16篇:C 语言项目实战
目录
- 引言
- 1. 项目规划
- 1.1 需求分析与设计
- 1.1.1 项目目标
- 1.1.2 功能需求
- 1.1.3 技术实现方案
- 2. 代码实现
- 2.1 模块化编程
- 2.1.1 学生信息模块
- 2.1.2 成绩管理模块
- 2.2 调试与测试
- 2.2.1 调试
- 2.2.2 测试
- 2.2.4 测试结果
- 3. 项目总结
- 3.1 代码优化与重构
- 3.1.1 代码优化
- 3.1.2 代码重构
- 3.2 项目反思
- 3.2.1 存在的问题
- 3.2.2 改进方式
- 4. 模拟内存结构
- 解释
- 5. 案例执行结果
- 结语
引言
欢迎来到 C 语言奇幻之旅的第16篇!在这一篇中,我们将一起踏上一段激动人心的项目实战之旅。无论你是初学者、中级开发者还是资深开发者,这篇文章都将为你提供宝贵的实战经验。我们将从项目规划、代码实现到项目总结,一步步带你领略 C 语言的魅力。准备好了吗?让我们开始吧!
1. 项目规划
1.1 需求分析与设计
在开始任何项目之前,需求分析和设计是至关重要的。我们需要明确项目的目标、功能需求以及技术实现方案。
1.1.1 项目目标
我们的项目目标是开发一个简单的学生成绩管理系统。该系统将允许用户添加学生信息、录入成绩、查询成绩以及计算平均成绩。通过这个项目,我们将学习如何将 C 语言的基础知识应用到实际开发中。
1.1.2 功能需求
- 添加学生信息:用户可以输入学生的姓名、学号和成绩。
- 录入成绩:用户可以录入学生的各科成绩。
- 查询成绩:用户可以通过学号查询学生的成绩。
- 计算平均成绩:系统可以计算并显示学生的平均成绩。
- 删除学生信息:用户可以通过学号删除学生的信息。
- 错误处理:系统能够处理无效输入(如重复学号、成绩超出范围等)。
1.1.3 技术实现方案
我们将采用模块化编程的方式来实现这个系统。每个功能模块将独立开发,最后通过主程序进行整合。为了提高代码的可维护性,我们将使用头文件和源文件分离的方式组织代码。
2. 代码实现
2.1 模块化编程
模块化编程是将程序分解为多个独立模块的编程方法。每个模块负责一个特定的功能,这样可以提高代码的可读性、可维护性和可重用性。
2.1.1 学生信息模块
// student.h
#ifndef STUDENT_H
#define STUDENT_H#define MAX_STUDENTS 100
#define NAME_LENGTH 50typedef struct {char name[NAME_LENGTH];int id;float score;
} Student;void addStudent(Student *students, int *count);
void deleteStudent(Student *students, int *count, int id);
void displayStudents(Student *students, int count);#endif
// student.c
#include <stdio.h>
#include <string.h>
#include "student.h"void addStudent(Student *students, int *count) {if (*count >= MAX_STUDENTS) {printf("错误:学生列表已满!\n");return;}Student newStudent;printf("请输入学生姓名:");scanf("%s", newStudent.name);printf("请输入学生学号:");scanf("%d", &newStudent.id);printf("请输入学生成绩:");scanf("%f", &newStudent.score);// 检查学号是否重复for (int i = 0; i < *count; i++) {if (students[i].id == newStudent.id) {printf("错误:学号已存在!\n");return;}}students[*count] = newStudent;(*count)++;printf("学生添加成功!\n");
}void deleteStudent(Student *students, int *count, int id) {int found = 0;for (int i = 0; i < *count; i++) {if (students[i].id == id) {// 将最后一个学生信息移动到删除的位置students[i] = students[*count - 1];(*count)--;found = 1;printf("学生删除成功!\n");break;}}if (!found) {printf("错误:未找到该学号!\n");}
}void displayStudents(Student *students, int count) {if (count == 0) {printf("没有找到学生信息。\n");return;}for (int i = 0; i < count; i++) {printf("姓名:%s,学号:%d,成绩:%.2f\n", students[i].name, students[i].id, students[i].score);}
}
2.1.2 成绩管理模块
// grade.h
#ifndef GRADE_H
#define GRADE_Hvoid enterGrades(Student *students, int count);
void queryGrade(Student *students, int count);
float calculateAverage(Student *students, int count);#endif
// grade.c
#include <stdio.h>
#include "grade.h"
#include "student.h"void enterGrades(Student *students, int count) {int id;printf("请输入学生学号:");scanf("%d", &id);for (int i = 0; i < count; i++) {if (students[i].id == id) {printf("请输入新的成绩:");scanf("%f", &students[i].score);printf("成绩更新成功!\n");return;}}printf("错误:未找到该学号!\n");
}void queryGrade(Student *students, int count) {int id;printf("请输入学生学号:");scanf("%d", &id);for (int i = 0; i < count; i++) {if (students[i].id == id) {printf("姓名:%s,成绩:%.2f\n", students[i].name, students[i].score);return;}}printf("错误:未找到该学号!\n");
}float calculateAverage(Student *students, int count) {if (count == 0) {printf("没有找到学生信息。\n");return 0.0;}float sum = 0;for (int i = 0; i < count; i++) {sum += students[i].score;}return sum / count;
}
2.2 调试与测试
在编写完代码后,我们需要进行调试和测试,以确保程序的正确性和稳定性。
2.2.1 调试
调试是发现和修复代码中错误的过程。我们可以使用调试工具(如 gdb
)来逐步执行代码,检查变量的值和程序的执行流程。
2.2.2 测试
测试是验证程序是否按预期工作的过程。我们可以编写测试用例,覆盖所有功能模块,确保每个功能都能正常工作。
// main.c
#include <stdio.h>
#include "student.h"
#include "grade.h"int main() {Student students[MAX_STUDENTS];int count = 0;int choice;while (1) {printf("\n--- 学生成绩管理系统 ---\n");printf("1. 添加学生\n");printf("2. 删除学生\n");printf("3. 录入成绩\n");printf("4. 查询成绩\n");printf("5. 计算平均成绩\n");printf("6. 显示所有学生\n");printf("7. 退出\n");printf("请输入您的选择:");scanf("%d", &choice);switch (choice) {case 1:addStudent(students, &count);break;case 2:if (count == 0) {printf("没有学生可删除。\n");} else {int id;printf("请输入要删除的学生学号:");scanf("%d", &id);deleteStudent(students, &count, id);}break;case 3:enterGrades(students, count);break;case 4:queryGrade(students, count);break;case 5:printf("平均成绩:%.2f\n", calculateAverage(students, count));break;case 6:displayStudents(students, count);break;case 7:printf("正在退出...\n");return 0;default:printf("无效的选择,请重试。\n");}}return 0;
}
2.2.4 测试结果
该实战程序测试结果如下,测试程序的在下一同级标题,测试结果使用 GIF 演示,该 GIF 生成程序由本人制作,现已开源,希望更多小伙伴一同加入开发。
完整源码,复制到任意支持 C 语言开发的环境下即可。
#include <stdio.h>
#include <string.h>
#include "student.h"void addStudent(Student *students, int *count) {if (*count >= MAX_STUDENTS) {printf("错误:学生列表已满!\n");return;}Student newStudent;printf("请输入学生姓名:");scanf("%s", newStudent.name);printf("请输入学生学号:");scanf("%d", &newStudent.id);printf("请输入学生成绩:");scanf("%f", &newStudent.score);// 检查学号是否重复for (int i = 0; i < *count; i++) {if (students[i].id == newStudent.id) {printf("错误:学号已存在!\n");return;}}students[*count] = newStudent;(*count)++;printf("学生添加成功!\n");
}void deleteStudent(Student *students, int *count, int id) {int found = 0;for (int i = 0; i < *count; i++) {if (students[i].id == id) {// 将最后一个学生信息移动到删除的位置students[i] = students[*count - 1];(*count)--;found = 1;printf("学生删除成功!\n");break;}}if (!found) {printf("错误:未找到该学号!\n");}
}void displayStudents(Student *students, int count) {if (count == 0) {printf("没有找到学生信息。\n");return;}for (int i = 0; i < count; i++) {printf("姓名:%s,学号:%d,成绩:%.2f\n", students[i].name, students[i].id, students[i].score);}
}void enterGrades(Student *students, int count) {int id;printf("请输入学生学号:");scanf("%d", &id);for (int i = 0; i < count; i++) {if (students[i].id == id) {printf("请输入新的成绩:");scanf("%f", &students[i].score);printf("成绩更新成功!\n");return;}}printf("错误:未找到该学号!\n");
}void queryGrade(Student *students, int count) {int id;printf("请输入学生学号:");scanf("%d", &id);for (int i = 0; i < count; i++) {if (students[i].id == id) {printf("姓名:%s,成绩:%.2f\n", students[i].name, students[i].score);return;}}printf("错误:未找到该学号!\n");
}float calculateAverage(Student *students, int count) {if (count == 0) {printf("没有找到学生信息。\n");return 0.0;}float sum = 0;for (int i = 0; i < count; i++) {sum += students[i].score;}return sum / count;
}int main() {Student students[MAX_STUDENTS];int count = 0;int choice;while (1) {printf("\n--- 学生成绩管理系统 ---\n");printf("1. 添加学生\n");printf("2. 删除学生\n");printf("3. 录入成绩\n");printf("4. 查询成绩\n");printf("5. 计算平均成绩\n");printf("6. 显示所有学生\n");printf("7. 退出\n");printf("请输入您的选择:");scanf("%d", &choice);switch (choice) {case 1:addStudent(students, &count);break;case 2:if (count == 0) {printf("没有学生可删除。\n");} else {int id;printf("请输入要删除的学生学号:");scanf("%d", &id);deleteStudent(students, &count, id);}break;case 3:enterGrades(students, count);break;case 4:queryGrade(students, count);break;case 5:printf("平均成绩:%.2f\n", calculateAverage(students, count));break;case 6:displayStudents(students, count);break;case 7:printf("正在退出...\n");return 0;default:printf("无效的选择,请重试。\n");}}return 0;
}
3. 项目总结
3.1 代码优化与重构
在项目完成后,我们可以对代码进行优化和重构,以提高代码的质量和性能。
3.1.1 代码优化
- 减少重复代码:将重复的代码提取到函数中,减少代码冗余。
- 提高算法效率:优化算法,减少时间和空间复杂度。
3.1.2 代码重构
- 模块化重构:将功能相似的代码合并到一个模块中,提高代码的可读性和可维护性。
- 命名规范:使用有意义的变量名和函数名,提高代码的可读性。
3.2 项目反思
在完成项目后,我们需要反思项目的开发过程,思考可能存在的问题和改进方式。
3.2.1 存在的问题
- 代码耦合度高:部分模块之间的耦合度较高,影响了代码的可维护性。
- 错误处理不足:程序中没有足够的错误处理机制,可能导致程序崩溃。
3.2.2 改进方式
- 降低耦合度:通过接口和抽象类降低模块之间的耦合度。
- 增强错误处理:增加错误处理机制,提高程序的健壮性。
4. 模拟内存结构
为了更好地理解程序的运行机制,我们可以模拟程序在内存中的结构。以下是 students
数组在内存中的布局示例:
假设我们添加了以下学生信息:
- 学生1:
姓名 = "张三", 学号 = 101, 成绩 = 85.5
- 学生2:
姓名 = "李四", 学号 = 102, 成绩 = 90.0
- 学生3:
姓名 = "王五", 学号 = 103, 成绩 = 78.5
内存结构如下:
地址 | 字段名 | 值 |
---|---|---|
0x1000 | 姓名 | "张三" |
0x1000+50 | 学号 | 101 |
0x1000+54 | 成绩 | 85.5 |
0x1050 | 姓名 | "李四" |
0x1050+50 | 学号 | 102 |
0x1050+54 | 成绩 | 90.0 |
0x10A0 | 姓名 | "王五" |
0x10A0+50 | 学号 | 103 |
0x10A0+54 | 成绩 | 78.5 |
解释
姓名
字段:每个学生的姓名
字段占用50
字节(NAME_LENGTH
定义的大小)。学号
字段:学号
是一个int
类型,占用4
字节。成绩
字段:成绩
是一个float
类型,占用4
字节。
通过这种内存布局,我们可以清晰地看到每个学生的信息是如何在内存中存储的。
5. 案例执行结果
以下是程序的运行示例:
--- 学生成绩管理系统 ---
1. 添加学生
2. 删除学生
3. 录入成绩
4. 查询成绩
5. 计算平均成绩
6. 显示所有学生
7. 退出
请输入您的选择:1
请输入学生姓名:张三
请输入学生学号:101
请输入学生成绩:85.5
学生添加成功!--- 学生成绩管理系统 ---
1. 添加学生
2. 删除学生
3. 录入成绩
4. 查询成绩
5. 计算平均成绩
6. 显示所有学生
7. 退出
请输入您的选择:1
请输入学生姓名:李四
请输入学生学号:102
请输入学生成绩:90.0
学生添加成功!--- 学生成绩管理系统 ---
1. 添加学生
2. 删除学生
3. 录入成绩
4. 查询成绩
5. 计算平均成绩
6. 显示所有学生
7. 退出
请输入您的选择:6
姓名:张三,学号:101,成绩:85.50
姓名:李四,学号:102,成绩:90.00--- 学生成绩管理系统 ---
1. 添加学生
2. 删除学生
3. 录入成绩
4. 查询成绩
5. 计算平均成绩
6. 显示所有学生
7. 退出
请输入您的选择:5
平均成绩:87.75--- 学生成绩管理系统 ---
1. 添加学生
2. 删除学生
3. 录入成绩
4. 查询成绩
5. 计算平均成绩
6. 显示所有学生
7. 退出
请输入您的选择:7
正在退出...
结语
通过这个项目实战,我们不仅掌握了 C 语言的基本语法和编程技巧,还学会了如何进行模块化编程、调试与测试以及代码优化与重构。希望这篇文章能激发你对 C 语言的学习兴趣,并提升你的开发技能。继续努力,未来的编程大师就是你!
希望这篇博客能够激发你对 C 语言预处理器与宏的兴趣,并帮助你在编程之路上走得更远。Happy coding! 🚀
相关文章:
C 语言奇幻之旅 - 第16篇:C 语言项目实战
目录 引言1. 项目规划1.1 需求分析与设计1.1.1 项目目标1.1.2 功能需求1.1.3 技术实现方案 2. 代码实现2.1 模块化编程2.1.1 学生信息模块2.1.2 成绩管理模块 2.2 调试与测试2.2.1 调试2.2.2 测试2.2.4 测试结果 3. 项目总结3.1 代码优化与重构3.1.1 代码优化3.1.2 代码重构 3.…...
[笔记] 使用 Jenkins 实现 CI/CD :从 GitLab 拉取 Java 项目并部署至 Windows Server
随着软件开发节奏的加快,持续集成(CI)和持续部署(CD)已经成为确保软件质量和加速产品发布的不可或缺的部分。Jenkins作为一款广泛使用的开源自动化服务器,为开发者提供了一个强大的平台来实施这些实践。然而…...
Git最便捷的迁移方式
#当公司要求git需要迁移时,你是不是感觉到束手无策。今天带来给大家最快,最便捷的迁移方式 这个命令是用于重命名git仓库中的远程仓库名。在这个命令中,我们将远程仓库的名字从"origin"改为"old-origin"。 git remote …...
【颜色分类--荷兰国旗问题】
问题 给定一个包含红色、白色和蓝色、共 n 个元素的数组 nums , 原地 对它们进行排序,使得相同颜色的元素相邻,并按照红色、白色、蓝色顺序排列。我们使用整数 0、 1 和 2 分别表示红色、白色和蓝色。必须在不使用库内置的 sort 函数的情况下…...
xrdp连接闪退情况之一
错误核查 首先使用命令vim ~/.xsession-errors,当里面的报错信息为WARNING **: Could not make bus activated clients aware of XDG_CURRENT_DESKTOPGNOME environment variable:Failed to execute child process “dbus-launch” (No such file or directory)&am…...
KubeVirt 进阶:设置超卖比、CPU/MEM 升降配、在线磁盘扩容
前两篇文章,我们分别介绍 Kubevirt 的安装、基本使用 以及 将 oVirt 虚拟机迁移到 KubeVirt,我们留了两个ToDo,一个是本地磁盘的动态分配,一个是固定 IP 的需求,本期我们先解决第一个,本地磁盘的动态分配。…...
(回溯法)leetcode39组合总和
第一个2开头,下面的子节点的集合元素均为2,5,3 但是在5开头,下面的子节点集合元素均为5,3 带着这个图的思路确定i和index的传递值 backtracking(i, nums,8,sum);用的是i而不是i1 // ConsoleApplication3.cpp : 此文件包含 "main" 函数。程序…...
【数据结构】二叉搜索树
目录 1. 二叉搜索树的概念 2. 二叉搜索树的性能分析 3.二叉搜索树的实现 3. 1.二叉搜索树的插入 3.2. 二叉搜索树的查找 3.3. 二叉搜索树的删除 3.4. 二叉搜索树的实现代码 4. 二叉搜索树key和key/value两种使用场景 4.1 key搜索场景: 4.2 key/value搜索场…...
高可用虚拟IP-keepalived
个人觉得华为云这个文档十分详细:使用虚拟IP和Keepalived搭建高可用Web集群_弹性云服务器 ECS_华为云 应用场景:虚拟IP技术。虚拟IP,就是一个未分配给真实主机的IP,也就是说对外提供数据库服务器的主机除了有一个真实IP外还有一个…...
CSS语言的多线程编程
CSS语言的多线程编程 引言 在现代Web开发中,CSS(层叠样式表)被广泛用于给网页添加样式。然而,CSS本身是一种声明性语言,在设计上并没有直接支持多线程编程的功能。实际上,CSS的解析和应用是由浏览器的渲染…...
电脑之一键备份系统(One Click Backup System for Computer)
电脑之一键备份系统 相信使用电脑的的人都遇到过,电脑系统崩溃,开机蓝屏等原因,这个时候你急着用电脑办公,电脑却给你罢工是多么气人了,其实可以给电脑做一个系统备份。 最近每天都有系统蓝屏崩溃,这个实难…...
R语言的正则表达式
R语言中的正则表达式深度解析 正则表达式(Regular Expressions,简称Regex)是一种用于描述字符串匹配规则的工具,广泛应用于数据处理、文本分析、数据清洗等多个领域。在R语言中,正则表达式被广泛应用于字符串的处理和…...
解决el-table表格数据量过大导致页面卡顿问题 又名《umy-ui---虚拟表格仅渲染可视区域dom的神》
后台管理系统的某个页面需要展示多个列表 数据量过多 页面渲染dom卡顿 经调研发现两个组件 pl-table和umy-ui (也就是u-table) 最终决定使用umy-ui 它是专门基于 Vue 2.0 的桌面端组件库 流畅渲染表格万级数据 而且他是对element-ui的表格做了二次优化…...
《机器学习》——贝叶斯算法
贝叶斯简介 贝叶斯公式,又称贝叶斯定理、贝叶斯法则,最初是用来描述两个事件的条件概率间的关系的公式,后来被人们发现具有很深刻的实际意义和应用价值。该公式的实际内涵是,支持某项属性的事件发生得愈多,则该属性成…...
零基础 监控数据可视化 Spring Boot 2.x(Actuator + Prometheus + Grafana手把手) (上)
一、安装Prometheus Releases prometheus/prometheus GitHubhttps://github.com/prometheus/prometheus/releases 或 https://prometheus.io/download/https://prometheus.io/download/ 1. 下载适用于 Windows 的二进制文件: 找到最新版本的发布页面…...
4.STM32F407ZGT6-独立看门狗
参考: 1.正点原子 前言: 看门狗是一个项目或者产品中肯定需要的功能部分,必须会。常见的两种看门狗类型,独立看门狗和窗口看门狗,各有使用的场景。总结记录独立看门狗一些知识点: 1.独立看门狗的概念。&am…...
RHCE实验-nfs及autofs
本次实验的目的:实现服务端的网络文件共享(配置nfs),且实现客户端的自动挂载(配置autofs) 服务端配置: 关闭防火墙和selinux: 安装软件 [rootlocalhost ~]# yum install nfs-utils -y 创建需要被挂载的目…...
docker代理设置
最近遇到国内镜像无法下载的问题,因此需要配置docker代理来使其能够下载镜像 代理设置方法如下: 编辑 /etc/docker/daemon.json 文件: 配置 HTTP 和 HTTPS 代理: {"proxies": {"http-proxy": "http:/…...
死信交换机
什么是死信?什么是死信交换机? 在MQ中未能成功被消费的消息就被称之为死信,而死信交换机就用于存放死信消息。 消息转变成死信消息的原因: 消息被消费者拒绝或者需要重发(nack、reject) nack:消…...
cat命令详解
🏝️专栏:https://blog.csdn.net/2301_81831423/category_12872319.html 🌅主页:猫咪-9527-CSDN博客 “欲穷千里目,更上一层楼。会当凌绝顶,一览众山小。” cat 是 Linux/Unix 中的一个非常常用的命令&…...
路由器的转发表
【4-24】 已知路由器R₁ 的转发表如表T-4-24 所示。 表T-4-24 习题4-24中路由器R₁的转发表 前缀匹配 下一跳地址 路由器接口 140.5.12.64/26 180.15.2.5 m2 130.5.8/24 190.16.6.2 ml 110.71/16 ----- m0 180.15/16 ----- m2 190.16/16 ----- ml 默认 11…...
腾讯云AI代码助手编程挑战赛-古诗词学习
一、作品介绍 在科技与文化深度交融的当下,“腾讯云 AI 代码助手编程挑战赛 - 每日古诗词” 宛如一颗璀璨的新星,闪耀登场。它绝非一场普通的赛事,而是一座连接编程智慧与古典诗词韵味的桥梁。 这项挑战赛以独特的视角,将每日古…...
积分系统的设计
1. 目的 学习是需要正反馈的,这样学员才能有源源不断的动力去继续学习。 为了激励学员,我们需要设定一个学习积分的排行榜系统。优秀的学员给予一定的奖励,比如奖励优惠券。大家互相比拼的,刺激学员持续学习,互相卷起…...
功能篇:spring事务配置
在 Java 应用程序中配置事务管理通常涉及使用 Spring 框架,因为 Spring 提供了强大的事务管理抽象,可以简化事务的配置和管理。Spring 支持两种类型的事务管理:编程式事务管理和声明式事务管理。 编程式事务管理 编程式事务管理是通过编写代…...
单元测试概述入门
引入 什么是测试?测试的阶段划分? 测试方法有哪些? 1.什么是单元测试? 单元测试:就是针对最小的功能单元(方法),编写测试代码对其正确性进行测试。 2.为什么要引入单元测试&#x…...
PySpark学习笔记2-RDD算子,RDD持久化
RDD定义 RDD是弹性分布式数据集,是spark中的最基本的数据抽象,里面的元素可以并行计算 RDD的五大特性 RDD是有分区的,它的分区是数据存储的最小单位 RDD的方法会作用在所有分区上 RDD之间是有依赖关系的 KV型的RDD可以有分区器 RDD的分区会尽…...
windows10下安装Microsoft SQL Server 2016
一、下载安装包 网站:MSDN, 我告诉你 - 做一个安静的工具站 选择需要的版本,点击详细信息,复制ed2k链接,打开eMule或迅雷,新建下载,粘贴链接,开始下载。 下载好的文件是一个.iso镜像文件。 二、…...
开关不一定是开关灯用 - 命令模式(Command Pattern)
命令模式(Command Pattern) 命令模式(Command Pattern)命令设计模式命令设计模式结构图命令设计模式涉及的角色 talk is cheap, show you my code总结 命令模式(Command Pattern) 命令模式&…...
急速了解什么是GPU服务器
GPU服务器是一种专门配置了高性能图形处理器(GPU)的服务器,旨在提供高性能计算、深度学习、科学计算等多种场景的计算服务。与传统的CPU服务器相比,GPU服务器在处理并行密集型计算任务时具有显著优势。本文将详细介绍GPU服务器的定…...
word论文排版常见问题汇总
word论文排版常见问题汇总 常用快捷键: Alt F9 正常模式与域代码模式切换 Ctrl F9 插入域代码 F9 刷新域代码显示,要注意选定后刷新才会有效果 word中在当前列表的基础上修改列表 在使用word时,我们会定义一个列表,并将其链接…...
作业:IO:day3
思维导图 使用3语言编写一个简易的界面 界面如下 1:标准输出流 2:标准错误流 3:文件流 要求: 按1的时候,通过printf输出数据, 按2的时候,通过perror输出数据, 按3的时候将输入写入文…...
H266/VVC 帧内预测 PDPC 技术
位置决定的帧内预测组合 PDPC 在 VVC 中,对于帧内预测的 Planar 模式、DC 模式和几种角度模式需要使用 PDPC (position dependent intra prediction combination) 方法进一步处理。 PDPC 用于 DC 模式、Planar 模式、小于等于水平模式(模式 18) 的角度模式、大于等于…...
微信小程序mp3音频播放组件,仅需传入url即可
// index.js // packageChat/components/audio-player/index.js Component({/*** 组件的属性列表*/properties: {/*** MP3 文件的 URL*/src: {type: String,value: ,observer(newVal, oldVal) {if (newVal ! oldVal && newVal) {// 如果 InnerAudioContext 已存在&…...
Hadoop3.x 万字解析,从入门到剖析源码
💖 欢迎来到我的博客! 非常高兴能在这里与您相遇。在这里,您不仅能获得有趣的技术分享,还能感受到轻松愉快的氛围。无论您是编程新手,还是资深开发者,都能在这里找到属于您的知识宝藏,学习和成长…...
mysql的一些函数及其用法
mysql 1-来自于leetcode1517的题目 表: Users------------------------ | Column Name | Type | ------------------------ | user_id | int | | name | varchar | | mail | varchar | ------------------------已知一个表,它的…...
[java基础]LinkedList源码粗析
LinkedList 的数据结构 实现List、Deque 接口,基于 双向链表实现的列表。与基于数组的 ArrayList 不同,基于链表的LinkedList 允许在列表的任何位置快速地插入和删除元素。 Java中LinkedList实现了Deque,它提供了 add, offer, remove, poll, …...
基于Spring Boot的海滨体育馆管理系统的设计与实现
风定落花生,歌声逐流水,大家好我是风歌,混迹在java圈的辛苦码农。今天要和大家聊的是一款基于springboot的海滨体育馆管理系统的设计与实现。项目源码以及部署相关请联系风歌,文末附上联系信息 。 项目简介: 宠物医院…...
易支付二次元网站源码及部署教程
易支付二次元网站源码及部署教程 引言 在当今数字化时代,二次元文化逐渐成为年轻人生活中不可或缺的一部分。为了满足这一庞大用户群体的需求,搭建一个二次元主题网站显得尤为重要。本文将为您详细介绍易支付二次元网站源码的特点及其部署教程…...
json序列化时,默认遇到中文会转换成unicode,如果想要保留中文怎么办?
在使用 Python 的 json 模块进行序列化时,默认情况下会将中文转换为 Unicode 编码。如果你希望在序列化时保留中文,可以通过设置 ensure_asciiFalse 来实现。 以下是示例代码: import jsondata {"name": "李浩瑞", &q…...
Perl语言的循环实现
Perl语言的循环实现 引言 Perl是一种强大的脚本语言,以其灵活的语法和强大的文本处理能力著称。无论是在系统管理、网络编程,还是在Web应用开发中,Perl都广泛应用于各种领域。循环是编程语言中一个极其重要的概念,它允许程序重复…...
IOMMU PT
什么是 IOMMU PT IOMMU PT(Input/Output Memory Management Unit - Pass-Through)是一种技术,主要用于虚拟化环境中,特别是在使用直接设备分配(也称为设备直通)的情况下。这项技术允许虚拟机直接访问物理硬…...
DNS协议漏洞利用实验_hust计算机网络安全实验
文章目录 计算机网络安全实验 DNS协议漏洞利用实验 docker使用 建立实验环境docker常用指令 一些注意事项设置本地 DNS 服务器 配置用户计算机设置本地DNS服务器在本地 DNS 服务器中建一个区域 修改主机文件(可略)netwox实施DNS的用户响应欺骗攻击netwo…...
深度学习中的卷积和反卷积(二)——反卷积的介绍
1 简介 反卷积(deconvolution)又称转置卷积,是卷积的拟操作,常用于GAN等模型中。反卷积是上采样的一种,上采样是指将特征图维度恢复到原始图的维度,这种增大维度的过程被称为上采样。上采样可以用插值或反…...
PyCharm 引用其他路径下的文件报错 ModuleNotFound 或报红
PyCharm 中引用其他路径下的文件提示 ModuleNotFound,将被引用目录添加到系统路径: # # 获取当前目录 dir_path os.path.dirname(os.path.realpath(__file__)) # # 获取上级目录 parent_dir_path os.path.abspath(os.path.join(dir_path, os.pardir))…...
【人工智能】Transformers之Pipeline(二):自动语音识别(automatic-speech-recognition)
目录 一、引言 二、自动语音识别(automatic-speech-recognition) 2.1 概述 2.2 技术原理 2.2.1 whisper模型 2.2.2 Wav2vec 2.0模型 2.3 pipeline参数 2.3.1 pipeline对象实例化参数 2.3.2 pipeline对象使用参数…...
Linux 工作队列
系列文章目录 Linux内核学习 Linux 知识(1) Linux 知识(2) Linux 工作队列 Linux 内核源代码情景分析(一) Linux 设备驱动程序(二) 文章目录 系列文章目录综述工作(work_…...
程序血缘分析技术在工商银行软件工程中的应用
当前,随着软件领域技术更新换代速度的日益加快,市场需求也变得更加多样化和个性化,业界普遍通过加速产品迭代来满足客户需求,但在此过程中也暴露出一些研发管理痛点问题,如服务和程序类资产信息分散于各个不同的应用和系统中,信息归集费时费力;设计、开发和测试人员无法…...
纯手工(不基于maven的pom.xml、Web容器)连接MySQL数据库的详细过程(Java Web学习笔记)
1 引言 最近读一些Java Web开发类的书籍时,发现书中的连接数据库的过程缺少了一些关键性的过程,这对初学者非常不友好。为此,本文将给出详细的连接MySQL数据库的过程,并且是纯手工,不依赖于pom.xml和Web容器ÿ…...
node-sass@4.14.1报错的最终解决方案分享
输入npm i全安装文件所需的依赖的时候,博主是使用sass去书写的,使用的是node-sass4.14.1和sass-loader7.3.1的版本的,安装的时候老是出现错误, node-sass4.14.1版本不再被支持的原因 node-sass 是一个基于 LibSass 的 Node.js 绑…...
腾讯云AI代码助手编程挑战赛-厨房助手之AI大厨
腾讯云AI代码助手编程挑战赛-厨房助手之AI大厨 作品简介 身处当今如火箭般迅猛发展的互联网时代,智能聊天助手已然化身成为提升用户体验的关键利器,全方位渗透至人们的数字生活。 紧紧跟随着这股汹涌澎湃的时代浪潮,我毅然投身于极具挑战性…...