- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
【最新资料】哈工大_软件学院_《并行程序设计》课程实验报告之三
《并行程序设计》课程实验报告
实验3:基于Intel Thread Checker和Profiler工具的多线程调试与调优
姓名 *** 院系 软件学院 学号 ********** 任课教师 张伟哲 指导教师 苏统华 实验地点 软件学院五楼机房 实验时间 2015-4-15 实验课表现 出勤、表现得分 实验报告
得分 实验总分 操作结果得分 一、实验目的 要求:需分析本次实验的基本目的,并综述你是如何实现这些目的的?
(1)掌握Intel Thread Checker 的基本功能、使用方法
(2)掌握多线程程序设计的基本调试方法
(3)掌握采用Intel Thread Checker 进行多线程程序调试的基本方法和步骤
(4)掌握Intel Thread Profiler 的基本功能、使用方法
(5)掌握多线程程序设计的基本调试方法
(6)掌握采用Intel Thread Profiler 进行多线程程序调试的基本方法和步骤
分析程序中潜在的数据竞争
分析程序死锁问题
三、线程安全性测试问题分析
四、Intel Thread Profiler 基础
五、负载平衡(Load Balance)问题分析
六、同步竞争问题分析
(2)
运行结果:
VTune 诊断结果
程序中,哪些变量可以作为线程中的共享变量?
r 和 round 可以作为共享变量,这两个变量在线程运行前就已经确定,并且不会再变化。
②哪些变量应该作为每个线程的私有变量?
线程内部定义的 i, j, start, end, tid 等变量属于私有变量、
③哪些变量出于线程的同步必须予以保护?
distx, disty, distz, dist 和 pot 出于线程同步的原因必须予以保护。
使用临界区对数据进行保护:
EnterCriticalSection(cs);
distx = pow( (r[0][j] - r[0][i]), 2 );
disty = pow( (r[1][j] - r[1][i]), 2 );
distz = pow( (r[2][j] - r[2][i]), 2 );
dist = sqrt( distx + disty + distz );
pot += 1.0 / dist;
LeaveCriticalSection(cs);
不再有冲突现象。把粒子和循环量改成之前单线程程序potential的数量,重新编译运行。运行结果如下
可见运行结果与单线程程序是一样的,但是相对单线程程序相比,性能提升不明显,主要原因是线程之间大量的发生竞争。
(2)
1. 运行结果
VTune 诊断结果:
分析:为什么不是每次都出现死锁问题?
死锁需要两个线程相互持有mutex同时请求对方持有的mutex,然后线程的执行顺序是不确定的,因此并不是每次执行都会出现死锁。
改动代码如下:
DWORD WINAPI work0 (void *arg)
{
Sleep(5000);
EnterCriticalSection( cs0 );
globalX++;
EnterCriticalSection( cs1 );
globalY++;
LeaveCriticalSection( cs1 );
LeaveCriticalSection( cs0 );
return 0;
}
DWORD WINAPI work1 (void *arg)
{
EnterCriticalSection (cs0);
globalX++;
EnterCriticalSection (cs1);
globalY++;
LeaveCriticalSection (cs1);
LeaveCriticalSection (cs0);
return 0;
}
int main (int argc, char *argv[])
{
HANDLE h[2];
DWORD rc;
InitializeCriticalSection (cs0);
InitializeCriticalSection (cs1);
printf (START\n);
h[0] = CreateThread (0, 0, work0, NULL, 0, NULL);
h[1] = CreateThread (0, 0, work1, NULL, 0, NULL);
rc = WaitForMultipleObjects (2, h, TRUE, INFINITE);
printf (TOTAL = (%d,%d)\n, glob
您可能关注的文档
- 【最新精选】2015年北京大兴区中考一模《化学》试题及答案.ppt
- 【最新】庆五一,爱岗敬业,鞠躬尽瘁先进模范事迹报告会活动总结.doc
- 【最新精选】中小企业绩效考核存在的问题与对策分析毕业论文.doc
- 【最新精选】保证金帐户资金不得划扣案例.doc
- 【最新精选】人教版小学二年级语文上册阅读短文练习题.doc
- 【最新精选】免费淘商城品牌入驻协议.doc
- 【最新精选】创业策划书-披萨小店.doc
- 【最新精选】单间手术室面积及净化级别等的确定.doc
- 【最新精选】初三英语时态汇总(一般现在时、一般将来时、一般过去时和现在进行时、过去进行时、现在完成时、过去完成时).doc
- 【最新精选】20160114家庭收纳技巧大全.doc
- 2025至2030中国PCP管道行业产业运行态势及投资规划深度研究报告.docx
- 2025至2030中国玻璃保温容器行业项目调研及市场前景预测评估报告.docx
- 2025至2030中国智能照明与控制行业项目调研及市场前景预测评估报告.docx
- 2025至2030中国软地板产品行业发展趋势分析与未来投资战略咨询研究报告.docx
- 2025至2030中国煤矿掘进机行业发展趋势分析与未来投资战略咨询研究报告.docx
- 2025至2030中国凸轮轴行业项目调研及市场前景预测评估报告.docx
- 2025至2030杂醇油行业运营态势与投资前景调查研究报告.docx
- 2025至2030中国镀铝纸行业发展趋势分析与未来投资战略咨询研究报告.docx
- 2025至2030中国铁镍合金行业市场运行分析及竞争格局与投资方向报告.docx
- 2025至2030中国钢带分拣机行业项目调研及市场前景预测评估报告.docx
最近下载
- 吸引眼球的单页高端简历模板下载 (5).doc VIP
- 优必选yanshee产品帮助手册-20180718.pdf VIP
- 2025上海市六年级升七年级暑假数学衔接讲义 第05讲 整式的加减 单元综合检测(难点)(解析版).docx VIP
- 危重患者小剂量胰岛素的使用及.ppt VIP
- 应知应会手册(医疗部分).pdf
- 益电通TD80变频器调试参数设置资料2.1.pdf
- 园艺植物种子生产教学课件.ppt VIP
- 认识情绪 管理情绪演示教学.ppt VIP
- 无忧传媒就业协议书.docx VIP
- 2025上海市六年级升七年级暑假数学衔接讲义 第04讲 整式的加减 单元综合检测(重点)(解析版).docx VIP
文档评论(0)