数据结构-线性结构(链表、栈、队列)实现
公共头文件common.h
#define TRUE 1
#define FALSE 0// 定义节点数据类型
#define DATA_TYPE int
单链表C语言实现
SingleList.h
#pragma once#include "common.h"typedef struct Node
{DATA_TYPE data;struct Node *next;
} Node;Node *initList();void headInsert(Node *L, DATA_TYPE data);void tailInsert(Node *L, DATA_TYPE data);int contains(Node *L, DATA_TYPE data);int list_delete(Node *L, DATA_TYPE data);void printList(Node *L);void test_SingleList();int size(Node *L);
SingleList.c
#include <stdio.h>
#include <stdlib.h>#include "SingleList.h"// 头结点 链表的第一个节点 通常不存储实际的数据元素 用于简化操作、管理链表
// 首节点 头结点之后的第一个节点 链表中第一个存储实际数据的节点
Node *initList()
{Node *head = malloc(sizeof(Node));head->data = 0;head->next = NULL;return head;
}// 头插法
void headInsert(Node *L, DATA_TYPE data)
{Node *node = malloc(sizeof(Node));node->data = data;node->next = L->next;L->next = node;L->data++;
}// 尾插法 需要遍历整个链表找到尾结点
void tailInsert(Node *L, DATA_TYPE data)
{Node *p_tmp = L;while (p_tmp->next != NULL) // 找到尾结点{p_tmp = p_tmp->next;}Node *node = malloc(sizeof(Node));node->data = data;node->next = NULL;p_tmp->next = node;L->data++;
}int contains(Node *L, DATA_TYPE data)
{Node *p_tmp = L;while (p_tmp->next != NULL && p_tmp->next->data != data){p_tmp = p_tmp->next;}if (p_tmp->next == NULL){return FALSE;}return TRUE;
}int list_delete(Node *L, DATA_TYPE data)
{Node *preNode = L;Node *node = L->next;while (node){if (node->data == data){preNode->next = node->next; // 删除节点free(node); // 释放节点占用内存L->data--; // 链表节点数减一return TRUE;}preNode = node; // 保存前一个节点指针node = node->next;}return FALSE;
}void printList(Node *L)
{Node *node = L->next;while (node){printf("%d -> ", node->data);node = node->next;}printf("NULL\n");
}int size(Node *L)
{return L->data;
}void test_SingleList()
{Node *head = initList();headInsert(head, 1);headInsert(head, 2);headInsert(head, 3);tailInsert(head, 4);tailInsert(head, 5);tailInsert(head, 6);printf("contains: %d\n", contains(head, 1));printf("contains: %d\n", contains(head, 6));printf("size: %d\n", size(head));printList(head);printf("\n");list_delete(head, 4);list_delete(head, 6);printf("size: %d\n", size(head));printList(head);
}
单链表Java实现
public class SingleList {private int size; // 保存节点个数private Node head;public SingleList() {head = new Node(0); // 头结点数据域保存节点个数 与 size等价}public void headInsert(int data) {Node node = new Node(data, head.next);head.next = node;head.data++;size++;}public void tailInsert(int data) {Node tmp = head;while (tmp.next != null) { // 找到尾结点tmp = tmp.next;}Node node = new Node(data);tmp.next = node;size++;head.data++;}public boolean contains(int data) {Node tmp = head;while (tmp.next != null && tmp.data != data) {tmp = tmp.next;}if (tmp.next == null) {return false;}return true;}public boolean delete(int data) { // Java LinkedList包含节点前后引用Node preNode = head; // 保存删除节点的前一个节点Node node = head.next;while (node != null) {if (node.data == data) { // 要删除的节点preNode.next = node.next;size--;head.data--;return true;}preNode = node;node = node.next;}return false;}public void printList() {Node node = head.next;while (node != null) {System.out.print(node.data + " -> ");node = node.next;}}public int size() {
// return size;return head.data;}/*** 单链表节点类*/private static class Node {int data;Node next;public Node(int data) {this.data = data;}public Node(int data, Node next) {this.data = data;this.next = next;}}public static void main(String[] args) {SingleList list = new SingleList();list.headInsert(1);list.headInsert(2);list.headInsert(3);list.tailInsert(4);list.tailInsert(5);list.tailInsert(6);System.out.println(list.contains(1));System.out.println(list.contains(6));System.out.println("size: " + list.size());list.printList();System.out.println();list.delete(4);list.delete(6);System.out.println("size: " + list.size());list.printList();}
}
循环单链表
LoopSingleList.h
#pragma once#include "common.h"typedef struct Node
{DATA_TYPE data;struct Node *next;
} Node;Node *initList();void headInsert(Node *L, DATA_TYPE data);void tailInsert(Node *L, DATA_TYPE data);int list_delete(Node *L, DATA_TYPE data);void printList(Node *L);int size(Node *L);void test_loop_singleList();
LoopSingleList.c
#include <stdio.h>
#include <stdlib.h>#include "LoopSingleList.h"Node *initList()
{Node *head = malloc(sizeof(Node));head->data = 0;head->next = head;return head;
}void headInsert(Node *L, DATA_TYPE data)
{Node *node = malloc(sizeof(Node));node->data = data;node->next = L->next;L->next = node;L->data++;
}void tailInsert(Node *L, DATA_TYPE data)
{Node *node = malloc(sizeof(Node));node->data = data;Node *head = L;while (head->next != L){head = head->next;}node->next = L;head->next = node;L->data++;
}int list_delete(Node *L, DATA_TYPE data)
{Node *preNode = L;Node *node = L->next;while (node != L){if (node->data == data){preNode->next = node->next;free(node);L->data--;return TRUE;}preNode = node;node = node->next;}return FALSE;
}void printList(Node *L)
{Node *node = L->next;while (node != L){printf("%d -> ", node->data);node = node->next;}printf("(首节点)%d", node->next->data);
}int size(Node *L)
{return L->data;
}void test_loop_singleList()
{Node *head = initList();headInsert(head, 1);headInsert(head, 2);headInsert(head, 3);tailInsert(head, 4);tailInsert(head, 5);tailInsert(head, 6);printf("size: %d\n", size(head));printList(head);printf("\n");list_delete(head, 4);list_delete(head, 6);printf("size: %d\n", size(head));printList(head);
}
双链表
DoubleList.h
#include "common.h"typedef struct Node
{DATA_TYPE data;struct Node *pre;struct Node *next;
} Node;Node *initList();void headInsert(Node *L, DATA_TYPE data);void tailInsert(Node *L, DATA_TYPE data);int list_delete(Node *L, DATA_TYPE data);void printList(Node *L);int size(Node *L);void test_double_list();
DoubleList.c
#include <stdio.h>
#include <stdlib.h>#include "DoubleList.h"Node *initList()
{Node *head = malloc(sizeof(Node));head->data = 0;head->pre = NULL;head->next = NULL;return head;
}void headInsert(Node *L, DATA_TYPE data)
{Node *node = malloc(sizeof(Node));node->data = data;node->pre = L;node->next = L->next;if (L->next){L->next->pre = node;L->next = node;}else // 首次插入 L->next=NULL{L->next = node;}L->data++;
}void tailInsert(Node *L, DATA_TYPE data)
{Node *tail = L;while (tail->next){tail = tail->next;}Node *node = malloc(sizeof(Node));node->data = data;node->pre = tail;node->next = tail->next; // NULLtail->next = node;L->data++;
}int list_delete(Node *L, DATA_TYPE data)
{Node *head = L->next;while (head){if (head->data == data){if (head->next) // 如果不是尾结点{head->next->pre = head->pre;}head->pre->next = head->next;free(head);L->data--;return TRUE;}head = head->next;}return FALSE;
}void printList(Node *L)
{Node *node = L->next;while (node){printf("%d -> ", node->data);node = node->next;}printf("NULL\n");
}int size(Node *L)
{return L->data;
}void test_double_list()
{Node *head = initList();headInsert(head, 1);headInsert(head, 2);headInsert(head, 3);tailInsert(head, 4);tailInsert(head, 5);tailInsert(head, 6);printf("size: %d\n", size(head));printList(head);printf("\n");list_delete(head, 3); // 首节点list_delete(head, 4); // 中间节点list_delete(head, 6); // 尾结点printf("size: %d\n", size(head));printList(head);
}
循环双链表
LoopDoubleList.c
#include <stdio.h>
#include <stdlib.h>#include "DoubleList.h"Node *initList()
{Node *head = malloc(sizeof(Node));head->data = 0;head->pre = head;head->next = head;return head;
}void headInsert(Node *L, DATA_TYPE data)
{Node *node = malloc(sizeof(Node));node->data = data;node->pre = L;node->next = L->next;L->next->pre = node;L->next = node;L->data++;
}void tailInsert(Node *L, DATA_TYPE data)
{Node *tail = L;while (tail->next != L){tail = tail->next;}Node *node = malloc(sizeof(Node));node->data = data;node->pre = tail;node->next = tail->next;tail->next = node;L->data++;
}int list_delete(Node *L, DATA_TYPE data)
{Node *head = L->next;while (head != L){if (head->data == data){head->next->pre = head->pre;head->pre->next = head->next;free(head);L->data--;return TRUE;}head = head->next;}return FALSE;
}void printList(Node *L)
{Node *node = L->next;while (node != L){printf("%d -> ", node->data);node = node->next;}printf("NULL\n");
}int size(Node *L)
{return L->data;
}void test_double_list()
{Node *head = initList();headInsert(head, 1);headInsert(head, 2);headInsert(head, 3);tailInsert(head, 4);tailInsert(head, 5);tailInsert(head, 6);printf("size: %d\n", size(head));printList(head);list_delete(head, 3); // 首节点list_delete(head, 4); // 中间节点list_delete(head, 6); // 尾结点printf("size: %d\n", size(head));printList(head);
}
栈-链表实现
ListStack.h
#include "common.h"typedef struct Node
{DATA_TYPE data;struct Node *next;
} Node;Node *initStack();void push(Node *L, DATA_TYPE data);DATA_TYPE pop(Node *L);int is_empty(Node *L);void printStack(Node *L);void test_List_Stack();
ListStack.c
#include <stdio.h>
#include <stdlib.h>#include "listStack.h"Node *initStack()
{Node *head = malloc(sizeof(Node));head->data = 0;head->next = NULL;return head;
}void push(Node *L, DATA_TYPE data)
{Node *node = malloc(sizeof(Node));node->data = data;node->next = L->next;L->next = node;L->data++;
}DATA_TYPE pop(Node *L)
{if (L->next){Node *node = L->next;DATA_TYPE data = node->data;L->next = node->next;free(node); // 释放首节点内存L->data--;return data;}return 0;
}int is_empty(Node *L)
{return L->data == 0;
}void printStack(Node *L)
{Node *head = L->next;while (head){printf("%d -> ", head->data);head = head->next;}printf("NULL\n");
}void test_List_Stack()
{Node *stack = initStack();printf("is_empty: %d\n", is_empty(stack));push(stack, 1);push(stack, 2);push(stack, 3);push(stack, 4);printf("is_empty: %d\n", is_empty(stack));printStack(stack);pop(stack);printStack(stack);
}
栈-数组实现
ArrayStack.h
#include "common.h"void initStack();void push(DATA_TYPE data);DATA_TYPE pop();DATA_TYPE top();int is_empty();void printStack();void destroy_stack();void test_Array_Stack();
ArrayStack.c
#include <stdio.h>
#include <stdlib.h>#include "ArrayStack.h"static size_t size; // 栈大小
static DATA_TYPE *stack; // 数组表示
static int index = -1; // 栈顶指针void initStack(size_t stack_size)
{size = stack_size;stack = malloc(sizeof(DATA_TYPE) * size);
}void push(DATA_TYPE data)
{stack[++index] = data;
}DATA_TYPE pop()
{if (is_empty()){perror("空栈...\n");exit(1);}return stack[index--];
}DATA_TYPE top()
{return stack[index];
}int is_empty()
{return index == -1;
}void printStack()
{for (int i = index; i >= 0; i--){printf("%d ", stack[i]);}printf("\n");
}void destroy_stack()
{size = 0;free(stack);stack = NULL;
}void test_Array_Stack()
{initStack(10);printf("is_empty: %d\n", is_empty());push(1);push(2);push(3);push(4);printf("is_empty: %d\n", is_empty());printStack();printf("pop: %d\n", pop());printf("top: %d\n", top());printStack();destroy_stack();
}
队列-双链表实现
ListQueue.h
#pragma once#include "common.h"typedef struct Node
{DATA_TYPE data;struct Node *pre;struct Node *next;
} Node;Node *initQueue();void enQueue(Node *L, DATA_TYPE data);void deQueue(Node *L);void printQueue(Node *L);void test_List_Queue();
ListQueue.c
#include <stdio.h>
#include <stdlib.h>#include "ListQueue.h"Node *initQueue()
{Node *head = malloc(sizeof(Node));head->data = 0;head->pre = NULL;head->next = NULL;return head;
}void enQueue(Node *L, DATA_TYPE data)
{Node *head = L;while (head->next){head = head->next;}Node *node = malloc(sizeof(Node));node->data = data;node->pre = head;node->next = head->next;head->next = node;L->data++;
}void deQueue(Node *L)
{Node *node = L->next;L->next = node->next;node->next->pre = L;free(node);L->data--;
}void printQueue(Node *L)
{Node *node = L;while (node->next){printf("%d <- ", node->next->data);node = node->next;}printf("NULL\n");
}void test_List_Queue()
{Node *head = initQueue();enQueue(head, 1);enQueue(head, 2);enQueue(head, 3);enQueue(head, 4);printQueue(head);deQueue(head);deQueue(head);printQueue(head);
}
循环队列
ArrayCircularQueue.h
#include <stdlib.h>#include "common.h"typedef struct Queue
{DATA_TYPE *data;int front;int rear;
} Queue;Queue *initQueue(size_t size);void enQueue(Queue *Q, DATA_TYPE value);DATA_TYPE deQueue(Queue *Q);int isFull(Queue* Q);int isEmpty(Queue* Q);void printQueue(Queue *Q);void test_Array_Queue();
ArrayCircularQueue.c
#include <stdio.h>
#include <stdlib.h>#include "ArrayCircularQueue.h"/**
* 当普通队列的尾指针达到存储空间的末尾时,即使队列前方仍有空位,也无法继续存储新元素,这就是假溢出现象。
* 循环队列通过将存储空间视为环状来解决这一问题,使得当队尾指针到达末尾时,可以循环回到存储空间的开头继续存储元素。
*/static size_t queue_size = -1;Queue *initQueue(size_t size)
{Queue *Q = malloc(sizeof(Queue));queue_size = size;Q->data = malloc(sizeof(DATA_TYPE) * size);Q->front = Q->rear = 0;return Q;
}void enQueue(Queue *Q, DATA_TYPE value)
{if (isFull(Q))return;Q->data[Q->rear] = value;Q->rear = (Q->rear + 1) % queue_size;
}DATA_TYPE deQueue(Queue *Q)
{if (isEmpty(Q)){perror("空队列...");exit(1);}DATA_TYPE val = Q->data[Q->front];Q->front = (Q->front + 1) % queue_size;return val;
}int isFull(Queue *Q)
{return (Q->rear + 1) % queue_size == Q->front;
}int isEmpty(Queue *Q)
{return Q->front == Q->rear; // 初始化时 队列为空
}void printQueue(Queue *Q)
{// 获取队列长度:队列中有多少个元素int len = (Q->rear - Q->front + queue_size) % queue_size;int index = Q->front;for (int i = 0; i < len; i++){printf("%d <- ", Q->data[index]);index = (index + 1) % queue_size;}printf("NULL\n");
}void test_Array_Queue()
{Queue *Q = initQueue(5);enQueue(Q, 1);enQueue(Q, 2);enQueue(Q, 3);enQueue(Q, 4);printf("isFull: %d\n", isFull(Q));enQueue(Q, 4);printf("isFull: %d\n", isFull(Q));printQueue(Q);deQueue(Q);deQueue(Q);printQueue(Q);
}
总结
栈:适用于需要后进先出的场景,如函数调用栈、表达式求值等。
队列:适用于需要先进先出的场景,如任务调度、消息队列等。
链表:适用于频繁插入和删除元素的场景,如链表实现的动态内存管理。
顺序表:一种以数组形式实现的线性结构,具有随机访问的特点。元素在内存中是连续存储的,支持快速的元素访问,但插入和删除操作需要移动多个元素。
相关文章:
数据结构-线性结构(链表、栈、队列)实现
公共头文件common.h #define TRUE 1 #define FALSE 0// 定义节点数据类型 #define DATA_TYPE int单链表C语言实现 SingleList.h #pragma once#include "common.h"typedef struct Node {DATA_TYPE data;struct Node *next; } Node;Node *initList();void headInser…...
第 7 篇:跳表 (Skip List):简单务实的概率性选手
前面几篇我们都在探讨各种基于“树”结构的有序表实现,它们通过精巧的平衡策略(高度、颜色、大小)和核心的“旋转”操作来保证 O(log N) 的性能。今天,我们要介绍一位画风完全不同的选手——跳表 (Skip List)。它不依赖树形结构&a…...
sys目录介绍
文章目录 1. 前言2. 目录层次3. 目录介绍3.1 devices 目录3.2 block 目录3.3 bus 目录3.4 class 目录3.5 dev 目录3.6 firmware目录3.7 fs 目录3.8 kernel目录3.9 module 目录3.10 power 目录 sys目录介绍 1. 前言 linux 下一切皆文件,文件的类型也很多,…...
基于DQN的自动驾驶小车绕圈任务
1.任务介绍 任务来源: DQN: Deep Q Learning |自动驾驶入门(?) |算法与实现 任务原始代码: self-driving car 最终效果: 以下所有内容,都是对上面DQN代码的改进&#…...
源码安装SRS4
Ubuntu20安装好SRS后,(源码安装) 注意:在trunk目录SRS ./objs/srs -c conf/srs.conf 以上为启动srs命令,-c 为指定配置文件, 查看SRS进程 ps aux | grep srs 查看端口: netstat -ano | gre…...
OrbitControls
OrbitControls 3D虚拟工厂在线体验 描述 Orbit controls(轨道控制器)可以使得相机围绕目标进行轨道运动。 Constructor OrbitControls( object : Camera, domElement : HTMLDOMElement ) 参数类型描述objectCamera(必须)将要…...
【数据库】四种连表查询:内连接,外连接,左连接,右连接
在数据库操作中,连表查询是处理多表关联的核心技术。以下是四种主要连接方式的详细介绍、快速掌握方法及实际应用指南: 目录 **一、四种连表查询详解****1. 内连接(INNER JOIN)****2. 左连接(LEFT JOIN / LEFT OUTER J…...
Redis怎么避免热点数据问题
使用 RedisTemplate 避免热点数据问题的解决方案、场景及示例: 1. 数据分片(Sharding) 场景:高频读写的计数器(如文章阅读量统计) 原理:将数据分散到多个子键,降低单个 Key 的压…...
完整的 VS Code + CMake + Qt + GCC 项目构建方案:EXE 程序与多个 DLL 库
完整的 VS Code CMake Qt GCC 项目构建方案:EXE 程序与多个 DLL 库 在本文中,我们将介绍如何构建一个包含 EXE 程序和多个 DLL 库的项目,适用于 VS Code CMake Qt GCC 开发环境。这个方案为一个模块化的项目结构,使得代码清…...
Python 数据智能实战 (7):智能流失预警 - 融合文本反馈
写在前面 —— 不再错过关键预警!结合用户行为与 LLM 文本洞察,构建更精准的流失预测模型 在之前的探索中,我们学习了如何利用大语言模型 (LLM) 对用户评论进行深度挖掘,提取情感、发现主题,并将非结构化的文本信息转化为有价值的特征 (如 Embeddings)。 现在,我们要将…...
Flutter - 概览
Hello world ⌘ shift p 选择 Empty Application 模板 // 导入Material风格的组件包 // 位置在flutter安装目录/packages/flutter/lib/material.dart import package:flutter/material.dart;void main() {// runApp函数接收MainApp组件并将这个Widget作为根节点runApp(cons…...
Python-pandas-操作Excel文件(读取数据/写入数据)及Excel表格列名操作详细分享
Python-pandas-操作Excel文件(读取数据/写入数据) 提示:帮帮志会陆续更新非常多的IT技术知识,希望分享的内容对您有用。本章分享的是pandas的使用语法。前后每一小节的内容是存在的有:学习and理解的关联性。【帮帮志系列文章】:每…...
手写 Vue 源码 === Vue3 设计思想
1.声明式框架 Vue3 是声明式的框架,用起来简单。 命令式和声明式区别 早在 JQ 的时代编写的代码都是命令式的,命令式框架重要特点就是关注过程声明式框架更加关注结果。命令式的代码封装到了 Vuejs 中,过程靠 vuejs 来实现声明式代码更加简单,不需要关注实现,按照要求填代…...
Android WebView加载h5打开麦克风与摄像头的权限问题
目录 快速处理 app向系统申请录音与相机权限h5向app申请录音和相机权限 详细解答 app权限与h5权限录音与麦克风默许的风险最佳实践 Android webview h5 麦克风权限,摄像头(相机)权限实现与填坑。 快速处理 app向系统申请录音与相机权限 …...
三种计算最小公倍数的方法分析
三种计算最小公倍数的方法分析与比较 一.引言 最小公倍数(Least Common Multiple, LCM)是数学中的一个基本概念,指能够被两个或多个整数整除的最小的正整数。在编程中,我们有多种方法可以计算两个数的最小公倍数。本文将分析三种…...
PDF转换工具xpdf-tools-4.05
XPDF是一个开源的PDF查看、提取和转换工具套件,使用C编写,支持多种操作系统,包括Linux、Unix、OS/2、Windows和Mac OS X1。XPDF不仅是一个PDF查看器,还包含多个实用工具,如文本提取器、图像转换器和HTML转换器等&a…...
aws(学习笔记第四十课) image-content-search
aws(学习笔记第四十课) image-content-search 使用SQS Lambda集成 数据库(Aurora Serverless) Cognito(用户管理) rekognition(图像解析) 学习内容: 使用SQS Lambda Aurora Serverless Cog…...
GPT-4o 图像生成与八个示例指南
什么是GPT-4o图像生成? 简单来说,GPT-4o图像生成是集成在ChatGPT内部的一项功能。用户可以直接在对话中,通过文本描述(Prompt)来创建、编辑和调整图像。这与之前的图像生成工具相比,体验更流畅、交互性更强…...
PostgreSQL 查看表膨胀情况的方法
PostgreSQL 查看表膨胀情况的方法 表膨胀(Table Bloat)是PostgreSQL中由于MVCC机制导致的一种常见现象,当大量数据被更新或删除后,表中会积累"死元组"(dead tuples),这些死元组占据空间但不可见,导致表实际占用的磁盘空…...
从 0 到 1!深度剖析项目实施流程,开启项目管理新视野
一、项目准备 / 前期准备 (一)跟销售进行项目交接 对接人:销售人员交接会议内容: 了解项目背景、客户基本信息、项目版本、具备二次开发功能、接口、了解合同信息等。明确项目情况、客户基本情况、使用软件(版本&…...
书生实战营之沐曦专场
一:实验环境进入和启动实验容器(D.run平台) 1.1首先进入平台进行注册 D.run平台https://console.d.run/ 注册和登录环节就跳过了。 1.2 启动实验容器--详细步骤如下 1.2.1选择容器的名称、区域、镜像(注意镜像必须选择Dlinfer) 1.2.2可以选…...
在运行 Hadoop 作业时,遇到“No such file or directory”,如何在windows里打包在虚拟机里运行
最近在学习Hadoop集群map reduce分布运算过程中,经多方面排查可能是电脑本身配置的原因导致每次运行都会报“No such file or directory”的错误,最后我是通过打包文件到虚拟机里运行得到结果,具体步骤如下: 前提是要保证maven已经…...
基于YOLOV5的目标检测识别
基于YOLOV5的目标检测识别 舰船目标检测口罩目标检测飞机目标检测 舰船目标检测 口罩目标检测 飞机目标检测...
第4篇:服务层抽象与复用逻辑
在业务系统复杂度指数级增长的今天,服务层(Service Layer)的合理设计直接影响着系统的可维护性和扩展性。本文将深入剖析 Egg.js 框架中的服务层架构设计,从基础实现到高级封装,全方位讲解企业级应用的开发实践。 一、…...
多模态大语言模型arxiv论文略读(五十四)
RoboMP 2 ^2 2: A Robotic Multimodal Perception-Planning Framework with Multimodal Large Language Models ➡️ 论文标题:RoboMP 2 ^2 2: A Robotic Multimodal Perception-Planning Framework with Multimodal Large Language Models ➡️ 论文作者ÿ…...
中小企业MES系统详细设计
版本:V1.1 日期:2025年5月2日 一、设备协议兼容性设计 1.1 设备接入框架 #mermaid-svg-PkwqEMRIIlIBPP58 {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-PkwqEMRIIlIBPP58 .error-icon{fill…...
第二十周:项目开发中遇到的相关问题(一)
自十九周开始,我们便开始着手写项目(关于新闻资讯类的Web项目),当然,在这之中我们也学到了很多高效且有用的好技术,在接下来的内容中将去具体的描述这些好技术,介绍它们的具体用法和应用场景。本…...
WebRtc10: 端对端1v1传输基本流程
媒体能力协商过程 RTCPeerConnection(核心类) 基本格式 pc new RTCPeerConnection([configiration]); RTCPeerConnection方法分类 媒体协商Stream/Track传输相关方法统计相关方法 媒体协商过程 协商状态变化 媒体协商方法 createOffercreateAnswe…...
【云备份】配置文件加载模块
目录 一.为什么要配置文件 二.配置文件的实现 三.单例文件配置类设计 四.源码 一.为什么要配置文件 我们将服务端程序运行中用到的一些关键信息保存到配置文件中,这样可以使程序的运行更加灵活。 这样做的好处是,未来如果我们想要修改一些关键信息&…...
重构之道:识别并替换不合适使用的箭头函数
1、引言 JavaScript 自 ES6 引入了箭头函数(Arrow Function)后,因其简洁的语法和对 this 的词法绑定机制,迅速成为开发者喜爱的写法之一。然而,并不是所有场景都适合使用箭头函数。 在实际开发中,我们常常会因为追求代码简洁而忽视其潜在问题,例如: this 指向错误不适…...
git问题记录-如何切换历史提交分支,且保留本地修改
问题记录 我在本地编写了代码,突然想查看之前提交的代码,并且想保留当前所在分支所做的修改 通过git stash对本地的代码进行暂存 使用git checkout <commit-hash>切换到之前的提交记录。 查看完之后我想切换回来,恢复暂存的本地代码…...
【MySQL】事务管理
事务管理 一. 事务的概念二. 事务的特征三. 事务的版本支持四. 事务的提交方式五. 事务的常见操作六. 事务的隔离级别1. 查看与设置隔离级别2. 读未提交 (Read Uncommitted)3. 读提交 (Read Committed)4. 可重复读 (Repeatable Read)5. 串行化 (Serializable)6. 隔离级别的总结…...
【点对点协议(PPP)全解析】从原理到工程实践
目录 前言技术背景与价值当前技术痛点解决方案概述目标读者说明 一、技术原理剖析核心概念图解核心作用讲解关键技术模块说明技术选型对比 二、实战演示环境配置要求核心配置实现案例1:基础PPP链路建立案例2:CHAP认证配置 运行结果验证 三、性能对比测试…...
环境搭建:开启 Django 开发之旅
一、环境搭建:开启 Django 开发之旅 (一)安装 Python 先确保电脑上装有 Python 3.6 及以上版本,Django 5.1 的话,至少得 Python 3.8 哦。 安装前,先查下有没有装过 Python ,终端(Wi…...
如何配置NGINX作为反向代理服务器来缓存后端服务的响应?
大家好,我是锋哥。今天分享关于【如何配置NGINX作为反向代理服务器来缓存后端服务的响应?】面试题。希望对大家有帮助; 如何配置NGINX作为反向代理服务器来缓存后端服务的响应? 1000道 互联网大厂Java工程师 精选面试题-Java资源…...
【Java IO流】File类基础详解
参考笔记:java File类基础 万字详解(通俗易懂)-CSDN博客 目录 1.前言 2. File类介绍 3. File类构造方法 4.File类常用的方法案例演示 4.1 创建文件/文件夹的方法 4.2 删除文件/文件夹的方法 4.3 判断文件/文件夹是否存在的方法 4.4 …...
《C#数据结构与算法》—201线性表
线性表的实现方式 顺序表 线性表的顺序存储是指在内存中用一块地址连续的空间依次存放线性表的数据元素,用这种方式存储的线性表叫顺序表。 特点:表中相邻的数据元素在内存中存储位置也相邻。 顺序表接口实现: 方法名参数返回值描述GetLen…...
MATLAB绘制局部放大图
今天,我将分享一段 MATLAB 代码,该代码生成了一个主副图结合的可视化展示,用于比较不同控制系统性能表现。 clc; clear; close all;% 生成时间向量 t 0:0.1:12;% 生成模拟数据 zero_feedback 0.5 * ones(size(t)); % 恒定…...
TS 常用类型
JS不会检查变量类型的变化 给变量规定特定的数据类型,错误赋值时会报错 优势:TS会标记出代码中的意外行为,尤其是typeerrors 具体实现:类型注解 JS和TS中数据类型的变化...
[Control-Chaos] Toxic Cascade(毒性級鏈)
信息 信息描述靶場名稱Toxic Cascade地址GitHub: Toxic Cascade難度中等人數推薦1人類型CTF、APT 攻擊模擬、故事解謎、化工工程與逆向工程描述Toxic Cascade 是一個結合 CTF、APT 攻擊模擬、故事解謎、化工工程與逆向工程的高度沉浸式靶場。該靶場具有獨特的情境背景與模擬真…...
纳米AI搜索体验:MCP工具的实际应用测试,撰写报告 / 爬虫小红书效果惊艳
1. 引言 近期测试了纳米AI搜索的MCP工具功能,重点体验了其智能体在报告生成和社交媒体数据分析方面的表现。平台整合了100多个MCP工具,通过本地化部署的方式,为用户提供了不同于云端方案的操作体验。本文将分享实际测试结果,包括智…...
React useMemo函数
第一个参数是回调函数,返回计算的结果,第二个参数是依赖项,该函数只监听count1变量的变化 import { useReducer, useState } from react; import ./App.css;// 定义一个Reducer函数 根据不同的action进行不同的状态修改 function reducer(st…...
第 1 篇:起点的选择:为何需要超越数组与链表?
大家好,欢迎来到“数据结构选型指南”系列!在软件开发中,数据是核心,而如何高效地组织和访问这些数据,则是程序性能的关键。选择合适的数据结构,就像为你的 Java 应用选择最优的“引擎零件”。今天…...
MySQL 索引不生效的情况
MySQL 索引不生效的 SQL 查询需要避免的情况 索引是提高 MySQL 查询性能的关键,但某些 SQL 写法会导致索引失效,从而影响查询效率。以下是需要避免的常见情况: 1. 使用 NOT、! 或 <> 操作符 -- 索引可能失效 SELECT * FROM users WH…...
【阿里云大模型高级工程师ACP学习笔记】2.9 大模型应用生产实践 (上篇)
特别说明:由于这一章节是2025年3月官方重点更新的部分,新增内容非常多,因此我不得不整理成上、下两篇,方便大家参考。 学习目标 备考阿里云大模型高级工程师ACP认证,旨在全面掌握大模型应用生产实践的专业知识,提升在该领域的实操技能与理论水平,为职业发展增添助力。具…...
STM32 ZIBEE DL-20 无线串口模块
一.配置方法 二.串口中断 u8 i; u16 buf[20],res; u8 receiving_flag 0; // 新增一个标志,用于标记是否开始接收数组 void USART1_IRQHandler(void) {if(USART_GetITStatus(USART1, USART_IT_RXNE) ! RESET) //接收中断{res USART_ReceiveData(USART1);if(receiv…...
【算法基础】选择排序算法 - JAVA
一、算法基础 1.1 什么是选择排序 选择排序是一种简单直观的排序算法,它的工作原理是:首先在未排序序列中找到最小(或最大)元素,存放到排序序列的起始位置,然后再从剩余未排序元素中继续寻找最小…...
FastAPI 与数据库交互示例
目录 安装必要的包完整代码示例运行应用使用说明API 端点说明代码解析 下面将创建一个简单的 FastAPI 应用程序,演示如何与 SQLite 数据库进行交互。这个例子包括创建、读取、更新和删除(CRUD)操作。 安装必要的包 首先,需要安装…...
(六——下)RestAPI 毛子(Http resilience/Refit/游标分页)
文章目录 项目地址一、Refit1.1 安装需要的包1.2 创建接口IGitHubApi1.3 创建RefitGitHubService1. 实现接口2. 注册服务 1.4 修改使用方法 二、Http resilience2.1 安装所需要的包2.2 创建resilience pipeline简单版2.3 创建全局的resilience处理1. 创建清理全局ResilienceHan…...
Rust 学习笔记:关于枚举与模式匹配的练习题
Rust 学习笔记:关于枚举与模式匹配的练习题 Rust 学习笔记:关于枚举与模式匹配的练习题以下程序能否通过编译?若能,输出是什么?考虑这两种表示结果类型的方式,若计算成功,则包含值 T;…...