实验思路以及过程
根据老师的演示,修改自己上次实验的代码。完成链表link table模块,并通过三层架构的方式完成实验。
三层架构
用户层 (包括 menu.c文件)
业务逻辑层 (包括 business_logic_layer.h,business_logic_layer.c 文件)
数据访问层 (包括 link_table.h link_table.c link_list.h link_list.c 文件)
使用时要注意的使用规则是只能是下层向上层提供服务,不能下层访问上层,而且不能隔层访问。
static的使用
static 加在函数声明前时,表示此函数是内部函数,其他文件不能调用该函数,可以用来隐藏函数。
实验总结
通过这次实验降低了客户端程序与命令行小程序的耦合度,使得客户端程序仅仅只需要调用两个命令行小程序暴露的接口就可以直接使用命令行小程序,同时不需要对命令行小程序进行修改,初步实现了命令行小程序的可重用性,
链表模块设计
link_table.h
#ifndef _LINK_TABLE_H
#define _LINK_TABLE_H
#define FAIL -1
#define SUCCESS 0
typedef struct link_table_node
{
struct link_table_node *p_next;
}linkTableNode;
typedef struct link_table
{
linkTableNode *p_head;
linkTableNode *p_end; int len;
}linkTable;
linkTable *create_link_table();
int del_link_table(linkTable *p_link);
int add_link_node(linkTable *p_link,linkTableNode *p);
int del_link_node(linkTable *p_link,linkTableNode *p);
linkTableNode get_link_head(linkTable *p_link);
linkTableNode get_link_end(linkTable *p_link);
linkTableNode get_next_node(linkTable *p_link,linkTableNode *p);
#endif
link_table.c
#include "link_table.h"
#include <stdio.h>
#include <stdlib.h>
linkTable *create_link_table()
{
linkTable *p_link=(linkTable*)malloc(sizeof(linkTable*));
if(p_link==NULL)
{
return NULL;
}
p_link->p_head=NULL;
p_link->p_end=NULL;
p_link->len=0;
return p_link;
}
int del_link_table(linkTable *p_link)
{
if(p_link==NULL)
{
return FAIL;
}
while(p_link->p_head!=NULL)
{
linkTableNode *p=p_link->p_head;
p_link->p_head=p_link->p_head->p_next;
free(p);
p_link->len-=1;
}
p_link->p_head=NULL;
p_link->p_end=NULL;
free(p_link);
return SUCCESS;
}
int add_link_node(linkTable *p_link,linkTableNode *p )
{
if(p_link==NULL||p==NULL)
{
return FAIL;
}
p->p_next=NULL;
if(p_link->p_head==NULL)
{
p_link->p_head=p;
}
if(p_link->p_end==NULL)
{
p_link->p_end=p;
}
else
{
p_link->p_end->p_next=p;
p_link->p_end=p;
}
p_link->len+=1;
return SUCCESS;
}
int del_link_node(linkTable *p_link,linkTableNode *p)
{
if(p_link==NULL||p==NULL)
{
return FAIL;
}
}
实验代码