linux程序设计——CD唱片应用程序(第七章)

7.4 CD唱片应用程序

这篇为第七章的CD唱片应用程序,代码在CD唱片应用程序代码下载。我们使用dbm数据库对数据存储,改进之前的CD唱片应用程序。

7.4.1 更新设计

虽然在文件中以逗号分隔变量来存储信息是一种在shell中很容易实现的方式,但是这样局限性很大,因为许多CD标题和曲目都包含逗号。可以通过使用dbm数据库来改进这种方法。
将CD资料分为标题和曲目两个部分,并用不同的文件来保存它们。
前面的实现存在一个问题,即将应用程序的数据访问部分和用户接口部分混在了一起,这与程序全实现在一个文件中有很大关系。在这个新的实现中,将用一个头文件来描述数据和用于访问它的例程,并将用户接口代码和数据处理代码分别放到两个文件中去。
虽然不能在dbm代码中使用SQL语句,但可以使用SQL术语以更正规的方式来描述新数据库。表可以用下面的代码来描述:
CREATE TABLE cdc_entry(
    catalog CHAR(30) PRIMARY KEY REFERENCES cdt_entry(catalog),
    title CHAR(70),
    type CHAR(30),
    artist CHAR(70)
);
CREATE TABLE cdt_entry(
    catalog CHAR(30) REFERENCES cdc_entry(catalog),
    track_no INTEGER,
    track_txt CHAR(70),
    PRIMARY KEY(catalog, track_no)
);
cdc_entry表中每个记录都有一个唯一的catalog列。cdt_entry表中曲目号不能为0,而且catalog和trach_no两列的组合是唯一的。

7.4.2 使用dbm数据库的CD唱片应用程序

通过使用dbm数据库存储信息的方法来重新实现应用程序。整个应用程序共有3个文件,它们是cd_data.h、app_ui.c和cd_access.c
将用户接口重写为命令行程序,本书的后面章节,使用不同的客户/服务器机制来实现应用程序,并最终将其实现为一个能够通过Web浏览器跨网络访问的应用程序。把接口转换为简单的命令行驱动接口,这样能更容易关注应用程序最重要的部分,而不是用户接口。
编写cd_data.h定义了数据的结构和用于访问这些数据的例程。
编写app_ui.c用户接口,它实现在一个单独的文件中,用它来访问数据库函数
编写cd_access.c
最后通过下面的makefile文件把所有的程序结合起来,敲入它的内容保存为Makefile文件:
all: application
INCLUDE=/usr/include/gdbm
LIBS=gdbm
#On some distributions you may need to change the above line to include the compatability library, as show belown.
#LIBS= -lgdbm_compat -lgdbm
CFLAGS=
app_ui.o: app_ui.c cd_data.h
    gcc $(CFLAGS) -c app_ui.c

access.o: access.c cd_data.h
    gcc $(CFLAGS) -I$(INCLUDE) -c access.c

application: app_ui.o access.o
    gcc $(CFLAGS) -o application app_ui.o access.o -l$(LIBS)

clean:
    rm 0f application *.o

nodbmfiles:
    rm -f *.dir *.pag
输入make,如果顺利可执行文件application将被编译并放置到当前目录中。

7.5 小结

这部分,首先学习linux内存系统的只是,虽然按需换页虚拟内存的内部实现非常复杂,但它的使用非常简单。学习它是如何保护操作系统和其他进程免受非法内存访问的侵害。
其次,这章介绍文件锁定功能是如何允许多个程序在访问数据时协调工作的。首先是简单的二进制信号量机制,然后是共享锁和独占锁来锁住同一个文件的不同部分。
然后文章介绍了dbm数据库,它具有使用一个非常灵活的索引布局来存储和高效地检索任意数据块的能力。
最后用dbm数据库为数据存储技术重新设计并实现了CD唱片应用程序。

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。