文档库 最新最全的文档下载
当前位置:文档库 › linux编程大作业

linux编程大作业

linux编程大作业
linux编程大作业

第一部分简述题目

要求:这部分题目必做,要详细回答,最好用自己理解的语言回答,有些题目可用图形和举例等阐述问题。

1、makefile文件的作用是什么,makefile文件中有一种变量,其值是根据具体的规则来确定的,称为自动变量,其中代表所有依赖文件列表的是哪个;举例说明make命令的工作流程。

答:在Makefile文件中描述了整个工程所有文件的编译顺序、编译规则。其中包括:工程中的哪些源文件需要编译以及如何编译、需要创建那些库文件以及如何创建这些库文件、如何最后产生我们想要的可执行文件。Makefile 有自己的书写格式、关键字、函数。在Makefile 中可以使用系统shell所提供的任何命令来完成想要的工作。能够使用一行命令来完成“自动化编译”。

自动变量$^代表所有依赖文件,以空格分开,以出现的先后为序。

2、什么是进程,用fork()创建一个子进程时,系统会做什么工作。请编程说明。

答:进程是具有独立功能的程序关于某个数据集合上的一次运行活动,是系统进行资源分配的单位,不仅是系统内部独立运行的实体也是独立竞争资源的实体。

用fork()时系统会分配子进程一个ID号然后继承父进程的地址空间,包括进程上下文进程堆栈打开的文件描述符等等,他就是父进程的一个复制品。

3、简述Linux文件系统通过i节点把文件的逻辑结构和物理结构转换的工作过程。解释i节点在文件系统中的作用。

答:文件系统建立在由若干连续的逻辑块构成的存储空间中,根据用途逻辑块可分为:超级块、i节点区和数据区。其中i节点区用于存放i节点,每个文件都

有各自唯一的i节点,i 节点是一个64字节长的表,表中包含了文件的相关信息,其中有文件的大小、文件所有者、文件的存取许可方式以及文件的类型等重要信息。在i节点表中最重要的内容是磁盘地址表。在磁盘地址表中有13个块号,文件将以块号在磁盘地址表中出现的顺序依次读取相应的块。Linux文件系统通过把i节点和文件名进行连接,当需要读取该文件时,文件系统在当前目录表中查找该文件名对应的项,由此得到该文件相对应的i节点号,通过该i 节点的磁盘地址表把分散存放的文件物理块连接成文件的逻辑结构。

4、文件指针FILE*与文件描述符是一个什么样的关系,请画图说明。

答:在linux系统中,一个文件可以被多个线程共享,每个进程在内核中用task_struct结构表示,其中有一个称为文件描述符表的fd,文件描述符表fd,是一个指针数组,每个指针指向一个file结构,用于记录一个打开文件的状态信息,其中f_pos记录打开文件的当前读写位置,f_dentry打开文件所在目录,f_op文件具体的操作集,打开文件就会获得文件描述符,它是个很小的正整数。每个进程在PCB(Process Control Block)中保存着一份文件描述符表,文件描述符就是这个表的索引,每个表项都有一个指向已打开文件的指针。

5、简述与windows的文件系统相比,linux文件系统有什么特点,并用图详细描述。

答:Linux的每个目录都可能是一个分区,在安装Linux时至少有两个分区,根分区和swap分区,其它的分区都安装在根下面。如将一个分区安装在/var下面,每个分区安装的位置成为“挂载点”,如挂载点/var。swaP分区大小是内存的2倍,等价于Windows的虚拟内存。根分区文件类型一般选择为ext3,swap 分区类型即为swap。Linux中文件和目录都区分大小写,如home和Home不是一个目录。Linux把文件的i-nod信息全都交给了目录管理。包括文件存不存在、文件名是什么、文件存放在磁盘哪里等信息。只要有这个目录的写权限,就可以

删除目录下的任意文件(注:这里的文件不包括目录)和更改目录下的任意文件的文件名(注:包括目录)。特别的,对于目录,如果这个目录只是一个空目录的话,就相当于一个文件,完全可以删除。但是因为Linux不能删除一个非空的目录。Linux中有一些重要的系统目录,它们都有特定的用途。Linux文件系统建立在由若干连续的逻辑块构成的存储空间中,根据用途逻辑块可分为:超级块、i节点区和数据区。

6、Linux创始人是谁,Linux操作系统的诞生、发展和成长过程始终依赖着的重要支柱有哪些,并描述Linux的特点。

答:linux的创始人是芬兰赫尔辛基大学生Linus Torvalds。Linux操作系统的诞生、发展和成长过程始终依赖着的重要支柱有:(1)UNIX操作系统、(2)MINIX 系统、(3)GUN计划、0(4)POSIX标准、(5)Internet网络。

Linux的特点:

1.模块化程度高

2.源代码公开

3.广泛的硬件支持

4.安全性及可靠性好

5.具有优秀的开发工具

6.有很好的网络支持和文件系统支持

7.与UNIX完全兼容

7、为什么要学习Linux开源技术。

答:因为Linux具有可靠的系统安全,而且开源最安全:

(1)、基于Linux操作系统的文件系统安全可靠,即限定操作系统存储物理空间,并使其不可被改写。将操作系统安装在相对独立的物理空间中,同时将安装操作系统的物理存储介质限定为只读方式,使所安装的操作系统在物理层上就不可被改写,达到安全可靠;同时将用户空间在物理上与系统空间相互隔绝,当用户需要安装软件或保存各种文档时,可以透明地存储在该空间中。

(2)、用户/文件权限的划分

用户权限在Windows操作系统里也不陌生,但是Linux操作系统的用户权限和文件权限要比Windows操作系统里严格有效。比较明显的一个案例就是,即便在Windows操作系统里设置了多用户,但是不同的用户之间通过一定的方式,还是能够互访文件的,这就失去了权限的意义。而LinuX可以对每一个文件进行授权,用户只能对自己有权限的文件进行权限范围内的操作,而且在实际使用中,root用户一般只在对系统进行维护时,如添加新用户,安装应用程序等才进行登录,一般都是以普通用户身份登录,普通用户不能修改系统文件夹下的文件,因此Linux下病毒软件想修改系统程序,根本没有可能性,大大增加了系统的安全性和可靠性。

8、Linux的主要组成包括什么。

答:Linux的主要组成包括:Linux内核、shell命令解释器、管理工具、图形用户界面。

9、什么是系统调用?系统调用是通过什么方式陷入内核态的?请写出你对系统调用的理解。什么是文件I/O和标准I/O库?文件I/O和标准I/O库的区别?

答:系统调用是指操作系统提供给用户程序调用的一组特殊接口,用户程序可以通过这组接口获得操作系统内核提供的服务。

系统调用是通过软件中断方式陷入内核的。

linux的文件I/O是由操作系统提供的基本IO服务, 标准I/O库通过封装系统调用,提供了一个到底层I/O的接口。

标准I/O默认采用了缓冲机制,还创建了一个包含文件和缓冲区相关数据的数据结构;文件I/O一般没有采用缓冲模式,需要自己创建缓冲区。一种是标准库封装系统调用而成,更高级,一种是系统提供的,比较低级;标准I/O 可移植性高、文件I/O可移植性低。

10、如何学习《Linux系统编程》这门课程,谈谈自己的感受。第二程序设计题目

要求:

●Shell程序设计部分、文件和目录部分、进程和信号部分、

网络编程部分则必做(其中前3部分选作5道题目,网络编程为自学部分,选作2道题目)。

●若做综合设计题目或自拟综合设计题目,则Shell程序设

计部分、文件和目录部分、进程和信号部分、网络编程部分可不做。

Shell程序设计部分

1、设计shell脚本程序,运行结果如下:

- - - - - - - - - - - - - - - -

Linux 13/06/11

- - - - - - - - - - - - - - - -

A: 查看进程信息

B:查看用户信息

C:显示当前目录信息

D:退出

- - - - - - - - - - - - - - -

当用户输入相应的数字执行相应的功能。

2、设计shell脚本程序,在屏幕上输出操作系统的信息,包括计算机名、Linux分发版本名称、Linux内核版本和当前的IP地址。

3、设计shell脚本程序,要求用户对/home目录下的文件进行备份,压缩为Linux系统中常用的tar.gz格式。

4、设计shell脚本程序,假设用户建立了目录A和目录B,目录中不包含子目录,要求用户编写一个脚本程序,比较两个目录内文件的差异。

5、设计一个shell程序,添加一个新组为class1,然后添加属于这个组的30个用户,用户名的形式为stdxx,其中xx从01到30。

6、设计一个shell程序计算n的阶乘。要求:

(1)从命令行接收参数n;

(2)在程序开始后立即判断n的合法性,即是否有参数,若有是否为正整数,若非法请给错误提示;

(3)最后输出计算的结果。

7、设计一个shell程序,在每月第一天备

份并压缩/etc目录的所有内容,存放在/root/bak目录里,且文件名为如下形式yymmdd_etc,yy为年,mm为月,dd为日。

8、判断当前工作目录下所有的文件类型,如果是目录显示目录名,如果是文件查看文件内容,如果都不是,显示提示信息。文件和目录部分

1、编写程序,打开一个文本文件

(1)读取其中内容,将其复制到一个新建文件中;

(2)将文本文件截断至原来长度的1/2;

(3)将文件中的小写字母转换成为大写字母,其他字符不变。

2、编写程序,读取当前目录下的内容,并将其打印输出到终端。

3、编写程序,在/tmp目录下面建立一个test目录,然后在test

目录下建立一个空文件hello.txt,注意函数出错处理。

4、编写程序实现一个简单的员工档案管理系统,具备简单的员工资料增加、删除和查询等功能,并采用二进制文件保存员工的资料信息。

5、为了便于文件的管理和传输,某些时候需要将特别大的文件切割为多个指定长度小的文件。现有一个文件管理程序需要实现大文件切割功能,要求用户编写一个函数实现该功能。

6、编写程序,根据输入的参数创建一个目录文件。

7、编写程序,首先输出当前的工作目录,然后更改工作目录,输出更改后的工作目录。

vi

8、编写程序,编写shell命令中的ls命令。

9、编写程序,编写shell命令中的pwd命令。

10、编写程序,编写shell命令中的cp命令。

11、编写Shell命令中的cat命令。

12、编写Shell命令中的tail命令。(用缓冲技术来提高效率)

13、编写Shell命令中的ls -i命令。

进程和信号部分

1、编写程序,获取并输出子进程和父进程的相关信息。

2、编写程序,要求用户设计多进程应用程序,改程序作为父进程执行,在执行过程中能够通过调用自身创建一个子进程。父进程和子进程均在终端中输出一条信息,标识自己的身份。

3、守护进程是运行于系统后台的进程,常用于提供各种系统服务和系统日志管理功能。现要求用户编写一个守护进程应用程序,定时向日志文件写入字符串。

4、编写程序,在不同的进程间实现信号发送和接收,同时在传达过程中附加其他信息。

5、编写程序,使用alarm函数在系统中设置一个定时器,期间对整数进行递减操作,并输出到屏幕。

6、现有一个应用程序在死循环中执行,要求用户让程序能够带捕捉用户按下的组合键Ctrl+C,终止应用程序的执行。

7、Linux系统提供了alarm( )和setitimer( )系统调用作为定时器的功能,要求用户使用这两个函数设计程序,让程序每隔一秒发出一个SIGALRM信号,每隔0.5秒发出一个SIGVTALRM信号。

8、编写程序,在主进程中创建一个子进程,子进程进行空循环,不停地输出“hello world!”字符串,主进程休眠一段时间后,

在主进程中结束子进程,随后主进程也退出。

9、编写程序,在程序中使用命令行形式显示程序所在当前文件

夹下的内容。

10、编写程序,得到当前进程的标识号,并将它打印输出,随后写入一个文件中。

11、在Linux系统下使用execl( )函数代替一个hello.c文件,在hello.c文件中实现从1到100的累加计算。

网络编程部分

1、在Linux系统下,通过TCP协议的套接字编程,在服务器端的计算机上实现累加求和的计算,数据全部从客户端传送,然后

在服务器端计算的和输出到终端,并传送回客户端。

2、在Linux系统下,实现IP地址转换,将名字地址转换为数字地址。

3、利用read函数编写读取客户端数据(提示在程序中,首先监听一个端口,如果有客户端连接这个端口则接受这个连接,然后用read函数读取远程主机发送的数据,输出这些数据以后结束这个程序)。

4、编程实现一个面向连接的套接字服务程序和客户端程序。客户端打开一个文件,把文件内容传送给服务器端,服务器端接受到文件内容后,保存在/tmp目录下。

选做题目:综合设计题目

1、实现一个飞机票网络售票系统的模拟程序。

2、实现一个银行代理收费服务器。

3、在linux下实现聊天室。

4、编写命令解释器sh

Linux课程大作业

Linux课程设计报告 题目 Linux课程大作业 院系 班级 姓名 指导教师 一、基础篇(给出源程序和编译运行的结果)

1、编写一个简单的c语言程序:根据输入的两个整数求平均值并且在终端输出,通过gcc编译器得到它的汇编程序文件。 源代码(c): 源代码(汇编): .file "sum.c" .text .globl average .type average, @function average: .LFB0: .cfi_startproc pushl %ebp .cfi_def_cfa_offset 8 .cfi_offset 5, -8 movl %esp, %ebp .cfi_def_cfa_register 5 subl $8, %esp movl 12(%ebp), %eax movl 8(%ebp), %edx

addl %edx, %eax movl %eax, -4(%ebp) fildl -4(%ebp) fldl .LC0 fdivrp %st, %st(1) leave .cfi_restore 5 .cfi_def_cfa 4, 4 ret .cfi_endproc .LFE0: .size average, .-average .section .rodata .align 4 .LC2: .string "\350\257\267\350\276\223\345\205\245\344\270\244\344\270\252\346\225\260\ 357\274\214\345\233\236\350\275\246\345\210\206\345\211\262" .LC3: .string "%d" .LC4: .string "%d\344\270\216%d\347\232\204\345\271\263\345\235\207\345\200\274\346\23 0\257\357\274\232%lf\n" .text .globl main .type main, @function main: .LFB1: .cfi_startproc pushl %ebp

Linux期末大作业

简单的IRC聊天程序 —— Linux课程期末实验 第一章概述 【实验目的】 综合应用Linux系统下的网络编程技术,使用C语言,结合软件工程思想,设计并实现一个简单的IRC聊天程序,具有服务器端和客户端,可以是终端字符界面,支持用户管理,用户名/密码注册和登录,支持版面聊天,用户可以选择进入某个版面,版面发言大家可以看到,同时支持点对点私聊,可以选择某个用户进行私聊。从而熟悉在Linux系统所提供的网络通信接口及该系统下的编程思想,深入对计算机系统的理解,并切实提高软件设计开发的能力。 【实验原理】 一个简单的聊天室,其功能是当这个聊天室中的任何一个用户输入一段字符后,室内的其他用户都可以看到这句话。据此,聊天程序分为客户端和服务器端。客户端对应每一个参加聊天的用户,完成从终端上输入采集并传递到服务器端和从服务器端接收信息输出显示的功能。 总体介绍该结构如下。 首先是初始化服务器,使服务器进入监听状态: sockfd = socket(AF_INET, SOCK_STREAM, 0); // 首先建立一个socket,族为AF_INET,类型为SOCK_STREAM。 // AF_INET = ARPA Internet protocols,即使用TCP/IP协议族。 // SOCK_STREAM类型提供了顺序的,可靠的,基于字节流的全双工连接。 // 由于该协议族中只有一个协议,因此第三个参数为0。 bind(sockfd, (struct sockaddr *)&servaddr, sizeof(serv_addr)); // 再将这个socket与某个地址进行绑定。

linux网络操作系统大作业

1.搭建一个简单的apache+mysql+php组合:点击红帽子—>系统设置-->服务器设置 服务勾上httpd然后点开始之后保存,如图: 在浏览器测试如图:

打开文件夹file:/var/www/html 在其中建一个about.php的文件,代码如下: 打开浏览器测试如图: 点击红帽子—>系统设置-->服务器设置 服务勾上mysqld然后点开始之后保存,然后在终端输入如图所示代码,给MYSQL设定密码,如图:

2.根据题目要求需要数据库中建立学生个人信息(学号、性别、年龄),所修课成,所在院系三个表,不是独立的。所以我建了一个名为php的数据库以及名为register(用户),student(学生),faculty(学院),course(课程)的数据表,代码如下: CREATE TABLE IF NOT EXISTS student ( name varchar(30) NOT NULL, id int(30) NOT NULL, class char(30) NOT NULL, sex varchar(30) NOT NULL, age int(20) NOT NULL ); CREATE TABLE IF NOT EXISTS register ( username char(25) NOT NULL, password int(20) NOT NULL ); INSERT INTO register VALUES('admin','111111'); CREATE TABLE IF NOT EXISTS course ( id int(30) NOT NULL, classname char(30) NOT NULL, classid int(20) NOT NULL, teacher varchar(30) NOT NULL, socre int(10) NOT NULL ); CREATE TABLE IF NOT EXISTS faculty ( id int(30) NOT NULL, name char(30) NOT NULL, academical char(30) NOT NULL ); 建数据库及数据表如图:

linux大作业

仲恺农业工程学院Linux课程大作业报告 院(系):信息科学与技术学院 专业班级:计算机 学号: 姓名:

目录 1 简述题目 (1) 2 shell程序设计 (5) 2.1 程序设计要求 (5) 2.2 程序设计内容 (5) 1 (5) 2 (10) 3 (11) 5 (13) 6 (16) 3 文件和目录部分 (17) 3.1 程序设计要求 (17) 3.2 程序设计内容 (17) 2 (17) 3 (17) 6 (18) 8 (19) 9 (19) 4 进程和信号部分 (20) 4.1 程序设计要求 (20) 4.2 程序设计内容 (20) 1 (20) 2 (21) 8 (22) 9 (23) 10 (24) 5 网络编程部分 (25) 5.1 程序设计要求 (25) 5.2 程序设计内容 (25) 2 (25) 3 (26)

1 简述题目 1、makefile文件的作用是什么,makefile文件中有一种变量,其值是根据具体的规则来确定的,称为自动变量,其中代表所有依赖文件列表的是哪个;举例说明make命令的工作流程。 答:(1)makefile的作用就是使得源文件修改的时候,能很快地自动编译和链接所有修改过的文件。Make工具可将编译和链接的步骤按一定的规则写入文本文件。(2)是指冒号后面的那一列(3)举例:现在有lib.h,lib.c,mod.c,app.h,app.c,main.c文件,编译链接成main.o 程序示例: #script5-2_makefile Appexam:main.o app.o mod.o lib.o gcc –o apexam main.o app.o mod.o lib.o main.o:main.c app.h gcc –c main.c app.o:app.c app.h gcc –c app.c mod.o:mod.c gcc –c mod.c lib.o:lib.c lib.h gcc –c lib.c clean: rm –f *.o 2、什么是进程,用fork()创建一个子进程时,系统会做什么工作。请编程说明。答:进程是具有一定独立功能的程序关于某个数据集合上的一次运行活动,进程是系统进行资源分配和调度的一个独立单位。在linux系统中,每个进程都有各自的生命周期。在一个进程的生命周期中,都有各自的运行环境以及所需的资源。一个进程程可以由多个线程组成,线程独自拥有的资源很小,但是系统运行的最小单位。 当通过fork函数创建心得子进程时,内核将父进程的用户地址空间的内容复制给子进程,这样父子进程之间拥有各自的用户空间,当父进程修改变量的值时不会影响子进程中的相应变量。但为了提高效率,Linux采用了COW(Copy on Write)算法,子进程创建时,父子进程享有相同的地址空间只是在页表中设置COW标志,只有在父进程或子进程执行写数据操作时,才为子进程申请一个物理页,将父进程空间中相应数据所在页的内容复制到该物理页,然后将该页映射至子进程用户地址空间的适当位置。此外,子进程还继承父进程的其他资源。 举例说明: #include intglob=10; int main(void) { int local;

linux大作业

2014 —2015 学年第二学期《Linux网络操作系统》大作业题目:浅谈 Linux 新技术及其发展 专业:计算机科学与技术 班级:12级计算机1班 学号: 120400301 姓名:郭芳瑜 教师:李桐 日期:2015 年05 月10 日

一.linux的发展历程 Linux 是一种自由和开放源码的类 Unix 操作系统.目前存在着许多不同的 Linux,但其都使用了 Linux 内核. Linux 可安装在各种计算机硬件设备中,从手机、平板电脑、路由器和视频游戏控制台,到台式计算机、大型机和超级计算机. Linux 是一个领先的操作系统,世界上运算速度最快的计算机运行的都是 Linux 操作系统。 Linux 操作系统的诞生、发展和成长过程始终依赖着以下 5 大支柱: UNIX 操作系统、MINIX 操作系统、GNU 计划、POSIX 标准和 Internet 网络. Unix 操作系统是美国 AT&T 的贝尔实验室的 Ken. Thompson,Dennis Ritchie 和 Douglas Mcllroy 于 1969年夏在 DEC PPP - 7 小型计算机上开发的一个分时操作系统. 1971 年 Ken. Thompson 和 Dennis Ritchie 成功地用 C 语言重写了 Unix 内核. 1974 年,Unix 以“仅用于教育目的”的协议,提供给大学作为教学之用,成为当时操作系统课程中的范例教材.各大学、公司开始通过 Unix 源码对Unix 进行了各种各样的改进和扩展,于是,Unix 开始广泛流行.后来,AT&T 公司开始注意到 Unix 带来的商业价值,公司的律师开始寻找一些手段来保护 Unix,并让其成为一种商业机密.从 1979 年 Unix 的版本 V7 开始,Unix 的许可证开始禁止大学使用 Unix 的源码,包括在授课中学习. MINIX 系统是由美藉荷兰侨民 Andrew. S. Tanenbaum( AST) 于 1987 年开发的,源于 Unix 源码被禁止使用,开发该系统主要用于学生学习操作系统原理. MINIX 的名称取自英语 Mini Unix,是一个迷你版本的类 Unix 操作系统,它是重新发展的,并没有使用任何的 AT&T 的程序码,到 1991 年时版本是 1. 5,当时该操作系统在大学使用是免费的,但其它用途不是,当然目前都已经是免费的. GNU 是“GNU’s Not Unix”的递归缩写,是一个名叫 Richard Stallman 认为 Unix 是一个相当好的操作系统,如果大家都能将自已所学贡献出来,那么,这个系统将会更加优异.他倡导的 Open Source 的概念,就是针对 Unix 这一事实,反对实验室里的产品商业化、私有化.实现一个仿 Unix 操作系统成了他追求的明确战略目标.为了这个理想,Richard Stallman 于 1984 年创立了 GNU,计划开发一套与 Unix 相互兼容的软件. 1985年,他又创立了自由软件基金会( Free Software Foundation) 来为 GNU 计划提供技术、法律以及财政支持.自发起这个计划以来,GNU 开始大量的产生或收集各种系统所必备的组件,例如: 函数库、编译器、调试工具、文本编辑器、网站服务器,以及一个 Unix 的使用接口( Unix Shell) 等,但由于种种原因,GNU 一直没有开发操作系统的 Kernel. POSIX 表示可移植操作系统接口( Portable Operating System Interface) ,电气与电子工程师协会( Institute of Electrical and Electronics Engineers,IEEE) 最初开发 POSIX 标准,是为了提高Unix 环境下应用程序的可移植性.然而,POSIX 并不局限于 Unix,许多其它操作系统,例如,DEC Open VMS 和 Microsoft Windows NT 都支持 POSIX 标准现在它已经发展成为一个非常庞大的标准族.1991 年,芬兰赫尔辛基大学的一名学生 Linus Torvalds,他主修的课程中有一门课是操作系统,专门研究程序设计和执行,并且本课程采用 MINIX 做为实验系统. Linus 不满足于该系统的功能,就希望能给其添加一些功能.于是,他就根据实际的需要编写了磁盘驱动程序以便下载访问新闻组的文件,又编写了文件系统以便能够阅读 MINIX 文件系统中的文件,这就是 0. 0. 1 版本的 Linux.Linus 从一开始就决定自由传播 Linux,他把源代码发布在网上,于是,众多的爱好者和程序员也都通过互联网加入到 Linux 的内核开发工作中.这个思想与 FSF 资助发起的 GNU 的自由软件精神不谋而合. GNU 是为了推广自由软件的精神以实现一个自由的操作系统,然后从应用程序开始,实现其内核.而当时 Linux 的优良性能备受 GNU 的赏识,于是,GNU 就决定采用 Linus 及其开发的内核.在他们共同努力下, Linux 这个完整的操作系统诞生了.其中的程序开发共同遵守 General Public License( GPL) 协议和POSIX 标准,规定了源码必须可以无偿地获取并且修改. 二.Linux技术热点和发展趋势 自九十年代初 L i n u x 出现以后,Linux技术首先在个人爱好者的圈子里迅速发展起来;此后,随着Internet的迅猛发展,以及在RedHat、Suse等主要Linux发行商的努力和 IBM、英特尔等的大力支持下,Linux在服务器端得到了长足的发展,在中、低端服务器市场中已经成为Unix 和 Windows NT的有力的竞争对手在高端应用的某些方面,如SMP、Cluster集群等,已经动摇了传统高级 Unix 的统治地位。近两年,由于政府上网工程、电子政务、电子商务等的不断发展,Linux桌面技术也越来越受到用户和厂家的重视。特别是在国内,中标软件、红旗等相继推出了多款Linux桌面产品,在政府采购、OEM 等领域占据了重要市场,Linux桌面技术也得到了长足的发展。目前,Linux技术已经成为IT技术发展的热点,投身于Linux技术研究的社区、研究机构和软件企业越来越多,支持Linux 的软件、硬件制造商和解决方案提供商也迅速增加,Linux在信息化建设中的应用范围也越来越广,Linux产业链已初步形成,并正在得到持续的完善。随着整个 Linux 产业的发展,Linux技术也处在快速的发展过程中,形成了若干了技术热点。下面,分别就 Linux 桌面技术和Linux服务器技术介绍最新的Linux发展动态和未来的发展趋势。

linux大作业

武汉轻工大学 数学与计算机学院 2019-2020学年第一学期 Linux大作业 指导老师: ** 专业:信息管理与信息系统 班级:信管1601班 学号: *********** 姓名: ** 2019年10月29 日

历史 1991年,还在芬兰赫尔辛基大学上学的Linus Torvalds在自己的Intel 386计算机上开发了属于他自己的第一个程序,并利用Internet发布了他开发的源代码,将其命名为Linux,从而创建了Linux操作系统,并在同年公开了Linux的代码,从而开启了一个伟大的时代。在之后的将近30年的时间里,越来越多的工程师投入到Linux,帮助不断完善Linux的功能。现在的Linux系统架构凭借优秀的分层和模块化的设计,融合了大量的设备和不同的物理架构。 这篇文章,也是对Linux系统的一个非常简单的介绍,主要讲解Linux的进程调度、内存管理、设备驱动、文件系统、网络模块。 Linux内核架构图 上图就是Linux内核的架构图,从硬件层--->操作系统内核--->应用层,这套系统架构的设计应用于各类软硬件结合的系统上,比如物联网系统,单片机系统、机器人等领域。 进程调度 进程在Linux系统中称为process或task。操作系统中进程的数据结构包含很多元素,诸如:地址空间、进程优先级、进程状态、信号量、占用的文件等,往往用链表链接。CPU在每个系统滴答(Tick)中断产生的时候检查就绪队列里边的进程(遍历链表中的进程结构体),如有符合调度算法的新进程需要切换,保存当前运行的进程的信息(包括栈、地址等)后挂起当前进程,然后运行新的进程,这就是进程调度。 CPU调度的基本依据是进程的优先级。调度的终极目标是让高优先级的进程能及时得到CPU的资源,低优先级的任务也能公平的分配到CPU资源。不过因为保存当前进程的信息所以进程的切换本身是有成本的,调度算法同样需要考虑效率。 在早期Linux内核中,就是采用轮询算法来实现的,内核在就绪的进程队列中选择高优先级的进程执行,每次运行相等时间,该算法简单直观,但仍然会导致一些低优先级的进程长时间不能执行。为了提高调度的公平性,在后来Linux内核(2.6)中,引入了CFS调度器算法。 CFS引入虚拟运行时间的概念,虚拟运行时间用task_struct->se.vruntime表示,通过它来记录和度量进程应该获得的CPU运行时间。在理想的调度情况下,任何时候所有的进程都应该有相同的task_struct->se.vruntime值。因为每个进程都是并发执行,没有进程会超过理想状态下应该占有的CPU时间。CFS选择需要运行的进程的逻辑基于task_struct->se.vruntime值,它总是选择task_struct->se.vruntime值最小的进程来运行(为了公平)。 CFS使用基于时间排序的红黑树来为将来进程的执行时间线。所有的进程按task_struct->se.vruntime关键字排序。CFS从树中选择最左边的任务执行。随着系统运行,执行过的进程会被放到树的右侧,逐步让每个任务都有机会成为最左边的进程,从而让每个进程都能获取CPU资源。

《Linux操作系统》期末大作业任务书2019

大作业任务书 课程名称:Linux操作系统 题目:Linux期末大作业 专业:计算机科学与技术 班级:计算机185班 学号:6109118148 学生姓名:全昊 完成人数: 起讫日期: 任课教师:李荣鑫职称:副教授 完成时间: 说明 1.本任务书由任课教师填写后,下达到学生。 2.任务完成后,任课教师需填写小结表。 3.任务书、学生成绩与学生完成后的大作业(纸质和电子两种)一 并报送各教学研究部审核后转教务办。 4.另附一份全班大作业总结

《Linux操作系统》期末大作业 (要求将计算机名改为你的名字,以便命令行截图时能看到个人信息,shell编程题的源程序代码的第二行用注释给出个人信息。)1. 写出完成下列操作的Linux命令 (1)给shell脚本文件myshell.sh设置文件主和小组用户拥有可执行权限,其他用户无可执行权限。(若无相应文件可以先创建) #sudo touch mashell.sh #sudo chmod 776 myshell.sh (2)将目录/home/ncu下的所有文件拷贝到/data。(若无相应的目录可以先创建) #sudo cp /home/ncu/* /home/data 拷贝前: (3)安装软件包apache2并查看启动状态。 # sudo apt-get install apache2

(4)将/home/ncu目录打包压缩,生成ncu.tar.gz文件,并将此文件保存到/data目录 #sudo tar -zcvf data/ncu.tar.gz ncu #tar默认使用的是相对路径,如果按照一般习惯书写绝对路径可能导致错误。 (5)删除目录/home/ncu及其下面所有文件。 #rm -rf /home/ncu (6)统计当前目录下普通文件的数目并显示结果。 #ls -lR |grep "^-"|wc -l (7)查询软件mysql是否安装,若没安装,请安装。 #service mysql status 检查数据库服务是否启动 #sudo apt-get install mysql-server

Linux期末大作业(第4组)

嵌入式Linux大作业 学院:软件学院 专业班级:计算机软件111 班姓名-学号:刘可—8000611008 王青叶—8000611039 王飞林—8000611022 李洪成—8000611001 韩金辰—8000611003 指导老师:李岚 设计地点:图书馆406 设计题目:驱动程序设计和QT程序设计

目录 1.驱动程序设计 (4) 1.1驱动功能实现 (4) 1.2按键中断驱动 (4) 1.2.1驱动程序编写 (4) 1.2.2驱动程序编译 (4) 1.3 GPIO驱动程序 (5) 1.3.1驱动程序编写 (5) 1.3.2 驱动程序编译 (7) 1.4数码管驱动 (7) 1.5 测试程序 (7) 1.6 驱动安装 (10) 1.7 实验结果展示 (10) 2. QT程序设计 (14) 2.1 QT环境搭建 (14) 2.2 QT/E环境(开发板)搭建 (15) 2.3 QT应用程序实例 (23) 2.3.1计算器 (23) 2.3.2电话簿 (27) 2.3.3 图片浏览器 (32) 3.遇到主要问题与解决: (36) 4. 实验总结: (42)

组员分工安排一、成员介绍 组长:刘可 组员:王青叶、王飞林、李洪成、韩金辰二、分工安排 刘可:GPIO驱动程序编写、测试程序编写王青叶:Qt环境搭建、计算器程序 王飞林:简单图片浏览器程序 李洪成:简单电话簿程序 韩金辰:资料搜集和实验报告书写

1.驱动程序设计 1.1驱动功能实现 按键按第一下,LED灯以1,2,3进行闪烁;按键按第二下,LED 灯以1,3,2进行闪烁;按键按第三下,LED灯全部熄灭;同时,数码管中记录按键按下的次数。 1.2按键中断驱动 1.2.1驱动程序编写 在该驱动程序中声明变量count,我们会用count值记录按键的点击次数;使用EXPORT_SYMBOL_GPL(count);以供其他驱动程序调用。 重要函数如下: irqreturn_t s3c2440_IRQ3_fun (int irq, void *dev_id, struct pt_regs *reg) { disable_irq(S3C2440_IRQ5); printk("interrupt int05\n"); mdelay(200); ++flag_count; if(flag_count == 2) {

#Linux系统课程大作业

案例分析课程大作业 题目:超市管理系统设计与实现 1.班级与姓名:0826 周文志学号:200892285 项目分工:界面与数据库设计 2.班级与姓名:0826 刘萱学号: 项目分工:需求分析与文档编写 大连理工大学软件学院 2011年4月 第一部分需求分析 本系统为超市管理系统,通过本系统实现对销售、库存、物品等数据的管理。系统分为前台与后台,前台实现对账单的录入和付款工作并录入数据库,后台通过数据库实现对物品、经销商、库存的管理,以及查看销售情况。 1项目计划 1.1系统开发目的 (1) 大大提高超市的运作效率. (2) 通过全面的信息采集和处理,辅助提高超市的决策水平. (3) 使用本系统,可以迅速提升超市的管理水平,为降低经营成本, 提高效益,增强超市扩张能力, 提供有效的技术保障. 1.2背景说明 21世纪,超市的竞争也进入到了一个全新的领域,竞争已不再是规模的竞争,而是技术的竞争,管理的竞争,人才的竞争.技术的提升和管理的升级是连锁超市业的竞争核心.零售领域目前呈多元发展趋势,多种业态:超市,仓储店,便利店,特许加盟店,专卖店,货仓等相互并存.如何在激烈的竞争中扩大销售额,降低经营成本,扩大经营规模,成为超市努力追求的目标. 目标: 1. 能够给出合理的搭配各种货物的进购,使得收入增多 2. 能够评估给定各种货物的进购比例,促进销售 3. 能够存储各种商品的价格,并方便查阅 4. 能够反映出一段时间内某种商品的销售情况 5. 能够记录各种商品的销售历史,以便以后核查 需求: 1. 系统是安全的 2. 系统必须易于非专业人员使用 3. 必须能够在出现一种新的商品的时候记录新的商品信息 4. 必须能够修改各种商品的信息,并且能够查看

linux编程大作业讲解

linux编程大作业讲解 linux 第一部分简述题目 要求:这部分题目必做,要详细回答,最好用自己理解的语言回答,有些题目可用图形和举例等阐述问题。 1、makefile文件的作用是什么,makefile文件中有一种变量,其值是根据具体的规则来确定的,称为自动变量,其中代表所有依赖文件列表的是哪个;举例说明make 命令的工作流程。 答:在Makefile文件中描述了整个工程所有文件的编译顺序、编译规则。其中包括:工程中的哪些源文件需要编译以及如何编译、需要创建那些库文件以及如何创建这些库文件、如何最后产生我们想要的可执行文件。Makefile 有自己的书写格式、关键字、函数。在Makefile 中可以使用系统shell所提供的任何命令来完成想要的工作。能够使用一行命令来完成“自动化编译”。 自动变量$^代表所有依赖文件,以空格分开,以出现的先后为序。

2、什么是进程,用fork()创建一个子进程时,系统会做什么工作。请编程说明。 答:进程是具有独立功能的程序关于某个数据集合上的一次运行活动,是系统进行资源分配的单位,不仅是系统内部独立运行的实体也是独立竞争资源的实体。 用fork()时系统会分配子进程一个ID号然后继承父进程的地址空间,包括进程上下文进程堆栈打开的文件描述符等等,他就是父进程的一个复制品。 3、简述Linux文件系统通过i节点把文件的逻辑结构和物理结构转换的工作过程。解释i节点在文件系统中的作用。 答:文件系统建立在由若干连续的逻辑块构成的存储空间中,根据用途逻辑块可分为:超级块、i节点区和数据区。其中i节点区用于存放i节点,每个文件都 有各自唯一的i节点,i 节点是一个64字节长的表,表中包含了文件的相关信息,其中有文件的大小、文件所有者、文件的存取许可方式以及文件的类型等重要信息。在i 节点表中最重要的内容是磁盘地址表。在磁盘地址表中有13个块号,文件将以块号在磁盘地址表中出现的顺序依次读取相应的块。Linux文件系统通过把i节点和文件名进行连接,当需要读取该文件时,文件系统在当前目录表中查找该文件名对应的项,由此得到该文件相对应的i节点号,通过该i 节点的磁盘地址表把分散存放的文件物理块

linux大作业及要求

一、为企业架设web服务器,要求: 1.建立WEB服务器,服务器名为https://www.wendangku.net/doc/cf17209245.html,,网站主目录为/var/xx/www, 站点主页文件的搜索顺序为index.html index.php;服务器启动时的子进程数为5;使用端口为80。 网页内容为:班级名称,用户名,192.168.yy.12, 2.每个同学为自己建立个人主页空间,在/home下对自己做限额,软配额限 制15M,硬配额限制60M, i节点数不受限制。每个同学都属于gp组,组的限额是用户限额的50倍。 网页内容为:学号,用户名,192.168.yy.12,/home/用户名/www 其中:XX为同学名字的最后一个字的拼音,yy为同学学号的后两位数字,十位为0的只取个位数字。 评分标准: 1. 正确安装DNS和apache并配置地址。(10分) 2. 正确配置dns,添加主机记录,并能够正常解析的。(30分) 3. 正确配置站点,建立主页,建立用户及个人主页,并能正常访问。(30分) 4. 正确设置配额。(20分) 5. 将配置及测试过程整理成文档,格式规范,步骤完整、图表清晰。(10分)

二、为企业架设ftp服务器 1.建立FTP服务器,服务器名字为https://www.wendangku.net/doc/cf17209245.html,,服务器的欢迎语为“welcome to login ftpserver”.允许匿名用户上传下载文件,匿名用户的根目录为/var/ftp/pub,匿名用户的最大传输速率为10Kb/s. 2.为自己和自己前后相邻的两个同学建立账户(只有一个相邻的,就建立一 个),账户名字为姓名的全拼,允许本地用户访问,禁止相邻两个同学的账号切换到主目录以外的目录。 3.对/home做磁盘限额,用户的软配额限制15M,硬配额限制60M, i节点数 不受限制。每个同学都属于gp组,组的限额是用户限额的50倍。 4.将windows主机的一个txt文件上传到ftp服务器,文档的内容为:姓名, 学号,windows主机ip,192.168.yy.13. 其中:XX为同学名字的最后一个字的拼音,yy为同学学号的后两位数字,十位为0的只取个位数字。 评分标准: 1.正确安装DNS和ftp并配置地址。(10分) 2.正确配置dns,添加主机记录,并能够正常解析的。(30分) 3.正确配置ftp服务器,建立用户,并能正常访问。(30分) 4.正确设置配额。(20分) 5. 将配置及测试过程整理成文档,格式规范,步骤完整、图表清晰。(10分)

LINUX大作业

2013届课程大作业 《Linux基础与应用》 课程大作业 学生姓名王春景 学号5011209204 所属学院信息工程学院 专业计算机科学与技术 班级计算机13-2班 指导教师范振岐 教师职称讲师 塔里木大学教务处制

《Linux基础与应用》课程大作业 王春景摘要:Linux是操作系统,确切地说是GNU/Linux操作系统。它的诞生、发展与UNIX、MINIX操作系统、GNU计划、POSIX标准以及Internet广泛应用有着极大的关系。本文就从对Linux系统中的一些代码程序做了简单的介绍,如:ping、ifconfig、netstat等网络命令的使用,熟悉网络配置文件的配置方法,体会Linux多用户的特点,利用telnet 进行。建立多个帐户进行测试。配置NFS服务器,实现文件系统的远程挂载。配置samba 服务器,实现不同系统之间的文件共享。简单shell编程等几个方面对Linux系统进行了一个全面的讲解。 关键词:服务器,网络命令,文件配置 前言 简单地说,Linux是一套免费使用和自由传播的类Unix操作系统,它主要用于基于Intel x86系列CPU的计算机上。这个系统是由世界各地的成千上万的程序员设计和实现的。其目的是建立不受任何商品化软件的版权制约的、全世界都能自由使用的Unix兼容产品。 Linux可在GNU(“不是UNIX”工程的缩写)公共许可权限下免费获得,是一个符合POSIX标准的操作系统。Linux操作系统软件包不仅包括完整的Linux操作系统,而且还包括了文本编辑器、高级语言编译器等应用软件。它还包括带有多个窗口管理器的 X-Windows图形用户界面,如同我们使用Windows NT一样,允许我们使用窗口、图标和菜单对系统进行操作。 Linux不仅为用户提供了强大的操作系统功能,而且还提供了丰富的应用软件。用户不但可以从Internet上下载Linux及其源代码,而且还可以从Internet上下载许多Linux的应用程序。可以说,Linux本身包含的应用程序以及移植到Linux上的应用程序包罗万象,任何一位用户都能从有关Linux的网站上找到适合自己特殊需要的应用程序及其源代码,这样,用户就可以根据自己的需要下载源代码,以便修改和扩充操作系统或应用程序的功能。这对Windows NT、Windows98、MS-DOS或OS/2等商品化操作系统来说是无法做到的。 Linux具有:稳定、可靠、安全的优点,并且有强大的网络功能。其中有对读、写进行权限控制、审计跟踪、核心授权等技术,这些都为安全提供了保障。在相关软件的支持下,可实现WWW、FTP、DNS、DHCP、E-mail等服务,还可作为路由器使用,利用IPCHAINS/IPTABLE网络治理工具可构建NAT及功能全面的防火墙。 熟悉基本的网络命令,pingi、ifconfing、netstat以及熟悉网络配置文件与配置方法,体会Linux多用户的特点利用telnet进行要求每个同学都有相应的帐户,配置NFS 服务器,实现文件系统的远程挂载。配置samba服务器,实现不同系统之间的文件共享, 简单shell编程是本次实习操作的主要内容。 1.1课程大作业的目的和意义 我们是计算机科学与技术专业的本科生,《Linux 操作系统》是我们重要的必修课程。当代社会学要大学培养出理论扎实,动手实践能力强的大学生。所以,本次课程大作业的目的就在于通过一次实践性的活动加深对这门课程的理解,使我们在感性的认识上进一步

LINUX大作业

Linux系统编程大作业 一、实验题目 实现一个FTP服务系统 二、实验目的 通过该实验,掌握Linux环境下的多线程/进程编程技术、文件操作、用户权限管理、进程间通信技术 三、实验要求 基于客户/服务器交互模式,采用TCP/IP通信协议,实现一个支持远程文件传输的客户/服务器软件,支持文件的上传和下载。其中客户端软件命名为myftp,服务器软件命名为ftpserver,具体功能需求如下: (一)服务器 1)启动方式。执行ftpserver [IP地址] port启动FTP服务。其中IP地址为可选项。若不提供服务器IP地址,FTP服务将自动绑定到本地网络的IP。 2)用户认证与权限管理。为FTP客户提供基于用户名/密码认证的服务模式,只有授权用户才可以访问FTP服务。与此同时,对文件/目录的访问,也实现基于授权的 访问机制,即只有授权用户才可以对指定文件进行读写操作。用户只有在具备写权 限操作的目录上才能上传文件。(可直接集成Linux服务器系统的用户管理)3)并行执行功能。为提高系统性能,服务器将采用多进程/线程技术响应客户请求。 当客户通过身份验证后,服务器将创建一个新的进程/线程来响应用户请求,提供 服务。 4)服务器支持的客户文件操作。登录成功后,客户可在服务器执行以下操作:创建/删除目录(mkdir/rmdir)、显示当前路径(pwd)、切换目录(cd)、查看当前目 录下的所有文件(ls)、上传单个/多个文件(put/mput)、下载单个/多个文件 (get/mget)。 5)服务传输模式。支持二进制(默认)及ASCII传输模式。用户可通过执行binary/ascii 命令切换传输模式。 6)站点计数与用户管理功能。统计服务器站点的当前活动用户数及自运行以来的访客总数。系统管理员可在服务器软件运行终端窗口执行以下命令: A)count current:当前活动用户数 B)c ount all:显示系统访客总数 C)l ist:显示当前在线的所有用户的用户名 D)kill username:强制删除某个用户。 E)quit:关闭ftp服务器软件。 7)其他功能。对用户错误输入提供容错保护,即当用户输入错误命令时,需向客户端返回出错提示信息。 8)可选功能(加分)。 A)在服务器端为访问频率最高的文件建立缓冲区(可采用共享内存技术),以便提高服务器端的性能。

linux编程大作业资料

第一部分简述题目 要求:这部分题目必做,要详细回答,最好用自己理解的语言回答,有些题目可用图形和举例等阐述问题。 1、makefile文件的作用是什么,makefile文件中有一种变量,其值是根据具体的规则来确定的,称为自动变量,其中代表所有依赖文件列表的是哪个;举例说明make命令的工作流程。 答:在Makefile文件中描述了整个工程所有文件的编译顺序、编译规则。其中包括:工程中的哪些源文件需要编译以及如何编译、需要创建那些库文件以及如何创建这些库文件、如何最后产生我们想要的可执行文件。Makefile 有自己的书写格式、关键字、函数。在Makefile 中可以使用系统shell所提供的任何命令来完成想要的工作。能够使用一行命令来完成“自动化编译”。 自动变量$^代表所有依赖文件,以空格分开,以出现的先后为序。 2、什么是进程,用fork()创建一个子进程时,系统会做什么工作。请编程说明。 答:进程是具有独立功能的程序关于某个数据集合上的一次运行活动,是系统进行资源分配的单位,不仅是系统内部独立运行的实体也是独立竞争资源的实体。 用fork()时系统会分配子进程一个ID号然后继承父进程的地址空间,包括进程上下文进程堆栈打开的文件描述符等等,他就是父进程的一个复制品。 3、简述Linux文件系统通过i节点把文件的逻辑结构和物理结构转换的工作过程。解释i节点在文件系统中的作用。 答:文件系统建立在由若干连续的逻辑块构成的存储空间中,根据用途逻辑块可分为:超级块、i节点区和数据区。其中i节点区用于存放i节点,每个文件都

有各自唯一的i节点,i 节点是一个64字节长的表,表中包含了文件的相关信息,其中有文件的大小、文件所有者、文件的存取许可方式以及文件的类型等重要信息。在i节点表中最重要的内容是磁盘地址表。在磁盘地址表中有13个块号,文件将以块号在磁盘地址表中出现的顺序依次读取相应的块。Linux文件系统通过把i节点和文件名进行连接,当需要读取该文件时,文件系统在当前目录表中查找该文件名对应的项,由此得到该文件相对应的i节点号,通过该i 节点的磁盘地址表把分散存放的文件物理块连接成文件的逻辑结构。 4、文件指针FILE*与文件描述符是一个什么样的关系,请画图说明。 答:在linux系统中,一个文件可以被多个线程共享,每个进程在内核中用task_struct结构表示,其中有一个称为文件描述符表的fd,文件描述符表fd,是一个指针数组,每个指针指向一个file结构,用于记录一个打开文件的状态信息,其中f_pos记录打开文件的当前读写位置,f_dentry打开文件所在目录,f_op文件具体的操作集,打开文件就会获得文件描述符,它是个很小的正整数。每个进程在PCB(Process Control Block)中保存着一份文件描述符表,文件描述符就是这个表的索引,每个表项都有一个指向已打开文件的指针。 5、简述与windows的文件系统相比,linux文件系统有什么特点,并用图详细描述。 答:Linux的每个目录都可能是一个分区,在安装Linux时至少有两个分区,根分区和swap分区,其它的分区都安装在根下面。如将一个分区安装在/var下面,每个分区安装的位置成为“挂载点”,如挂载点/var。swaP分区大小是内存的2倍,等价于Windows的虚拟内存。根分区文件类型一般选择为ext3,swap 分区类型即为swap。Linux中文件和目录都区分大小写,如home和Home不是一个目录。Linux把文件的i-nod信息全都交给了目录管理。包括文件存不存在、文件名是什么、文件存放在磁盘哪里等信息。只要有这个目录的写权限,就可以

操作系统大作业(含课程设计)

“计算机操作系统”课程设计大作业 一、题目: 页面置换算法模拟实验 二、目的 分别采用最佳(Optimal)置换算法、先进先出(FIFO)页面置换算法和最近最少使用(LRU)置换算法对用户输入的页面号请求序列进行淘汰和置换,从而加深对页面置换算法的理解。 三、内容和要求 请用C/C++语言编一个页面置换算法模拟程序。用户通过键盘输入分配的物理内存总块数,再输入用户逻辑页面号请求序列,然后分别采用最佳(Optimal)置换算法、先进先出(FIFO)页面置换算法和最近最少使用(LRU)置换算法三种算法对页面请求序列进行转换,最后按照课本P150页图4-26的置换图格式输出每次页面请求后各物理块内存放的虚页号,并算出每种算法的缺页次数。最后评价三种页面置换算法的优缺点。 三种页面置换算法的思想可参考教材P149-P152页。 假设页面号请求序列为4、3、2、1、4、3、5、4、3、2、1、5,当分配给某进程的物理块数分别为3块和4块时,试用自己编写的模拟程序进行页面转换并输出置换图和缺页次数。 四、提交内容 本大作业每个人必须单独完成,大作业以WORD附件形式提交。最后需提交的内容包括:算法算法思路及流程图、数据结构说明、源

程序(关键代码需要注释说明)、运行结果截图、心得体会及总结。 大作业严禁抄袭。发现抄袭一律以不及格论。 请大家严格按照大作业题目来编写程序,不要上交以前布置的大作业。如果提交的大作业题目与本文档要求不符,成绩一律为不及格。 请大家按时在网院网上系统里提交大作业,过了规定时间将无法再补交大作业。 答: 一、思路 页面置换算法:当CPU接收到缺页中断信号,中断处理程序先保存现场,分析中断原因,转入缺页中断处理程序。该程序通过查找页表,得到该页所在外存的物理块号。熟悉UNIX/LINUX的常用基本命令,练习并掌握UNIX提供的vi 编辑器来编译C程序,学会利用gcc、gdb编译、调试C程序,学会如何把学到的知识用于解决实际问题,培养学生!

bupt本科-Linux基础(董远)-某年期末大作业

LINUX系统与程序设计2011春本科生大作业 ------------------------------------------ 1. Shell编程:查询系统最近1000条命令中使用最多的前10条命令,编写Shell脚本实现此功能。写出具体代码和操作过程。 ------------------------------------------ # echo $HISTSIZE 1000 # history | awk '{CMD[$2]++;count++;}END { for (a in CMD)print CMD[a] " " CMD[a]/count*100 "% " a;}' | grep -v "./" | column -c3 -s " " -t | sort -nr | nl | head -n10 解释:第一行的echo $HISTSIZE 1000是设置history中记录1000条命令;第二行中用awk 统计history 中的命令部分出现的次数,去掉“./" 这样不算命令的情况,最后排序输出,列出前10 个负责统计最近1000条命令中使用最多的10条命令。 ------------------------------------------- 2. Linux操作系统的系统配置文件默认储存在/etc目录下,因此管理员可以通过查看相应的文件来得知系统配置信息。编写一个shell脚本显示下列系统配置信息: (1)CPU相关信息:如处理器类型,速度等; (2)内存信息; (3)挂载文件信息。 ------------------------------------------- 说明:通过在网上查到的资料,以及ls对/etc目录的列表,没有发现系统配置信息存在于/etc 中,而应该是/proc中。 #ls -a /etc #ls /etc/cpuinfo #ls /etc/meminfo #ls /etc/mount ------------------------------------------- 3. 编写my_cp.sh脚本,功能是把一个文件拷贝到另一文件。其有两个参数,一个作为输入文件(source),一个作为输出文件(destination)。脚本需满足下面一些条件:(1)确保输入的两个参数不重名; (2)验证输出文件(destination)是一个文件,而不是目录; (3)验证输入文件(source)文件存在; (4)检查输出文件是否存在,若存在,则询问用户是否覆盖。 ------------------------------------------- #! bin/sh sign=1 if [ "$#" != 2 ] then echo "please make sure that you enter 2 arguments, first is the source file, second is the destination directory." exit 1

相关文档