- 博客(66)
- 收藏
- 关注
原创 【C++后端项目】负载均衡OJ服务器
负载均衡oj项目基于http网络请求,通过简单的前后端交互:前端的页面编辑、提交代码,后端控制模块和编译运行的模块分离整合(负载均衡式的选择后端编译运行服务),从而实现在线oj的正常使用。使用语言:C/C++,服务器环境:Linux CentOS7,gcc version 9.3.1 20200408 (Red Hat 9.3.1-2) (GCC)
2024-05-09 19:30:30 795 1
原创 【深度学习】手写数字分类模型
从我们之前讲解的视觉任务分类来看,,输入一张图片进行。在现实生活中,手写数字识别也有非常多的应用场景。如下图,我们看到的,可以极大地推动产业自动化,使用卷积神经网络实现的。本次任务就是想建立一个模型,输入一张手写数字的图片,就能输出一个正确的分类结果。通过这样的一个实战项目,可以很好地帮我们,也可以温习一下深度学习的基本流程。
2024-08-16 15:47:12 646
原创 ProtoBuf入门基础
Protocol Buffers 是 Google 的一种语言无关、平台无关、可扩展的序列化结构数据的方法,它可用于(数据)通信协议、数据存储等。Protocol Buffers 类比于 XML,是一种灵活,高效,自动化机制的结构数据序列化方法,但是比 XML 更小、更快、更为简单。你可以定义数据的结构,然后使用特殊生成的源代码轻松的在各种数据流中使用各种语言进行编写和读取结构数据。你甚至可以更新数据结构,而不破坏由旧数据结构编译的已部署程序。
2024-07-27 21:40:37 1116 1
原创 【MySQL】数据库入门基础
存储数据用文件就可以了,文件已经提供了数据存储功能,为什么还要弄个数据库?因为在用户角度看来,文件没有提供非常好的数据管理能力。文件的安全性问题文件不利于数据查询和管理文件不利于存储海量数据文件在程序中控制不方便磁盘内存为了解决上述问题,专家们设计出更加利于管理数据的东西——数据库,数据库能更有效的管理数据。
2024-06-06 23:04:50 1418 2
原创 【Linux网络】传输层协议 - UDP
运输层向高层用户屏蔽了下面网络核心的细节(如网络拓扑、所采用的路由选择协议等),它使应用进程看见的就是好像在两个运输层实体之间有一条端到端的逻辑通信信道,
2024-06-06 22:06:43 1083
原创 法线方程实现最小二乘拟合(Matlab)
法线方程作为最小二乘法的数学基础,为数据拟合提供了可靠的理论支持。通过构造法线方程,我们能够得到最优参数,实现对数据的准确拟合。在实际应用中,理解法线方程的原理对于建立有效的拟合模型至关重要。
2024-05-31 15:19:17 1392 1
原创 三次样条插值的实现(Matlab)
在完成三次样条插值的实验过程中,我获得了许多关于插值方法和 MATLAB 编程的经验。通过这个实验,我更深入地理解了三次样条插值的原理。三次样条插值是一种通过分段定义的三次多项式来逼近原始数据的方法。理解插值、平滑和端点条件的关系对正确实现算法至关重要。在编写 MATLAB 代码的过程中,我学到了一些有关函数文件和主文件的组织结构的技巧。将不同功能的代码模块化,使用函数文件进行封装,有助于提高代码的可读性和维护性。同时,注释的使用也对代码的理解和他人阅读提供了帮助。
2024-05-31 15:06:58 1318
原创 拉格朗日插值及牛顿差商方法的实现(Matlab)
一、问题描述拉格朗日插值及牛顿差商方法的实现。二、实验目的掌握拉格朗日插值和牛顿差商方法的原理,能够编写代码实现两种方法;能够分析多项式插值中的误差。三、实验内容及要求利用拉格朗日插值及牛顿差商方法估计1980 年的人口,并与1980 年的真实值4452584592 进行比较,观察两种方法的结果是否相同。其中:(a)利用1970 年和1990 年的数据,得到插值直线,估计1980 年的人口;
2024-05-28 22:49:12 1058
原创 利用迭代方法求解线性方程组(Matlab)
Jacobi方法和Gauss-Seidel方法的实现。通过这个实验,我得到了一些总结与思考。首先,在实现Jacobi和Gauss-Seidel方法时,我深刻理解了这两种迭代方法的原理。Jacobi方法与Gauss-Seidel方法相比,更为简单,每次迭代都是基于上一次迭代的近似解。而Gauss-Seidel方法则更为迅速,因为它在每次迭代中使用了当前步骤已更新的近似解。这让我对这两种方法的迭代过程和计算方式有了更深入的认识。
2024-05-28 22:47:11 1107
原创 【C++11】线程库 | 互斥量 | 原子性操作 | 条件变量
C++11中最重要的特性就是对线程进行支持了,使得C++在并行编程时不需要依赖第三方库,而且在原子操作中还引入了原子类的概念。要使用标准库中的线程,必须包含头文件。线程是操作系统中的一个概念,线程对象可以关联一个线程,用来控制线程以及获取线程的状态。
2024-05-09 18:09:50 887
原创 【Linux】Socket编程接口 | 实现简单的UDP网络程序
socket API是一层抽象的网络编程接口,适用于各种底层网络协议,如IPv4、IPv6,以及后面要讲的UNIX Domain Socket。然而,各种网络协议的地址格式并不相同。
2024-04-12 22:13:18 915 2
原创 【Linux】网络基础(一)
OSI七层模型最大的优点是将服务、接口和协议这三个概念明确地区分开来,概念清楚,理论也比较完整,通过七个层次化的结构模型使不同的系统不同的网络之间实现可靠的通讯。但是,OSI七层模型既复杂又不实用,所以后来在具体实现的时候就对其进行了调整,于是就有了我们现在看到的TCP/IP四层协议。
2024-04-12 22:00:52 1201
原创 【Linux】线程封装 | 线程互斥 | 基于阻塞队列的生产消费者模型
代码必须要有互斥行为:当代码进入临界区执行时,不允许其他线程进入该临界区。如果多个线程同时要求执行临界区的代码,并且临界区没有线程在执行,那么只能允许一个线程进入该临界区。如果线程不在临界区中执行,那么该线程不能阻止其他线程进入临界区。做到以上这三点,本质上就是给临界区加一把锁。Linux上提供的这把锁叫互斥量。
2024-03-19 16:02:14 893 3
原创 【Linux】多线程概念 | POSIX线程库
线程是比进程更加轻量化的一种执行流,线程是在进程内部执行的一种执行流,线程是CPU调度的基本单位,而进程是承担系统资源的基本实体。换言之,当我们创建进程时是创建一个task_struct、创建地址空间、维护页表,然后在物理内存当中开辟空间、构建映射,打开进程默认打开的相关文件、注册信号对应的处理方案等等。在一个程序里的一个执行路线就叫做线程(thread)。更准确的定义是:线程是“一个进程内部的控制序列”。一切进程至少都有一个执行线程。
2024-03-19 15:37:18 1124
原创 【开发工具】Git模拟多人开发场景理解分支管理和远程仓库操作
这是一个模拟多人多分支协作开发的基本流程。你可以在本地多个分支之间切换,模拟不同开发者的工作,并通过合并、推送、拉取等操作进行分支集成。同时也可以在远程创建新分支,模拟其他贡献者的工作。选项不是必需的,但能自动建立分支关联关系,避免每次都要手动指定远程分支,非常方便。是两个不同的命令,它们的主要区别在于获取远程数据的方式和合并的行为。就可以了,Git会自动将本地分支推送到关联的远程分支。选项用于将当前本地分支与远程同名分支建立关联关系。因此,对于重要的项目分支,建议使用更保守的。分支,添加一些提交。
2024-03-06 18:17:24 650
原创 【开发工具】认识Git | 认识工作区、暂存区、版本库
所谓的版本控制器,就是能让你了解到一个文件的历史,以及它的发展过程的系统。• 在创建 Git 版本库时,Git 会为我们自动创建一个唯一的 master 分支,以及指向 master 的一个指针叫 HEAD。• 当对工作区修改(或新增)的文件执行 git add 命令时,暂存区目录树的文件索引会被更新。• --soft 参数对于工作区和暂存区的内容都不变,只是将版本库回退到某个指定版本。rm命令只会删除工作区的文件,对于暂存区和版本库中的内容没有影响。的内容退回为指定的版本内容,但工作区文件保持不变。
2024-03-06 18:16:23 1056
原创 【C++11】lambda表达式 | 函数包装器
lambda表达式是一个可调用对象,是一个无名函数,一个lambda表达式可以被赋值给对象,或者直接使用auto类型推导。是一个通用的函数封装器,它可以包装任意可调用对象,包括函数指针、函数对象、成员函数指针以及lambda表达式。lambda表达式提高了代码的可读性。
2024-02-23 18:07:12 1036 1
原创 【C++】C语言可变函数参数 | C++11可变参数模板
C语言使用stdarg.h来实现可变函数参数,通过va_listva_startva_arg和va_end宏进行操作。C++使用模板参数包来实现可变模板参数,可以利用递归、逗号表达式展开参数包处理不同数量的参数。
2024-02-23 17:54:49 1099 1
原创 C语言和C++的类型转换
C语言类型强转存在缺陷:转换的可视性比较差,所有的转换形式都是以一种相同形式书写,难以跟踪错误的转换。因此标准C++为了加强类型转换的可视性,引入了四种命名的强制类型转换操作符:`static_cast`、`reinterpret_cast`、`const_cast`、`dynamic_cast`
2024-02-20 16:35:21 1036 3
原创 【算法】一维、二维前缀和算法的模板
在没有前缀和的情况下,对于每个区间 [l, r],我们可能需要遍历数组并累加所有元素,这样的操作需要 O(n) 的时间。这样,在计算区间 [l, r] 的元素和时,我们只需要通过简单的减法操作得到 prefixSum[r] - prefixSum[l-1],而不需要重新遍历数组。总的来说,前缀和的优势在于提前计算出部分信息,通过存储中间结果避免了重复计算,从而显著提高了算法的效率。前缀和算法之所以能够将某些问题的时间复杂度从 O(n) 优化到 O(1),主要是因为它提供了一种有效的方式来避免重复计算。
2024-02-17 19:46:35 514 5
原创 【Linux】进程信号的保存 | 自定义捕捉
不是所有信号的处理都是立即进行的,而是在合适的时候处理,“合适的时候”是指进程从内核态返回到用户态的时候。有些信号,例如 SIGKILL,会立即终止进程。但对于其他信号,处理可能会延迟,具体取决于进程的状态以及是否被阻塞。
2024-02-17 19:01:29 1146
原创 【Linux】进程信号概念 | 核心转储 | 信号的产生
产生信号的方式可以有很多(譬如:由操作系统、其他进程,或者进程自身产生),但是向目标进程发送信号只能由操作系统发送,因为操作系统是进程的管理者,发送信号的本质是修改PCB中的信号位图。
2024-02-13 15:50:15 1314 4
原创 【C++11】右值引用 | 移动构造&赋值 | 万能引用 | 完美转发
传统的C++语法中就有`引用`的语法,而C++11中新增了的右值引用语法特性,所以从现在开始,为了与`右值引用(rvalue reference)`区分开来,我们可以称之为`左值引用 (lvalue reference)`。无论左值引用还是右值引用,都是给对象取别名。
2024-02-08 22:13:10 1120 2
原创 【Linux】文件的软硬链接
软链接:也称为符号链接,类似于 Windows 快捷方式,可以跨文件系统。硬链接:指向相同 inode 的文件副本,不能跨文件系统。
2024-02-08 10:06:02 2389 1
原创 【C++11】统一初始化 和 initializer_list
C++11扩大了用大括号括起的列表(初始化列表)的使用范围,使其可用于所有的内置类型和自定义类型。统一初始化是语法层面的,initializer_list是标准库提供的对语言层面的初始化列表的封装。
2024-02-07 01:14:37 1781 2
原创 高斯消去法 | LU分解 | PA=LU分解(MatLab)
高斯消去法、LU分解和PA=LU分解。这些算法是解线性方程组的基石,并且在各种应用领域中都有广泛的使用。代码实现的技巧使用MATLAB进行矩阵操作相对简单。
2024-02-04 23:36:17 2837 2
原创 【Linux】EXT2文件系统 | 磁盘分区&块组 | inode
我们已经学习了在内存中被打开(被加载)的文件,还有一部分是磁盘中未被打开的文件。这篇我们来谈磁盘文件。文件系统这个名词狭义上指的是磁盘文件系统,例如Linux下的ext2文件系统。
2024-02-04 23:26:46 1427
原创 【C++】异常
实际使用中很多公司都会自定义自己的异常体系进行规范的异常管理,因为一个项目中如果大家随意抛异常,那么外层的调用者基本就没办法玩了,所以实际中都会定义一套继承的规范体系。这样大家抛出的都是继承的派生类对象,捕获一个基类就可以了。
2024-02-02 21:07:23 1433 4
原创 【C语言】异常处理 | assert函数 | errno错误码
C语言传统的处理错误的方式主要包括assert终止程序和返回/设置错误码两种方式。
2024-02-02 20:49:42 1255 2
原创 利用牛顿方法求解非线性方程(MatLab)
牛顿方法(Newton's Method),也称为牛顿-拉弗森方法,是一种用于数值求解非线性方程的迭代方法。其基本思想是通过不断迭代来逼近方程的根。
2024-01-30 13:39:53 5053 2
原创 【Linux】System V 共享内存
"System V 共享内存" 是一种在类Unix操作系统中实现的共享内存机制,得名于AT&T的UNIX System V操作系统,其中引入了这种共享内存的概念。System V共享内存是System V IPC(Inter-Process Communication,进程间通信)机制的一部分,与其他System V IPC机制,如消息队列和信号量一起,提供了进程间通信的方式。
2024-01-30 13:33:43 1342
原创 利用二分法及不动点迭代求解非线性方程(MatLab)
理解二分法和不动点迭代法:通过本实验,你将更深刻地理解这两种数值方法的工作原理,优缺点,以及适用场合。收敛性分析:通过对不动点迭代公式的导数进行分析,你可以了解为什么某些迭代公式会收敛,而其他的不会。误差分析:二分法和不动点迭代法都有自己的误差范围和收敛速度,理解这些将有助于你选择更合适的方法解决实际问题。
2024-01-28 13:47:58 1899 4
原创 【Linux】命名管道
匿名管道与命名管道的区别- 匿名管道由`pipe`函数创建并打开。- 命名管道由`mkfifo`函数创建,打开用`open`- FIFO(命名管道)与 pipe(匿名管道)之间唯一的区别在它们创建与打开的方式不同,一但这些工作完成之后,它们具有相同的语义。
2024-01-28 13:38:39 1378
原创 熟悉MATLAB 环境
在这次的实验中,我深入了解了MATLAB的基础功能和环境。此外,我也体会到了为什么MATLAB在科学计算和工程领域如此受欢迎,它的向量化操作和强大的可视化工具使得处理数据和展示结果变得简单且直观。了解Matlab 数据的特点,熟悉Matlab 变量的命名规则,赋值语句及输出的格式。
2024-01-27 23:38:26 1170
原创 【Linux】进程间通信概念 | 匿名管道
进程间通信简称IPC(Interprocess communication),是操作系统中的一个重要概念,它允许不同的进程在执行过程中交换数据、共享资源、协调行为等。在多道程序设计环境下,多个进程可能需要相互通信以完成复杂的任务,而进程间通信提供了各种机制来实现这种交互。管道是Unix中最古老的进程间通信的形式。我们把从一个进程连接到另一个进程的一个数据流称为一个“管道”。
2024-01-27 23:20:25 1414
原创 【Linux】文件描述符 | 重定向 | C文件指针与fd的关系 | 用户级缓冲区
当进程用open()系统调用打开文件时,我们需要先将该文件从磁盘当中加载到内存,形成对应的struct file,将该struct file连入文件双链表,并将该结构体的首地址填入fd_array数组当中下标为3的位置,使得fd_array数组中下标为3的指针指向该struct file,最后open()返回该文件的文件描述符给调用进程即可。在Linux系统中,"一切皆文件"是一个核心概念,意味着系统中的各种资源,包括设备、套接字、管道等,都被抽象为文件,并通过文件描述符进行访问。
2024-01-26 15:51:54 1859 6
原创 【Linux】从C语言文件操作 到Linux文件IO | 文件系统调用
一个进程可以打开很多文件,所以操作系统运行时被打开的文件是很多的,操作系统当然要对这些被打开的文件做管理,管理的方式是:先描述,再组织。因此,一个文件要被打开,一定要先在内核中,形成被打开的文件对象。本文研究的文件操作的本质是:进程和内存中被打开(被加载)的文件的关系。
2024-01-26 15:30:44 1290
空空如也
空空如也
TA创建的收藏夹 TA关注的收藏夹
TA关注的人