- 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
[2016必威体育精装版精品]哈工大_软件学院_《并行程序设计》课程实验报告之三
《并行程序设计》课程实验报告 实验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
您可能关注的文档
- (必威体育精装版)吉林省林区医院手术室净化工程设计方案.doc
- (必威体育精装版整理)建设工程施工劳务内部承包合同(班组劳务合同).doc
- (必威体育精装版整理)绿化施工质量保证体系.doc
- (必威体育精装版整理)某餐饮管理公司绩效考核管理制度(46P).doc
- (必威体育精装版整理)高层住宅沉降观测招标文件.doc
- (必威体育精装版整理)武清区医疗质量与安全管理及持续改进方案与质量考核标.doc
- (答辩PPT)基于单片机的温湿度控制系统设计.ppt.ppt
- (精选文档)二级综合医院评审标准(2012年版)实施细则 麻醉科.doc
- (精选文档)技术研发人员KPI绩效量化指标考核.doc
- (精选文档)职业健康安全管理体系的2001与2007版本对照.doc
- [doc] 浅谈临床科室配合手术室做好心理护理改善术前焦虑.doc
- [doc] 朱丹溪论治血证特色探析.doc
- [doc] 用脉冲数分布作为诊断方法评价旋转电机绝缘的老化水平.doc
- [DOC] 认真贯彻上级文件精神努力开创基层统战工作新局面.doc
- [DOC]-GMAT阅读真题解析(英吉GMAT每日一题).doc
- [DOC]-2015二级建造师复习重点总结(施工管理、第四版法律法规及机电实务部分).doc
- [DOC]-国有集团公司全面风险管理制度规定DOC-风险管理.doc
- [DOC]-必威体育精装版最全食品安全认证QS手册(18个文件)食品质量安全管理简明手册(QS生产许可重要文档)-品质管理.doc
- 1第一节 地貌成因与地貌类型地貌的定义.ppt
- [DOC]-文本编辑器c 实验报告附源代码.doc
文档评论(0)