数组实现简单的栈操作

前言

单片机开发过程中,常常会用到栈操作,例如多级菜单的页面跳转,这里分享一个自己C语言写的非常简单的栈操作文件供各位参考。

源代码

#include "bsp_user_stk.h"

uint8_t stack[STACK_SIZE];
__IO static int top_element = -1;	//指向栈顶元素的指针

void push(uint8_t val)
{
	if(is_full() == 0){
		top_element++;
		stack[top_element] = val;
	}
}

uint8_t pop(void)
{
	if(is_empty() == 0){
		return stack[top_element--];//页面ID
	}
	else
		return 19;
}

uint8_t is_empty(void)
{
	if(top_element == -1){
		return 1;
	}
	else
		return 0;
}

uint8_t is_full(void)
{
	if(top_element == STACK_SIZE - 1){
		return 1;
	}
	else
		return 0;
}




总结

这样就使用一个固定数组实现了栈操作,可以直接用在工程中。

猜你喜欢

转载自blog.csdn.net/SammySum/article/details/107676104