当前位置: 首页 > news >正文

操作系统原理实验报告

操作系统原理课程的实验报告汇总

实验三:线程的创建与撤销

实验环境:计算机一台,内装有VC++、office等软件

实验日期:2024.4.11

实验要求:

1.理解:Windows系统调用的基本概念,进程与线程的基本概念。

2.掌握:使用Windows系统调用创建与撤销线程的方法。

实验内容:

1.使用Windows系统提供的系统调用创建线程。

2.使用Windows系统提供的系统调用撤销线程。

3.使用Windows系统提供的系统调用挂起线程。

实验源代码


// 实验三:线程的创建与撤销.cpp : Defines the entry point for the console application.
//#include "stdafx.h"
#include "实验三:线程的创建与撤销.h"#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif/
// The one and only application objectCWinApp theApp;using namespace std;
void ThreadName1();
static HANDLE hHandle1 = NULL;
DWORD dwThreadID1;int _tmain(int argc, TCHAR* argv[], TCHAR* envp[])
{int nRetCode = 0;hHandle1 = CreateThread((LPSECURITY_ATTRIBUTES) NULL,0,(LPTHREAD_START_ROUTINE) ThreadName1,(LPVOID) NULL,0,&dwThreadID1);Sleep(5000);CloseHandle(hHandle1);ExitThread(0);return nRetCode;
}void ThreadName1()
{printf("xiancheng is Running\n");
}

实验总结:

代码没有任何问题,过编译不过运行是因为将VC++安装在了C盘,权限不够,将其重新安装在D盘即成功运行。

对于代码的一些注释:

HANDLE类型的hHandle1是用于存储线程返回句柄的变量

DWORD类型的dwThreadID1是用于存储线程标识符的变量

创建操作:CreateHandle方法中共需要6个变量,本次代码中第三个变量为创建一个名为ThreadName1的线程

挂起操作:Sleep(5000);将主线程挂起5秒

CloseHandle方法用于关闭句柄

撤销操作:ExitThread(0)方法用于撤销所有线程

实验四:线程的同步

实验环境:计算机一台,内装有VC++、office等软件

实验日期:2024.4.26

实验要求:

1.理解:线程同步的基本概念。

2.掌握:使用线程同步API实现多线程同步的方法。

实验内容:

1.使用Windows系统提供的系统调用创建与撤销线程。

2.使用Windows系统提供的线程同步API实现多线程同步。

3.使用Windows系统提供的线程同步API解决实际问题。

实验源代码

// 15 实验四:线程的同步.cpp : Defines the entry point for the console application.
//#include "stdafx.h"
#include "15 实验四:线程的同步.h"#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif/
// The one and only application objectCWinApp theApp;using namespace std;static HANDLE h1;
static HANDLE hHandle1 = NULL;
void func();int _tmain(int argc, TCHAR* argv[], TCHAR* envp[])
{int nRetCode = 0;DWORD dwThreadID1;DWORD dRes,err;hHandle1 = CreateSemaphore(NULL, 0, 1, "SemaphoreName1");if(hHandle1 == NULL) printf("Semaphore Create Fail\n");else printf("Semaphore Create Success\n");hHandle1 = OpenSemaphore(SYNCHRONIZE|SEMAPHORE_MODIFY_STATE,NULL,"SemaphoreName1");if(hHandle1 == NULL) printf("Semaphore Open Fail\n");else printf("Semaphore Open Success\n");h1 = CreateThread((LPSECURITY_ATTRIBUTES)NULL,0,(LPTHREAD_START_ROUTINE)func,(LPVOID)NULL,0,&dwThreadID1);if(h1==NULL) printf("Thread1 create Fail\n");else printf("Thread1 create Success\n");dRes = WaitForSingleObject(hHandle1,INFINITE);err = GetLastError();printf("WaitForSingleObject err =%d\n", err);if(dRes == WAIT_TIMEOUT) printf("TIMEOUT! dRes = %d\n", dRes);else if(dRes == WAIT_OBJECT_0) printf("WAIT_OBJECT! dRes = %d\n", dRes);else if(dRes == WAIT_ABANDONED) printf("WAIT_ABANDONED! dRes = %d\n", dRes);else printf("dRes = %d\n", dRes);CloseHandle(h1);CloseHandle(hHandle1);ExitThread(0);return nRetCode;
}void func()
{BOOL rc;DWORD err;printf("Now In Thread\n");rc = ReleaseSemaphore(hHandle1,1,NULL);err = GetLastError();printf("ReleaseSemaphore err = %d\n", err);if(rc == 0) printf("Semaphore Release Fail\n");else printf("Semaphore Release Successs! rc = %d\n",rc);
}

实验总结:

  1. h1是线程句柄,hHandle1是信号量句柄
  2. CreateSemaphore用于创建一个信号量
  3. OpenSemaphore打开信号量
  4. CreateThread创建子线程
  5. WaitForSingleObject主线程等待子线程结束
  6. ReleaseSemaphore(hHandle1,1,NULL)是子线程唤醒主线

 实验五:线程的互斥

实验环境:计算机一台,内装有VC++、office等软件

实验日期:2024.5.11

实验要求:

1.理解:线程互斥的基本概念。

2.掌握:使用线程互斥API及临界区实现多线程互斥的方法。

实验内容:

1.使用Windows系统提供的系统调用创建与撤销线程。

2.使用Windows系统提供的线程互斥API实现多线程互斥。

3.使用Windows系统提供的线程互斥API解决实际问题。

实验源代码

// 实验五:线程的互斥.cpp : Defines the entry point for the console application.
//#include "stdafx.h"
#include "实验五:线程的互斥.h"#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif/
// The one and only application objectCWinApp theApp;using namespace std;static int count = 5;
static HANDLE h1;
static HANDLE h2;
LPCRITICAL_SECTION hCriticalSection;
CRITICAL_SECTION Critical;
void func1();
void func2();int _tmain(int argc, TCHAR* argv[], TCHAR* envp[])
{int nRetCode = 0;DWORD dwThreadID1,dwThreadID2;hCriticalSection = &Critical;InitializeCriticalSection(hCriticalSection);h1 = CreateThread((LPSECURITY_ATTRIBUTES)NULL,0,(LPTHREAD_START_ROUTINE)func1,(LPVOID)NULL,0,&dwThreadID1);if(h1 == NULL) printf("Thread1 create Fail\n");else printf("Thread1 create Success\n");h2 = CreateThread((LPSECURITY_ATTRIBUTES)NULL,0,(LPTHREAD_START_ROUTINE)func2,(LPVOID)NULL,0,&dwThreadID2);if(h2 == NULL) printf("Thread2 create Fail\n");else printf("Thread2 create Success\n");Sleep(1000);CloseHandle(h1);CloseHandle(h2);DeleteCriticalSection(hCriticalSection);ExitThread(0);return nRetCode;
}void func2()
{int r2;EnterCriticalSection(hCriticalSection);r2 = count;_sleep(100);r2 = r2 + 1;count = r2;printf("count in func2 = %d\n", count);LeaveCriticalSection(hCriticalSection);
}void func1()
{int r1;EnterCriticalSection(hCriticalSection);r1 = count;_sleep(500);r1 = r1 + 1;count = r1;printf("count in func1 = %d\n", count);LeaveCriticalSection(hCriticalSection);
}

实验总结:

  1. EnterCriticalSection(…)进入临界区
  2. LeaveCriticalSection(…)退出临界区
  3. DeleteCriticalSection(…)删除临界区
  4. InitialCriticalSection(…)初始化临界区

实验六:系统内存使用统计

实验环境:计算机一台,内装有Visual Studio、office等软件

实验日期:2024.6.7

实验要求:

1.了解:Windows内存管理机制。

2.理解:页式存储管理技术,Windows内存管理基本数据结构。

3.掌握:Windows内存管理基本API的使用。

实验内容:

1.使用Windows系统提供的API和数据结构获取系统物理内存和虚拟内存信息。

2.分配及释放虚拟内存。

3.分配及释放物理内存。

4.当物理内存和虚拟内存空间发生变化时,分析产生变化的原因。

工程创建过程

勾选MFC 

实验源代码

// 实验六:系统内存使用统计.cpp : 定义控制台应用程序的入口点。
//#include "stdafx.h"
#include "实验六:系统内存使用统计.h"#ifdef _DEBUG
#define new DEBUG_NEW
#endif// 唯一的应用程序对象CWinApp theApp;using namespace std;
void GetMemSta(){MEMORYSTATUSEX MemInfo;MemInfo.dwLength = sizeof(MEMORYSTATUSEX);GlobalMemoryStatusEx(&MemInfo);printf("当前内存状态是:\n");printf("总物理内存大小:%dMB\n",MemInfo.ullTotalPhys/(1024*1024));printf("可用物理内存大小:%dMB\n",MemInfo.ullAvailPhys/(1024*1024));printf("总页文件大小:%dMB\n",MemInfo.ullTotalPageFile/(1024*1024));printf("可用页文件大小:%dMB\n",MemInfo.ullAvailPageFile/(1024*1024));printf("总虚拟内存大小:%dMB\n",MemInfo.ullTotalVirtual/(1024*1024));printf("可用虚拟内存大小:%dMB\n",MemInfo.ullAvailVirtual/(1024*1024));printf("内存利用率:%d\n",MemInfo.dwMemoryLoad);
}
int _tmain(int argc, TCHAR* argv[], TCHAR* envp[])
{int nRetCode = 0;LPVOID BaseAddr;GetMemSta();printf("现在分配300M的虚拟内存和200M的物理内存\n\n");BaseAddr=VirtualAlloc(NULL, 1024*1024*300,MEM_RESERVE|MEM_COMMIT,PAGE_READWRITE);if(BaseAddr==NULL) printf("虚拟内存分配失败\n");char * str = (char*)malloc(1024*1024*300);GetMemSta();printf("现在释放300M的虚拟内存和200M的物理内存\n\n");if(VirtualFree(BaseAddr,0,MEM_RELEASE)==0) printf("释放失败");free(str);GetMemSta();system("PAUSE");return nRetCode;
}

 实验结果:

相关文章:

  • 常用的rerank模型有哪些?都有什么优势?
  • AI(学习笔记第三课) 使用langchain进行AI开发(2)
  • Java原生结合MQTTX---完成心跳对话(附带源码)
  • Linux 进程等待
  • 数字化工厂中央控制室驾驶舱系统 API接口文档
  • 洛谷题目:P1673 [USACO05FEB] Part Acquisition S 题解(本题简)
  • python【扩展库】websockets
  • C 语言报错 xxx incomplete type xxx
  • STM32f103 标准库 零基础学习之按键点灯(不涉及中断)
  • 二叉搜索树讲解
  • Funplus 服务端开发实习 面经
  • robomaster机甲大师--电调电机
  • Transformer Decoder-Only 算力FLOPs估计
  • 仿真生成激光干涉包裹相位数据-用于深度学习训练!
  • 【信息系统项目管理师】第3章:信息系统治理 - 29个经典题目及详解
  • RHCSA Linux系统 Web页面 论坛 网盘的搭建
  • 架构思维:通用架构模式_怀疑下游的设计思路与最佳实践
  • 基于 TSBS 标准数据集下 TimescaleDB、InfluxDB 与 TDengine 性能对比测试报告
  • 花朵识别系统Python+深度学习+卷积神经网络算法+TensorFlow+人工智能
  • MySQL的索引分类
  • 上海市重大工程一季度开局良好,崇明线等按既定计划加快建设
  • 气候多米诺:厄尔尼诺与东南亚跨境害虫或威胁中国粮食安全
  • 中华人民共和国和巴西联邦共和国关于强化携手构建更公正世界和更可持续星球的中巴命运共同体,共同维护多边主义的联合声明
  • 反犹、资金与抗议:特朗普的施压如何撕裂美国大学?|907编辑部
  • 苹果或将于2027年推出由玻璃制成的曲面iPhone
  • 左娅︱悼陈昊