2024-2025学年下学期期末
2025春季学期并行程序设计期末考试试卷(回忆版)
选择题
选择题都较简单, 不做记录.
填空题
-
均匀储存访问模型中, 处理器访问储存器的时间____, 物理储存器被所有处理器____, 每台处理器带____缓存.
-
MPI的点到点通信模式包括:标准通信____, ____, ____, ____.
-
四种循环转换包括:循环交换, 循环分块, ____, ____.
-
MPI集合通信的三个主要功能是:通信, ____, ____.
简答题
-
简述 OpenMP 的 Fork-Join 工作模式.
-
分布式内存系统与共享内存系统的核心区别是什么?
-
MPI阻塞接收与非阻塞接收的区别是什么?
-
临界区嵌套会导致什么问题? 如何解决?
-
简述信号量(Semaphore)实现 Barrier 的方法.
编程题
-
哲学家用餐问题, 如何用互斥锁与信号量解决哲学家用餐问题, 保证不会出现死锁和饥饿? (注:此题只需写伪代码, 不需要严格的参照接口定义)
-
多个进程分别拥有私有的数组, 现在要计算各个进程中所有数组元素的平均值.
使用MPI_Allreduce实现函数void Global_average(double loc_arr[], int loc_n, MPI_Comm comm, double* global_avg), 先计算局部总和与元素总数, 再归约计算全局总和与总元素数, 最后算平均值, 运行结束后所有进程中的global_avg都应该储存相同的结果, 即全局平均值.
(其中loc_arr[]为每个进程拥有的局部数组, loc_n 为局部数组的大小, comm 为通讯器, global_avg 储存最终结果)
(注:本题下方提供了会用到的 MPI 函数定义以供查阅, 不需要特意背诵接口. 不过奇怪的是考试中唯独没有提供 MPI_Allreduce 的定义, 比较诡异)