1 / 38
文档名称:

Linux程序设计 实验报告 大作业.pdf

格式:pdf   大小:3,671KB   页数:38页
下载后只包含 1 个 PDF 格式的文档,没有任何的图纸或源代码,查看文件列表

如果您已付费下载过本站文档,您可以点这里二次下载

分享

预览

Linux程序设计 实验报告 大作业.pdf

上传人:青山代下 2024/6/12 文件大小:3.58 MB

下载得到文件列表

Linux程序设计 实验报告 大作业.pdf

相关文档

文档介绍

文档介绍:该【Linux程序设计 实验报告 大作业 】是由【青山代下】上传分享,文档一共【38】页,该文档可以免费在线阅读,需要了解更多关于【Linux程序设计 实验报告 大作业 】的内容,可以使用淘豆网的站内搜索功能,选择自己适合的文档,以下文字是截取该文章内的部分文字,如需要获得完整电子版,请下载此文档到您的设备,方便您编辑和打印。:..实验报告课程名称:LINUX程序设计学院:计算机学院专业:软件工程班级:14-3姓名:张正锟学号:20140**********年1月1日山东科技大学教务处制1:..实验报告组别姓名张正锟同组实验者第11周周四实验项目名称实验一熟悉Linux命令实验日期9,10节教师评语实验成绩指导教师一、实验目的熟悉并掌握Linux操作系统基本命令二、,date,,less,head,tail,nl,wc等命令的使用2:..,chown,:mkdir,rmdir3:..三、,/etc/shadow/etc/passwd是用户数据库,其中的域给出了用户名、加密口令和用户的其他信息./etc/shadow是在安装了影子(shadow)口令软件的系统上的影子口令文件。影子口令文件将/etc/passwd文件中的加密口令移动到/etc/shadow中,而后者只对超级用户(root)可读。这使破译口令更困难,以此增加系统的安全性。,/etc/gshadow4:..,who,whoami,groups等命令四、:..五、:..六、,显示的进程号为17271,然后用kill命令杀死这个进7:..程,观察到gedit关闭七、实验总结通过本次实验,熟悉了好多Linux下面的基本命令,可以看出Linux的命令基本上都有好多参数可选,这样就可以用一条命令完成好多任务,大大提高效率。另外还学会了当命令不会使用的时候,可以调用man来查看命令的使用方法。8:..实验报告组别姓名张正锟同组实验者第12周周四实验项目名称实验二Shell编程实验日期9,10节教师评语实验成绩指导教师一、实验目的?掌握Shell命行的运行?掌握编写和执行Shell程序的步骤?掌握在Shell中使用参数和使用变量的方法?掌握表达式比较,循环结构语句和条件结构语句的写法?掌握在shell脚本中使用函数的方法二、:..计算器:、:..、:..:..实验总结shell中的各种写法,包括流程控制,循环,数组,函数等等,了解到shell在Linux是一种强大的神器,可以批量完成各种操作。:..验报告组别姓名张正锟同组实验者第13周周四实验项目名称实验三文件操作实验日期9,、date、pwd、cal、who、echo、clear、passwd等常用命令。:复制一个文件、显示文件内容、查找指定内容、排序、文件比较、文件删除等。:创建和删除子目录、改变和显示工作目录、列出和更改文件权限、链接文件等。二、文件操作:修改文件权限设计一个程序,要求把系统中“/etc”目录下的passwd文件权限,设置成文件所有者可读可写,所有其他用户为只读权限。编写C语言程序:..,即使原来的文件不存在,也可以用open函数创建文件。在打开或者创建文件时,可以指定文件的属性及用户的权限等参数。关闭一个打开的文件,用close函数。当一个进程终止时,它所有已打开的文件都由内核自动关闭。:..、,要求在“/root”下打开一个名为“5-11file”的文件,如果该文件不存在,则创建此文件。打开后对其加上强制性的写入锁F_WRLCK,按回车后解锁F_UNLCK,然后加上读出锁F_RDLCK,按回车后再解锁F_UNLCK。程序在终端1运行后会显示程序的进程号,再打开终端2,会提示此文件处于锁定状态,此时在终端2可以多按回车,观察程序的运行结果。然后在终端1按回车,等待终端1解锁后,在终端2才可锁定此文件,你可观察到强制性锁是独占状态,当在终端2解锁后,在终端1或2可加读出锁,在读出锁状态终端1或2的运行不需要等待,因为读出锁是处于共享状态,请编写程序并测试程序运行的结果。“5-11file”,如果该文件不存在,则创建此文件;接着调用自定义函数lock_set:先传递参数“F_WRLCK”给文件“5-11file”加锁,并打印输出给文件加锁进程的进程号,然后先传递参数“F_UNLCK”给文件“5-11file”解锁,并打印输出给文件解锁进程的进程号;在自定义函数lock_set给文件上锁语句前,加上判断文件是否上锁的语句,如果文件已经被上锁,打印输出给文件上锁进程的进程号。:..17:..:加上写入锁的是:5403释放强制性锁:5403文件已加上写入锁,其进程号是:5404文件已加上写入锁,其进程号是:5404文件已加上写入锁,其进程号是:5404加上读取锁的是:5403释放强制性锁:5403终端2:文件已加上写入锁,其进程号是:5403文件已加上写入锁,其进程号是:540318:..文件已加上写入锁,其进程号是:5403加上写入锁的是:5404释放强制性锁:5404加上读取锁的是:5404释放强制性锁:5404五、流文件的打开和关闭带缓存的流文件I/O操作,是基于输入/输出(I/O)流机制的文件操作,又做文件流(FileStream)的操作。下面具体说明文件流的关闭与打开。,要求用流文件I/O操作打开文件“5-12file”,如果该文件不存在,则创建此文件。(I/O)流机制的文件操作时,打开文件用fopen函数,关闭文件用fclose函数。:..”5-12file”文件六、实验总结通过本次实验,我掌握了Linux下用C语言读写文件的方法,包括带缓存和不带缓存的方法。另外也学会了用C语言修改文件权限等知识点。可以看出Linux和C语言是浑然一体地,可以用C语言无缝地操作Linux系统。20:..实验报告组别姓名张正锟同组实验者第14周周四实验项目名称实验四进程控制实验日期9,10节教师评语实验成绩指导教师一、、、进程简介进程是正在执行中的程序。当我们在终端执行命令时,Linux就会建立一个进程,而当我们的程序执行完成时,这个进程就被终止了。Linux是一个多任务操作系统,允许多个用户使用计算机系统,多个进程并发执行。Linux环境下启动进程有两种主要途径:手工启动和调度启动。三、程序显示进程号和父进程号在Linux环境下进程创建时,系统会分配一个唯一的数值给每个进程,这个数值21:..就称为进程标识符(PID)。在Linux中进程标识有进程号(PID)和它的父进程号(PPID)。其中,PID唯一地标识一个进程。PID和PPID都是非零的正整数。在Linux中获得当前进程的PID和PPID的系统调用为getpid和getppid函数。:..可看到,每次运行的pid都是不同的。四、子进程的创建进程调用fork函数创建一个新进程,由fork创建的新进程被称为子进程(childprocess)。该函数被调用一次,但返回两次,两次返回的区别是子进程的返回值是0,而父进程的返回值则是新子进程的进程PID。子进程和父进程继续执行fork之后的指令。子进程是父进程的复制品。例如,子进程获得父进程数据空间、堆和栈的复制品。注意,这是子进程所拥有的拷贝。父、子进程并不共享这些存储空间部分,通常父、:..、,要求子进程和父进程都在显示输出一些文字后分别用exit和_exit函数终止进程。,遇到””时自动将数据从缓冲区读出。可以看出,调用exit函数时,缓冲区中的记录能正常输出;而调用_exit时,缓冲区中的记录无法输出。Linux标准函数库中,有一种操作称为“缓冲I/O”,每次读写文件时,都是在缓冲区里读取、写入。写入文件时,等满足一定条件才将缓冲区的内容一次性写入文件。但是,有时没有满足选定的条件,数据只存在缓冲区内,如果这时调用_exit函数直接关闭进程,缓冲区中的数据就会丢失。:..,程序只在父进程进行了输出。这是因为子进程调用了_exit()函数,没有进行缓冲区IO的刷新。六、实验总结通过本次试验,我了解了Linux的进程机制,学会了基本的进程创建,进程终止,学会了在Linux下用C语言操作进程。了解到了Linux是一个多任务操作系统,允许我们使用计算机系统,多个进程并发执行。25:..验报告组别姓名张正锟同组实验者第15周周四实验项目名称实验五线程练****实验日期9,10节教师评语实验成绩指导教师实验目的了解线程的基本概念?掌握线程相关函数及应用?理解线程同步互斥二、线程概述线程定义为进程内一个执行单元或一个可调度实体。在不拥有线程的进程概念中,进程既是一个拥有资源的独立单位,它可独立分配虚地址空间、主存和其它,又是一个可独立调度和分派的基本单位。在有了线程以后,资源拥有单位称为进程(或任务),调度的单位称为线程、又称轻进程(LightWeightProcess,LWP)。多线程的进程在同一地址空间内包括多个不同的控制流,也即属于同一进程下的线程,它们共享进程拥有的资源,如代码、数据、文件等。线程也独占一些资源,如堆栈、程序计数器等。多线程系统的优点包括对用户响应的改进,进程内的资源共享,以及利用多处理器体系结构的便利。从实现的角度看,把线程分为用户级线程和内核级线程。用户级线程对程序员来说是可见的,而对内核来说是未知的,用户空间的线程库:..内核级线程由操作系统支持和管理,在内核空间实现线程创建、调度和管理。用户级线程与内核级线程相比,优点是创建和管理要更快;缺点是得到CPU的时间更少,当一个线程阻塞时,连累其它线程全部阻塞。共享内存变量访问中冲突的现象关于线程同步与互斥当并发执行的线程共享数据时,各线程会改写共享的数据,由于CPU调度顺序的不确定性,造成线程运行结果的不确定性。所以,必须为共享数据的一组相互协作的线程提供互斥。一种思想是确保在任何时刻最多只能有一个线程执行这些访问共享数据的代码。这就是临界区互斥问题。线程在并发执行时为了保证结果的可再现性,各线程执行序列必须加以限制以保证互斥地使用临界资源,相互合作完成任务。多个相关线程在执行次序上的协调称为线程同步。用于保证多个线程在执行次序上的协调关系的相应机制称为线程同步机制。Pthread线程库提供了多种方式来处理线程同步互斥机制,最常用的是互斥锁、条件变量和信号量。:..:..结果是10。我们创建两个线程,counter的初值为0,各自把counter增加10次,正常情况下最后counter应该等于20通过本次实验,我学会了在Linux下使用C语言操作线程的方法,了解了线程和进程的区别,对于理解Linux的核心非常有帮助。:..验报告组别姓名张正锟同组实验者第16周周四实验项目名称实验六网络编程实验日期9,10节教师评语实验成绩指导教师实验目标理解端口及Socket的基本概念?掌握面向连接的TCP编程?掌握面向非连接的UDP编程?了解I/O多路利用的控制?了解复杂网络程序的实现二、协议概述TCP/IP协议TCP/IP协议(TransmissionControlProtocol/Protocol)叫做传输控制/网际协议,又叫网络通信协议。TCP/广域网开发的网络体系结构和协议标准,是目前国际上规模最大的计算机网络。的广泛使用,使得TCP/IP成了事实上的标准。TCP/IP虽然叫传输控制协议(TCP)和网际协议(IP),但实际上是一组协议,它:..ICMP、RIP、、FTP、SMTP、ARP、TFTP等,这些协议一起被称为TCP/IP协议。UDP和TCP协议TCP与UDP是两种不同的网络传输方式。两个不同计算机中的程序,使用IP地址和端口,要使用一种约定的方法进行数据传输。主要的区别是进行数据传输时是否进行连接。TCP:TCP是一种面向连接的网络传输方式。这种方式可以理解为打电话。计算机A先呼叫计算机B,计算机B接受连接后发出确认信息,计算机A收到确认信息以后发送信息,计算机B完成数据接收以后发送完毕信息,这时再关闭数据连接。所以TCP是面向连接的可靠的信息传输方式。这种方式是可靠的,缺点是传输过程复杂,需要占用较多的网络资源。UDP:UDP是一种不面向连接的传输方式。可以简章理解成邮寄信件。将信件封装放入邮筒以后,不再参预邮件的传送过程。使用UDP传送信息时,不建立连接,直接把信息发送到网络上,由网络完成信息的传送。信息传递完成以后也不发送确认信息。这种传输方式是不可靠的,但是有很好的传输效率。对传输可靠性要求不高时,可以选择使用这种传输方式。,它是一种特殊的I/O。在TCP/IP协议中,“IP地址+TCP或UDP端口号”可以唯一标识网络通讯中的一个进程,可以简单地认为:“IP地址+端口号”就称为socket。在TCP协议中,建立连接的两个进程各自有一个socket来标识,这两个socket组成的socket对就唯一标识一个连接。用socket函数建立一个socket连接,此函数:..返回一个整型的socket描述符,随后进行数据传输。一个完整的socket有一个本地唯一的socket号,由操作系统分配。最重要的是,socket是面向客户/服务器模型而设计的。通常,socket分为三种类型:流式socket、数据报socket和原始socket。注意:一个完整的socket有一个本地唯一的socket号,由操作系统分配。最重要的是,socket是面向客户/服务器模型而设计的。三、设计服务器-#inet/>//forsockaddr_in#include<sys/>//forsocket#include<sys/>//forsocket#include<>//forprintf#include<>//forexit#include<>//forbzero/*#include<sys/>#include<sys/>#include<>#include<>*/#defineHELLO_WORLD_SERVER_PORT6666#defineLENGTH_OF_LISTEN_QUEUE20#defineBUFFER_SIZE1024#defineFILE_NAME_MAX_SIZE512intmain(intargc,char**argv){//设置一个socket地址结构server_addr,地址,端口structsockaddr_inserver_addr;bzero(&server_addr,sizeof(server_addr));//=;=htons(INADDR_ANY);32:..=htons(HELLO_WORLD_SERVER_PORT);//的流协议(TCP)socket,用server_socket代表服务器socketintserver_socket=socket(,SOCK_STREAM,0);if(server_socket<0){exit(1);}{intopt=1;setsockopt(server_socket,SOL_SOCKET,SO_REUSEADDR,&opt,sizeof(opt));}//把socket和socket地址结构联系起来if(bind(server_socket,(structsockaddr*)&server_addr,sizeof(server_addr))){exit(1);}//server_socket用于监听if(listen(server_socket,LENGTH_OF_LISTEN_QUEUE)){exit(1);}while(1)//服务器端要一直运行{//定义客户端的socket地址结构client_addrstructsockaddr_inclient_addr;socklen_tlength=sizeof(client_addr);//接受一个到server_socket代表的socket的一个连接//如果没有连接请求,就等待到有连接请求--ept函数的特性//accept函数返回一个新的socket,这个socket(new_server_socket)用于同连接到的客户的通信//new_server_socket代表了服务器和客户端之间的一个通信通道//accept函数把连接到的客户端信息填写到客户端的socket地址结构client_addr中intnew_server_socket=accept(server_socket,(structsockaddr*)&client_addr,&length);33:..if(new_server_socket<0){break;}charbuffer[BUFFER_SIZE];bzero(buffer,BUFFER_SIZE);length=recv(new_server_socket,buffer,BUFFER_SIZE,0);if(length<0){break;}charfile_name[FILE_NAME_MAX_SIZE+1];bzero(file_name,FILE_NAME_MAX_SIZE+1);strncpy(file_name,buffer,strlen(buffer)>FILE_NAME_MAX_SIZE?FILE_NAME_MAX_SIZE:strlen(buffer));//intfp=open(file_name,O_RDONLY);//if(fp<0)if(NULL==fp){}else{bzero(buffer,BUFFER_SIZE);intfile_block_length=0;//while((file_block_length=read(fp,buffer,BUFFER_SIZE))>0)while((file_block_length=fread(buffer,sizeof(char),BUFFER_SIZE,fp))>0){//发送buffer中的字符串到new_server_socket,实际是给客户端if(send(new_server_socket,buffer,file_block_length,0)<0){break;34:..}bzero(buffer,BUFFER_SIZE);}//close(fp);fclose(fp);}//关闭与客户端的连接close(new_server_socket);}//关闭监听用的socketclose(server_socket);return0;}#inet/>//forsockaddr_in#include<sys/>//forsocket#include<sys/>//forsocket#include<>//forprintf#include<>//forexit#include<>//forbzero/*#include<sys/>#include<sys/>#include<>#include<>*/#defineHELLO_WORLD_SERVER_PORT6666#defineBUFFER_SIZE1024#defineFILE_NAME_MAX_SIZE512intmain(intargc,char**argv){if(argc!=2){exit(1);35:..}//设置一个socket地址结构client_addr,地址,端口structsockaddr_inclient_addr;bzero(&client_addr,sizeof(client_addr));//=;//=htons(INADDR_ANY);//=htons(0);//0表示让系统自动分配一个空闲端口//的流协议(TCP)socket,用client_socket代表客户机socketintclient_socket=socket(,SOCK_STREAM,0);if(client_socket<0){exit(1);}//把客户机的socket和客户机的socket地址结构联系起来if(bind(client_socket,(structsockaddr*)&client_addr,sizeof(client_addr))){exit(1);}//设置一个socket地址结构server_addr,地址,端口structsockaddr_inserver_addr;bzero(&server_addr,sizeof(server_addr));=;if(inet_aton(argv[1],&)==0)//服务器的IP地址来自程序的参数{exit(1);}=htons(HELLO_WORLD_SERVER_PORT);socklen_tserver_addr_length=sizeof(server_addr);//向服务器发起连接,连接成功后client_socket代表了客户机和服务器的一个socket连接if(connect(client_socket,(structsockaddr*)&server_addr,server_addr_length)<0){exit(1);}36:..charfile_name[FILE_NAME_MAX_SIZE+1];bzero(file_name,FILE_NAME_MAX_SIZE+1);charbuffer[BUFFER_SIZE];bzero(buffer,BUFFER_SIZE);strncpy(buffer,file_name,strlen(file_name)>BUFFER_SIZE?BUFFER_SIZE:strlen(file_name));//向服务器发送buffer中的数据send(client_socket,buffer,BUFFER_SIZE,0);//intfp=open(file_name,O_WRONLY|O_CREAT);//if(fp<0)if(NULL==fp){exit(1);}//从服务器接收数据到buffer中bzero(buffer,BUFFER_SIZE);intlength=0;while(length=recv(client_socket,buffer,BUFFER_SIZE,0)){if(length<0){break;}//intwrite_length=write(fp,buffer,length);intwrite_length=fwrite(buffer,sizeof(char),length,fp);if(write_length<length){break;}37:..bzero(buffer,BUFFER_SIZE);}close(fp);//关闭socketclose(client_socket);return0;},只要在客户端建立一个帐号,双方就可以收发数据了。四、实验总结通过本次实验,我学会了在Linux操作系统下,设计服务端和客户端程序的基本方法,了解了socket通信的重要性,同时也复****了在《计算机网络》中学到的TCP、UDP、IP和端口等知识。38