【数据结构与算法(C 语言)】栈的基本操作函数(动图演示) 及 栈的实际应用之一:进制转换
目录
- 1. 前言
- 2. 结构及基本操作函数:
- 2.1 栈的结构类型 Stack
- 2.2 初始化栈 InitStack
- 2.3 销毁栈 DestroyStack
- 2.4 清空栈 ClearStack
- 2.5 判断栈是否为空 StackEmpty
- 2.6 获取stack的长度 StackLength
- 2.7 获取栈顶元素 GetTop
- 2.8 入栈 Push
- 2.9 出栈 Pop
- 2.10 访问元素
- 2.11 遍历栈的所有元素
- 3. 严蔚敏版完整测试代码:
- 3.1 代码
- 3.2 运行结果:
- 4. 简易版完整测试代码
- 4.1 完整代码
- 4.2 运行结果
- 5. 栈的应用 :进制转化
- 5.1 转化函数
- 5.2 进制转化完整代码
- 5.3 运行结果
1. 前言
栈的操作思想:先进后出
本文的基本操作函数使用 严蔚敏版的《数据结构与算法》中的实现方式。此方式可以实现动态的分配栈空间内存。
本文还有一个更为简单的栈操作方式,虽简单,但是就失去了动态分配栈空间内存的优势。栈空间的最大值会被限制。
对比之下,严教授的编程思想还是比一般人厉害。
入栈和出栈的示意图:


2. 结构及基本操作函数:
2.1 栈的结构类型 Stack
typedef struct Stack{SElemType * base; //栈底指针SElemType * top; //栈顶指针int stacksize; //当前已分配的存储空间
} SqStack;
2.2 初始化栈 InitStack
功能: 初始化栈 ,分配栈底内存空间,栈空间大小设置初始值
/*初始化栈*/
Status InitStack(SqStack * stack)
{stack->base =(SElemType * )malloc(STACK_INIT_SIZE* sizeof(SElemType));if(!stack->base)exit(EXIT_FAILURE);stack->top=stack->base; // 栈顶指针初始 指向栈底;stack->stacksize=STACK_INIT_SIZE;return TRUE;
}
2.3 销毁栈 DestroyStack
功能:销毁栈,释放内存空间
/*销毁栈 */
Status DestroyStack(SqStack * stack)
{free(stack->base);stack->top=stack->base=NULL;stack->stacksize=0;return TRUE;
}
2.4 清空栈 ClearStack
功能: 清空栈内数据,区别于销毁栈的释放内存。只需要将栈顶指针等于栈底指针
/* 清理stack,只需要将top指针指向base*/
Status ClearStack(SqStack * stack)
{stack->top=stack->base;return TRUE;
}
2.5 判断栈是否为空 StackEmpty
功能: 判断栈是否为空,在实际应用中,这个函数经常要用到
/* 判断栈是否为空 */
Status StackEmpty(SqStack stack)
{if(stack.base == stack.top)return TRUE;else return FALSE;
}
2.6 获取stack的长度 StackLength
/* 获取stack的长度 */
int StackLength(SqStack stack)
{return stack.top - stack.base;
}
2.7 获取栈顶元素 GetTop
功能 :获取栈顶元素,并将值传递给 e,注意区别于下面的pop函数,GetTop是不改变栈的元素。
/* 获取栈顶元素,并将值传递给 e*/
Status GetTop(SqStack stack, SElemType * e)
{if(StackEmpty(stack))return FALSE;*e = *--stack.top;
}
2.8 入栈 Push
功能: 入栈, 将元素e压入栈中。这里面就涉及到一个扩容问题,如果栈的空间不够,可以增加栈的内存空间。
/*入栈, 将元素e压入栈中 */
Status Push(SqStack * stack,SElemType e)
{if(stack->top - stack->base >= stack->stacksize)//如果空间不够的话,扩容{stack->base =(SElemType *) realloc(stack->base,(stack->stacksize+STACKINCREMENT)* sizeof(SElemType));if(!stack->base)exit(EXIT_FAILURE);stack->stacksize += STACKINCREMENT;}*stack->top++ = e;return TRUE;
}
示意图 :
2.9 出栈 Pop
/*出栈, 从栈顶弹出元素,并将元素值传递给e*/
Status Pop(SqStack * stack ,SElemType * e)
{if(!stack->base)return FALSE;if(stack->base == stack->top) //空栈return FALSE;*e = *(--stack->top);return TRUE;
}
示意图 :
以上的函数在各类实际应用中基本都不用修改,可以直接使用。下面还有两个函数,栈元素的访问,一般在实际应用中,根据需要自行的灵活修改。
2.10 访问元素
功能 :访问元素,因为是测试用的,所以打印就行了
/* 访问元素 */
void Visit(SElemType e)
{printf("%d\t", e);
}
2.11 遍历栈的所有元素
功能:遍历stack,对stack的每一个元素调用visit函数。
/* 遍历stack,对stack的每一个元素调用visit函数 */
Status StackTraverse(SqStack stack,void (*visit)(SElemType e))
{SElemType * curElem=stack.base;if(StackEmpty(stack))return FALSE;while(curElem!=stack.top)visit(*curElem++);return TRUE;
}
3. 严蔚敏版完整测试代码:
3.1 代码
/*此版本为严蔚敏老师版本此版本,栈的空间大小可以*/#include <stdio.h>
#include <stdlib.h>#define STACK_INIT_SIZE 100 //初始内存空间
#define STACKINCREMENT 10 // 内存空间增量#define TRUE 1
#define FALSE 0typedef int SElemType;typedef struct Stack{SElemType *base; //栈底指针SElemType * top; //栈顶指针int stacksize; //当前已分配的存储空间
} SqStack;typedef int Status;Status InitStack(SqStack * stack);
Status DestroyStack(SqStack * stack);
Status ClearStack(SqStack * stack);
Status StackEmpty(SqStack stack);
int StackLength(SqStack stack);
Status GetTop(SqStack stack, SElemType * e);
Status Push(SqStack * stack,SElemType e);
Status Pop(SqStack * stack, SElemType *e);
void Visit(SElemType e);
Status StackTraverse(SqStack stack,void (*visit)(SElemType));/*初始化栈*/
Status InitStack(SqStack * stack)
{stack->base =(SElemType * )malloc(STACK_INIT_SIZE* sizeof(SElemType));if(!stack->base)exit(EXIT_FAILURE);stack->top=stack->base; // 栈顶指针初始 指向栈底;stack->stacksize=STACK_INIT_SIZE;return TRUE;
}/*销毁栈 */
Status DestroyStack(SqStack * stack)
{free(stack->base);stack->top=stack->base=NULL;stack->stacksize=0;return TRUE;
}
/* 清理stack,只需要将top指针指向base*/
Status ClearStack(SqStack * stack)
{stack->top=stack->base;return TRUE;
}/* 判断栈是否为空 */
Status StackEmpty(SqStack stack)
{if(stack.base == stack.top)return TRUE;else return FALSE;
}/* 获取stack的长度 */
int StackLength(SqStack stack)
{return stack.top - stack.base;
}/* 获取栈顶元素,并将值传递给 e*/
Status GetTop(SqStack stack, SElemType * e)
{if(StackEmpty(stack))return FALSE;*e = *--stack.top;
}/*入栈, 将元素e压入栈中 */
Status Push(SqStack * stack,SElemType e)
{if(stack->top - stack->base >= stack->stacksize)//如果空间不够的话,扩容{stack->base =(SElemType *) realloc(stack->base,(stack->stacksize+STACKINCREMENT)* sizeof(SElemType));if(!stack->base)exit(EXIT_FAILURE);stack->stacksize += STACKINCREMENT;}*stack->top++ = e;return TRUE;
}
/*出栈, 从栈顶弹出元素,并将元素值传递给e*/
Status Pop(SqStack * stack ,SElemType * e)
{if(!stack->base)return FALSE;if(stack->base == stack->top) //空栈return FALSE;*e = *(--stack->top);return TRUE;
}/* 访问元素 */
void Visit(SElemType e)
{printf("%d\t", e);
}/* 遍历stack,对stack的每一个元素调用visit函数 */
Status StackTraverse(SqStack stack,void (*visit)(SElemType e))
{SElemType * curElem=stack.base;if(StackEmpty(stack))return FALSE;while(curElem!=stack.top)visit(*curElem++);return TRUE;}int main()
{SqStack stack;SElemType elem;InitStack(&stack);printf("压入数字1、2、3\n");Push(&stack,1);Push(&stack,2);Push(&stack,3);printf("当前栈的容量:%d\n",StackLength(stack));GetTop(stack,&elem);printf("栈顶元素为:%d\n",elem);printf("将4、5压入栈中\n");Push(&stack,4);Push(&stack,5);Pop(&stack,&elem);printf("弹出栈顶元素为:%d\n",elem);printf("当前栈的容量:%d\n",StackLength(stack));printf("遍历栈:");StackTraverse(stack,Visit);printf("\n");DestroyStack(&stack);getchar();return 0;
}
3.2 运行结果:

4. 简易版完整测试代码
简易版,无法动态的给栈扩容
4.1 完整代码
/*此版本为简易版本*/#include <stdio.h>
#include <stdlib.h>#define TRUE 1
#define FALSE 0
#define MAXSIZE 30typedef int Status;typedef int ElemType; //定义元素类型为整型
typedef struct{ElemType * base; //在栈构造之前和销毁之后,base的值均为NULLint top;
}SqStack;/*初始化栈,为栈分配空间*/
Status InitStack(SqStack * stack)
{stack->base=(ElemType*) malloc(sizeof(ElemType)*MAXSIZE);if(stack->base==NULL)return FALSE;stack->top= -1; //初始值可以是-1,也可以设置为0。//如果设置为-1,那么当栈不为空时, 栈顶元素为 stack->base[top]//如果设置为0, 那么当栈不为空时, 栈顶元素为 stack->base[top-1]return TRUE;
}/*销毁栈,释放栈的数据空间*/
void DestroyStack(SqStack *stack)
{free(stack->base);stack->base=NULL;stack->top= -1;
}/* 获取栈顶元素 */
Status GetTop(SqStack stack, ElemType * elem)
{if(stack.top<0)return FALSE;*elem=stack.base[stack.top];return TRUE;
}/* 压栈,将元素elem 插入栈顶 */
Status Push(SqStack * stack,ElemType elem)
{if(stack->top == MAXSIZE-1) /*栈已经满了,实际应用中,可以动态扩展栈的空间*/return FALSE;stack->base[++stack->top]=elem;return TRUE;
}/*出栈,将栈顶元素elem出栈,相当于删除栈顶元素 */
Status Pop(SqStack * stack,ElemType * elem)
{if(stack->top<0)return FALSE;*elem=stack->base[stack->top--];return TRUE;
}int main ()
{SqStack stack;ElemType * elem=(ElemType*)malloc(sizeof(ElemType));InitStack(&stack);printf("压入数字1、2、3\n");Push(&stack,1);Push(&stack,2);Push(&stack,3);printf("当前栈的容量:%d\n",stack.top+1);GetTop(stack,elem);printf("栈顶元素为:%d\n",*elem);printf("将4、5压入栈中\n");Push(&stack,4);Push(&stack,5);Pop(&stack,elem);printf("弹出栈顶元素为:%d\n",*elem);printf("当前栈的容量:%d\n",stack.top+1);printf("\n");DestroyStack(&stack);free(elem);getchar();return 0;
}
4.2 运行结果

5. 栈的应用 :进制转化
5.1 转化函数
此函数是将10进制的数据 转化为2进制或者8进制 。
/* 十进制制转换成8进制或2进制* 参数radix 进制数,如果要转换成2进制,则输入2,如果转换成8进制,则radix=8* 参数n 待转换的十进制数 */
void conversion(int radix,int n)
{SqStack stack;int elem;InitStack(&stack);while(n){Push(&stack,n%radix); // 将余数入栈n=n/radix; // 商做为被除数,进行下一个循环(只要商不为0,就继续除下去)}while(!StackEmpty(stack)){ //从栈中,将余数依次取出。Pop(&stack ,&elem);printf("%d",elem);}printf("\n");
}
5.2 进制转化完整代码
#include <stdio.h>
#include <stdlib.h>#define STACK_INIT_SIZE 100 //初始内存空间
#define STACKINCREMENT 10 // 内存空间增量#define TRUE 1
#define FALSE 0typedef int Status;typedef int SElemType;typedef struct Stack{SElemType *base; //栈底指针SElemType * top; //栈顶指针int stacksize; //当前已分配的存储空间
} SqStack;Status InitStack(SqStack * stack);
Status DestroyStack(SqStack * stack);
Status ClearStack(SqStack * stack);
Status StackEmpty(SqStack stack);
int StackLength(SqStack stack);
Status GetTop(SqStack stack, SElemType * e);
Status Push(SqStack * stack,SElemType e);
Status Pop(SqStack * stack, SElemType *e);
void Visit(SElemType e);
Status StackTraverse(SqStack stack,void (*visit)(SElemType));/*初始化栈*/
Status InitStack(SqStack * stack)
{stack->base =(SElemType * )malloc(STACK_INIT_SIZE* sizeof(SElemType));if(!stack->base)exit(EXIT_FAILURE);stack->top=stack->base; // 栈顶指针初始 指向栈底;stack->stacksize=STACK_INIT_SIZE;return TRUE;
}/*销毁栈 */
Status DestroyStack(SqStack * stack)
{free(stack->base);stack->top=stack->base=NULL;stack->stacksize=0;return TRUE;
}
/* 清理stack,只需要将top指针指向base*/
Status ClearStack(SqStack * stack)
{stack->top=stack->base;return TRUE;
}/* 判断栈是否为空 */
Status StackEmpty(SqStack stack)
{if(stack.base == stack.top)return TRUE;else return FALSE;
}/* 获取stack的长度 */
int StackLength(SqStack stack)
{return stack.top - stack.base;
}/* 获取栈顶元素,并将值传递给 e*/
Status GetTop(SqStack stack, SElemType * e)
{if(StackEmpty(stack))return FALSE;*e = *--stack.top;
}/*入栈, 将元素e压入栈中 */
Status Push(SqStack * stack,SElemType e)
{if(stack->top - stack->base >= stack->stacksize)//如果空间不够的话,扩容{stack->base =(SElemType *) realloc(stack->base,(stack->stacksize+STACKINCREMENT)* sizeof(SElemType));if(!stack->base)exit(EXIT_FAILURE);stack->stacksize += STACKINCREMENT;}*stack->top++ = e;return TRUE;
}
/*出栈, 从栈顶弹出元素,并将元素值传递给e*/
Status Pop(SqStack * stack ,SElemType * e)
{if(!stack->base)return FALSE;if(stack->base == stack->top) //空栈return FALSE;*e = *(--stack->top);return TRUE;
}/* 十进制制转换成8进制或2进制* 参数radix 进制数,如果要转换成2进制,则输入2,如果转换成8进制,则radix=8* 参数n 待转换的十进制数 */
void conversion(int radix,int n)
{SqStack stack;int elem;InitStack(&stack);while(n){Push(&stack,n%radix); // 将余数入栈n=n/radix; // 商做为被除数,进行下一个循环(只要商不为0,就继续除下去)}while(!StackEmpty(stack)){Pop(&stack ,&elem);printf("%d",elem);}printf("\n");}int main ()
{printf("将4转换为2进制:");conversion(2,4);printf("将20转换为8进制:");conversion(8,20);getchar();return 0;
}
5.3 运行结果

相关文章:
【数据结构与算法(C 语言)】栈的基本操作函数(动图演示) 及 栈的实际应用之一:进制转换
目录 1. 前言2. 结构及基本操作函数:2.1 栈的结构类型 Stack2.2 初始化栈 InitStack2.3 销毁栈 DestroyStack2.4 清空栈 ClearStack2.5 判断栈是否为空 StackEmpty2.6 获取stack的长度 StackLength2.7 获取栈顶元素 GetTop2.8 入栈 Push2.9 出栈 Pop2.10 访问元素2.…...
[原创]C++ 11的thread_local线程局部变量与Lambda表达式配合使用, 却引发致命的, 难以发现的冲突.
[简介] 常用网名: 猪头三 出生日期: 1981.XX.XX QQ联系: 643439947 个人网站: 80x86汇编小站 https://www.x86asm.org 编程生涯: 2001年~至今[共22年] 职业生涯: 20年 开发语言: C/C、80x86ASM、PHP、Perl、Objective-C、Object Pascal、C#、Python 开发工具: Visual Studio、D…...
C语言-单精度和双精度浮点型
文章目录 一、遇到的问题二、解决方案三、问题根因float和double的区别: 总结-浮点数 一、遇到的问题 将NXP项目的代码移植到RH850F1K的项目上时,程序运行异常: u16Volt (uint16)((double)u16ADVal * (double)6.3) 执行到这一行程序就跑飞了…...
STM32学习问题总结(2)—CubeMX生成项目后串口没效果和Microlib
检查完所有的硬件和软件部分,最后发现,又是Keil的设置问题,啊啊啊啊 打开Keil的魔术棒,勾选Target的Use Microlib选项即可,但这并不是最佳方案 最终解决方案: 参考:http://t.csdnimg.cn/2Tjfc…...
【数据结构与算法 | 二叉树篇】二叉树的前中后序遍历(递归版本)
1. 二叉树的概念 (1). 二叉树的结构 借用了一下力扣的模板 public class TreeNode {int val;TreeNode left;TreeNode right;TreeNode() {}TreeNode(int val) { this.val val; }TreeNode(int val, TreeNode left, TreeNode right) {this.val val;this.left left;this.righ…...
Python exp用法:深入探索指数函数的奥秘
Python exp用法:深入探索指数函数的奥秘 在Python中,exp是一个非常重要的数学函数,它属于math模块的一部分,用于计算自然数e的指数。自然数e是一个无理数,约等于2.71828,它在数学、物理和工程等领域有着广…...
[有监督学习] 8.详细图解神经网络
神经网络 一直以来,人们都认为神经网络(Neural Network,NN)是模仿生物体的神经网络设计而成的。神经网络既可以用于回归,也可以用于分类,但在实际应用中常用于分类。基于神经网络的深 度学习因在图像识别和…...
我给线程池管理框架hippo4j找bug
1 虚拟机参数不生效 hippo4j的docker启动脚本位于 docker/docker-startup.sh 。从下图可以看到 JAVA_OPT放在了jar包名 hippo4j-server.jar之后,而只有项目参数才放在jar包名之后。 实际上这里JAVA_OPT中包含虚拟机参数,而虚拟机参数要放在jar包名之前…...
win10键盘按乱了,如何恢复?
今天键盘被宝宝给按乱了,好不容易给重新调整回来,记录备忘: 1、win10的asdw和方向键互换了: 使用Fnw键来回切换,OK! 2、键盘的win键失效,例如:按winD无法显示桌面。此时…...
5.29工效学-人因工程人机交互
对于工效学这门课,一直都感觉很有意思,是一个值得再认真一点的课。可惜上课的时候效率不高,有感兴趣的东西课后也没有自行去拓展开来,前面的课我感觉还讲了比较重要的东西,但是,全忘了呢(真的对…...
头歌数据结构与算法课程设计中-硬币找零
给定n种不同面值的硬币k_i和每种硬币的数量x_i以及一个总金额k,请编写一个程序计算最少需要几枚硬币凑出这个金额k,凑出的方案是什么? 如果凑不出则输出“凑不出” 输入描述: 第一行两个正整数,n和k 然后n行每行两个数k_i和x_i 表示k_i面值的硬币有x_i个,中间以空格分隔 输…...
Golang的内存关系
1.Page Golang的Page,在操作系统对虚拟内存管理的MMU定义的物理页有相似的定义,默认的Page为8KB 2.mSpan 多个连续的Page称之为是一个Span,其定义含义有操作系统的管理的页表相似 3.Size Class Size Class: 相当于 一个等级和刻度, 比如 第二等级 就代表 一个Pag…...
VRTK4.0学习——(二)
手柄绑定以及显示 1.导入CameraRigs.UnityXRPluginFramework 和 CameraRigs.TrackedAlias 预设,将CameraRigs.UnityXRPluginFramework拖入CameraRigs.TrackedAlias的Elements中即可,运行软件后即可看到手柄了 注:如果无法看到手柄ÿ…...
体验Photoshop:无需下载,直接在浏览器编辑图片
搜索Photoshop时,映入眼帘的是PS软件下载,自学PS软件需要多长时间,学PS软件有必要报班吗...PS软件的设计功能很多,除了常见的图像处理功能外,还涉及图形、文本、视频、出版等。不管你是平面设计师,UI/UX设计…...
Codeforces Round 895 (Div. 3)(A,B,C)题解(自己VP的,没有参加这场比赛)
A. Two Vessels 题解: 这题直接计算两个杯子之间的差值,然后直接除以2倍杯子的容量直接过,没有任何难度 #include<bits/stdc.h> using namespace std;int t; int a,b,c;int main() {cin>>t;while(t--){cin>>a>>b>…...
9秒爬取庆余年2分集剧情
版本一: 要创建一个Python爬虫程序来爬取指定网站的分集剧情,我们需要使用requests库来发送HTTP请求,以及BeautifulSoup库来解析HTML内容。以下是一个简单的示例,展示了如何爬取你提供的网站的分集剧情,并将每集剧情保存到本地的.txt文件中。 首先,确保你已经安装了req…...
阿里云布置net core 项目
一、 创建镜像 给镜像添加触发器,编译的时候会触发k8s集群里的taget链接,从而更新项目 二,创建k8s集群 使用镜像创建 添加基本信息 镜像名称:镜像仓库》基本信息公网地址镜像Tag:创建镜像时的镜像版本镜像配置为:总…...
两整数之和 ---- 位运算
题目链接 题目: 分析: 题目中要求不能使用-, 考虑到我们的位运算异或^, 是无进位加法, 可以使用如果是无进位加法, 那么我们就要找到进位, 并进行计算, 进位只有1和1相加时才会产生进位1, 而0和1相加无进位, 进位为0, 那么我们就想到了&运算, 1&1 1, 0&1 0, 所…...
长城电脑压缩文件丢失了怎么办?怎么解决
在数字化时代,电脑已成为我们日常生活和工作中不可或缺的设备。长城电脑作为国内知名品牌,以其稳定可靠的性能赢得了广大用户的信赖。然而,即便是可靠的电脑,也难免会遇到一些问题。其中,压缩文件丢失无疑是一个令人头…...
论文笔记《基于深度学习模型的药物-靶标结合亲和力预测》
基于深度学习模型的药物-靶标结合亲和力预测 这是一篇二区的文章,算是一个综述,记录一下在阅读过程中遇到的问题。 文章目录 基于深度学习模型的药物-靶标结合亲和力预测前言一、蛋白质接触图谱二、为什么蛋白质图谱的准确性对DTA模型预测结果没有影响1…...
Agent+用药提醒:真正难的不是提醒,而是结合病情和依从性管理
用药提醒如果只做成定时推送,本质上接近一个带药品名称的闹钟。医疗健康应用里更棘手的问题是:用户是否按计划执行、漏服后如何记录、连续异常时是否需要升级提醒,以及这些规则如何被机构确认并可审计。本文只讨论技术架构和工程流程示例&…...
2026年盲审前论文降AI攻略:盲审提交前AIGC超标免费4.8元知网达标完整处理方案
2026年盲审前论文降AI攻略:盲审提交前AIGC超标免费4.8元知网达标完整处理方案 答辩前三天,AI率还有74%。 翻遍论坛找方法,最终用嘎嘎降AI(www.aigcleaner.com)把74%降到6.8%,4.8元,当天搞定。…...
【Perplexity心理健康资源权威指南】:20年临床IT专家亲测的5大高隐蔽性心理支持工具揭秘
更多请点击: https://codechina.net 第一章:Perplexity心理健康资源的临床价值与技术定位 Perplexity 作为一款基于大语言模型的实时信息检索与推理引擎,其在心理健康领域并非直接提供诊疗服务,而是通过增强临床决策支持、辅助心…...
CanMV K230 家用电器电流识别 预告
数据采集:家用电器电流采集 数据分析:电流波形与特征 识别方法: 硬件设置: 算法部署: 电器可能包括:手机充电器、电脑、电视、热水壶等...
生态学家都在用的R包MixSIAR:手把手教你用贝叶斯模型搞定食物网溯源
生态数据分析实战:用MixSIAR实现贝叶斯食物网溯源 河口湿地的鱼类究竟以藻类还是陆源有机物为主要食物?这个看似简单的问题背后,隐藏着复杂的生态关系网络。传统稳定同位素分析方法虽然能提供部分答案,但当面对多个潜在食物源和不…...
OpenPLC Editor:零成本开启工业自动化编程的完整解决方案
OpenPLC Editor:零成本开启工业自动化编程的完整解决方案 【免费下载链接】OpenPLC_Editor 项目地址: https://gitcode.com/gh_mirrors/ope/OpenPLC_Editor 在工业自动化领域,PLC编程一直被视为专业工程师的专属技能,高昂的商业软件许…...
前端开发从入门到精通:Vue3+TypeScript实战教程
一、为什么软件测试从业者要学Vue3TypeScript在软件测试领域,尤其是自动化测试和性能测试方向,懂前端开发技术早已不是加分项,而是必备技能。作为测试从业者,掌握Vue3TypeScript能为你的职业发展带来多重优势:…...
慢时钟域到快时钟域控制信号传递:原理、方案与实战
1. 控制信号跨时钟域传递:一个资深工程师的实战拆解在数字电路设计里,尤其是涉及多时钟域的复杂系统,比如SoC、高速接口或者异构计算单元,控制信号的跨时钟域传递(CDC, Clock Domain Crossing)绝…...
嵌入式网络开发避坑:LwIP软件定时器溢出处理与链表排序的实战细节
嵌入式网络开发避坑:LwIP软件定时器溢出处理与链表排序的实战细节 在嵌入式网络开发中,LwIP协议栈因其轻量级和高度可裁剪性成为众多开发者的首选。然而,在实际应用中,软件定时器的溢出处理和链表排序逻辑往往是引发隐蔽问题的重灾…...
TensorFlow GPU内存分配失败怎么办?教你一招避坑
💓 博客主页:瑕疵的CSDN主页 📝 Gitee主页:瑕疵的gitee主页 ⏩ 文章专栏:《热点资讯》 TensorFlow GPU内存分配失败的终极解决方案:一招避坑指南 目录 TensorFlow GPU内存分配失败的终极解决方案࿱…...
