当前位置:
文档之家› Linux程序设计实验报告大作业
Linux程序设计实验报告大作业
主程序先用open函数打开文件“5-11file”,如果该文件不存在,则创建此文件;接着调用自定义函数lock_set:先传递参数“F_WRLCK”给文件“5-11file”加锁,并打印输出给文件加锁进程的进程号,然后先传递参数“F_UNLCK”给文件“5-11file”解锁,并打印输出给文件解锁进程的进程号;在自定义函数lock_set给文件上锁语句前,加上判断文件是否上锁的语句,如果文件已经被上锁,打印输出给文件上锁进程的进程号。
线程在并发执行时为了保证结果的可再现性,各线程执行序列必须加以限制以保证互斥地使用临界资源,相互合作完成任务。多个相关线程在执行次序上的协调称为线程同步。用于保证多个线程在执行次序上的协调关系的相应机制称为线程同步机制。
Pthread线程库提供了多种方式来处理线程同步互斥机制,最常用的是互斥锁、条件变量和信号量。
编译并运行程序:结果是10。我们创建两个线程,counter的初值为0,各自把counter增加10次,正常情况下最后counter应该等于20四、实验总结
通过本次实验,我学会了在Linux下使用C语言操作线程的方法,了解了线程和进程的区别,对于理解Linux的核心非常有帮助。
实验报告
组别
姓名
张正锟
可以看到,程序只在父进程进行了输出。这是因为子进程调用了_exit()函数,没有进行缓冲区IO的刷新。
通过本次试验,我了解了Linux的进程机制,学会了基本的进程创建,进程终止,学会了在Linux下用C语言操作进程。了解到了Linux是一个多任务操作系统,允许我们使用计算机系统,多个进程并发执行。
实验报告
Socket是网络编程的一种接口,它是一种特殊的I/O。
多线程的进程在同一地址空间内包括多个不同的控制流,也即属于同一进程下的线程,它们共享进程拥有的资源,如代码、数据、文件等。线程也独占一些资源,如堆栈、程序计数器等。
多线程系统的优点包括对用户响应的改进,进程内的资源共享,以及利用多处理器体系结构的便利。从实现的角度看,把线程分为用户级线程和内核级线程。用户级线程对程序员来说是可见的,而对内核来说是未知的,用户空间的线程库通常用以管理用户级线程,线程库提供对线程创建、调度和管理的支持。内核级线程由操作系统支持和管理,在内核空间实现线程创建、调度和管理。
实验报告
组别
姓名
张正锟
同组实验者
实验项目名称
实验四进程控制
实验日期
第14周周四9,10节
教师评语
实验成绩
指导教师
1.理解进程的基本概念及进程的结构
2.学会Linux环境下进程的相关函数的应用
3.掌握守护进程的概念、启动和建立
4.掌握进程操作程序的编写
进程是正在执行中的程序。当我们在终端执行命令时,Linux就会建立一个进程,而当我们的程序执行完成时,这个进程就被终止了。
通过本次实验,我学会了shell中的各种写法,包括流程控制,循环,数组,函数等等,了解到shell在Linux是一种强大的神器,可以批量完成各种操作。
实验报告
组别
姓名
张正锟
同组实验者
实验项目名称
实验三文件操作
实验日期
第13周周四9,10节
教师评语
实验成绩
指导教师
1.熟悉cd、date、pwd、cal、who、echo、clear、passwd等常用命令。?
带缓存的基于输入/输出(I/O)流机制的文件操作时,打开文件用fopen函数,关闭文件用fclose函数。
可以看到程序运行后创建了”5-12file”文件
通过本次实验,我掌握了Linux下用C语言读写文件的方法,包括带缓存和不带缓存的方法。另外也学会了用C语言修改文件权限等知识点。可以看出Linux和C语言是浑然一体地,可以用C语言无缝地操作Linux系统。
Linux是一个多任务操作系统,允许多个用户使用计算机系统,多个进程并发执行。
Linux环境下启动进程有两种主要途径:手工启动和调度启动。
在Linux环境下进程创建时,系统会分配一个唯一的数值给每个进程,这个数值就称为进程标识符(PID)。
在Linux中进程标识有进程号(PID)和它的父进程号(PPID)。其中,PID唯一地标识一个进程。PID和PPID都是非零的正整数。在Linux中获得当前进程的PID和PPID的系统调用为getpid和getppid函数。
可看到,每次运行的pid都是不同的。
进程调用fork函数创建一个新进程,由fork创建的新进程被称为区别是子进程的返回值是0,而父进程的返回值则是新子进程的进程PID。
子进程和父进程继续执行fork之后的指令。子进程是父进程的复制品。例如,子进程获得父进程数据空间、堆和栈的复制品。注意,这是子进程所拥有的拷贝。父、子进程并不共享这些存储空间部分,通常父、子进程共享代码段
实验报告
课程名称:LINUX程序设计
学院:计算机学院
专业:软件工程班级:14-3
姓名:张正锟学号:
2017年1月1日
山东科技大学教务处制
实验报告
组别
姓名
张正锟
同组实验者
实验项目名称
实验一熟悉Linux命令
实验日期
第11周周四9,10节
教师评语
实验成绩
指导教师
熟悉并掌握Linux操作系统基本命令
/etc/passwd是用户数据库,其中的域给出了用户名、加密口令和用户的其他信息. /etc/shadow是在安装了影子(shadow)口令软件的系统上的影子口令文件。影子口令文件将/etc/passwd文件中的加密口令移动到/etc/shadow中,而后者只对超级用户( r o o t )可读。这使破译口令更困难,以此增加系统的安全性。
加上写入锁的是:5404
释放强制性锁:5404
加上读取锁的是:5404
释放强制性锁:5404
带缓存的流文件I/O操作,是基于输入/输出(I/O)流机制的文件操作,又做文件流(File Stream)的操作。下面具体说明文件流的关闭与打开。
设计一个程序,要求用流文件I/O操作打开文件“5-12file”,如果该文件不存在,则创建此文件。
用gedit打开一个文件并在后台运行,显示的进程号为17271,然后用kill命令杀死这个进程,观察到gedit关闭
通过本次实验,熟悉了好多Linux下面的基本命令,可以看出Linux的命令基本上都有好多参数可选,这样就可以用一条命令完成好多任务,大大提高效率。另外还学会了当命令不会使用的时候,可以调用man来查看命令的使用方法。
用户级线程与内核级线程相比,优点是创建和管理要更快;缺点是得到CPU的时间更少,当一个线程阻塞时,连累其它线程全部阻塞。
当并发执行的线程共享数据时,各线程会改写共享的数据,由于CPU调度顺序的不确定性,造成线程运行结果的不确定性。所以,必须为共享数据的一组相互协作的线程提供互斥。一种思想是确保在任何时刻最多只能有一个线程执行这些访问共享数据的代码。这就是临界区互斥问题。
同组实验者
实验项目名称
实验六网络编程
实验日期
第16周周四9,10节
教师评语
实验成绩
指导教师
理解端口及Socket的基本概念
掌握面向连接的TCP编程
掌握面向非连接的UDP编程
了解I/O多路利用的控制
了解复杂网络程序的实现
TCP/IP协议(Transmission Control Protocol/Internet Protocol)叫做传输控制/网际协议,又叫网络通信协议。
设计一个程序,要求子进程和父进程都在显示输出一些文字后分别用exit和_exit函数终止进程。
由于printf函数使用的是缓冲I/O方式,遇到”\n”时自动将数据从缓冲区读出。可以看出,调用exit函数时,缓冲区中的记录能正常输出;而调用_exit时,缓冲区中的记录无法输出。
Linux标准函数库中,有一种操作称为“缓冲I/O”,每次读写文件时,都是在缓冲区里读取、写入。写入文件时,等满足一定条件才将缓冲区的内容一次性写入文件。但是,有时没有满足选定的条件,数据只存在缓冲区内,如果这时调用_exit函数直接关闭进程,缓冲区中的数据就会丢失。
组别
姓名
张正锟
同组实验者
实验项目名称
实验五线程练习
实验日期
第15周周四9,10节
教师评语
实验成绩
指导教师
了解线程的基本概念
掌握线程相关函数及应用
理解线程同步互斥
线程定义为进程内一个执行单元或一个可调度实体。在不拥有线程的进程概念中,进程既是一个拥有资源的独立单位,它可独立分配虚地址空间、主存和其它,又是一个可独立调度和分派的基本单位。在有了线程以后,资源拥有单位称为进程(或任务),调度的单位称为线程、又称轻进程(Light Weight Process,LWP)。
文件的打开可以用open函数,即使原来的文件不存在,也可以用open函数创建文件。在打开或者创建文件时,可以指定文件的属性及用户的权限等参数。关闭一个打开的文件,用close函数。当一个进程终止时,它所有已打开的文件都由内核自动关闭。
设计一个程序,要求在“/root”下打开一个名为“5-11file”的文件,如果该文件不存在,则创建此文件。打开后对其加上强制性的写入锁F_WRLCK,按回车后解锁F_UNLCK,然后加上读出锁F_RDLCK,按回车后再解锁F_UNLCK。程序在终端1运行后会显示程序的进程号,再打开终端2,会提示此文件处于锁定状态,此时在终端2可以多按回车,观察程序的运行结果。然后在终端1按回车,等待终端1解锁后,在终端2才可锁定此文件,你可观察到强制性锁是独占状态,当在终端2解锁后,在终端1或2可加读出锁,在读出锁状态终端1或2的运行不需要等待,因为读出锁是处于共享状态,请编写程序并测试程序运行的结果。
TCP/IP是20世纪70年代中期美国国防部为其ARPANET广域网开发的网络体系结构和协议标准,以它为基础组建的Internet是目前国际上规模最大的计算机网络。正因为Internet的广泛使用,使得TCP/IP成了事实上的标准。