“软件工程(C编码实践篇)”实验报告(四)

实验思路以及过程

根据老师的演示,修改自己上次实验的代码。完成链表link table模块,并通过三层架构的方式完成实验。

三层架构

  1. 用户层 (包括 menu.c文件)

  2. 业务逻辑层 (包括 business_logic_layer.h,business_logic_layer.c 文件)

  3. 数据访问层 (包括 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;
    }
}
   实验代码

转载于:https://my.oschina.net/doumenghan/blog/631045

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值