免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: newroot_phy
打印 上一主题 下一主题

[C] 百度的测试题 - 最后一题 [复制链接]

论坛徽章:
5
狮子座
日期:2013-08-20 10:12:24午马
日期:2013-11-23 18:04:102015年辞旧岁徽章
日期:2015-03-03 16:54:152015亚冠之德黑兰石油
日期:2015-06-29 18:11:1115-16赛季CBA联赛之新疆
日期:2024-02-21 10:00:53
11 [报告]
发表于 2014-07-11 15:00 |只看该作者
回复 10# cobras


    多核的时候,lock锁了总线,会影响其他核。

不过互斥锁也有问题,陷入内核总不会太快。

所以要么就futex,要么就上spinlock。spinlock在单核的情况下效率低(但也还好,无非就是空转用掉时间片然后导致nice提高),而futex貌似只有Linux有吧?反正就权衡一下呗。

最靠谱的还是直接用原子操作,很多这方面的库的,比如这个:https://github.com/mintomic/mintomic,再比如gcc的__sync系列函数等等。

论坛徽章:
44
15-16赛季CBA联赛之浙江
日期:2021-10-11 02:03:59程序设计版块每日发帖之星
日期:2016-07-02 06:20:0015-16赛季CBA联赛之新疆
日期:2016-04-25 10:55:452016科比退役纪念章
日期:2016-04-23 00:51:2315-16赛季CBA联赛之山东
日期:2016-04-17 12:00:2815-16赛季CBA联赛之福建
日期:2016-04-12 15:21:2915-16赛季CBA联赛之辽宁
日期:2016-03-24 21:38:2715-16赛季CBA联赛之福建
日期:2016-03-18 12:13:4015-16赛季CBA联赛之佛山
日期:2016-02-05 00:55:2015-16赛季CBA联赛之佛山
日期:2016-02-04 21:11:3615-16赛季CBA联赛之天津
日期:2016-11-02 00:33:1215-16赛季CBA联赛之浙江
日期:2017-01-13 01:31:49
12 [报告]
发表于 2014-07-11 17:13 |只看该作者
回复 11# starwing83

最靠谱的还是直接用原子操作

这在x86上还不是要锁总线

论坛徽章:
59
2015年亚洲杯之约旦
日期:2015-01-27 21:27:392015年亚洲杯之日本
日期:2015-02-06 22:09:41拜羊年徽章
日期:2015-03-03 16:15:432015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:50:282015元宵节徽章
日期:2015-03-06 15:50:392015年亚洲杯之阿联酋
日期:2015-03-19 17:39:302015年亚洲杯之中国
日期:2015-03-23 18:52:23巳蛇
日期:2014-12-14 22:44:03双子座
日期:2014-12-10 21:39:16处女座
日期:2014-12-02 08:03:17天蝎座
日期:2014-07-21 19:08:47
13 [报告]
发表于 2014-07-11 17:52 |只看该作者
回复 12# windoze

不锁总线如何原子?
   

论坛徽章:
59
2015年亚洲杯之约旦
日期:2015-01-27 21:27:392015年亚洲杯之日本
日期:2015-02-06 22:09:41拜羊年徽章
日期:2015-03-03 16:15:432015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:50:282015元宵节徽章
日期:2015-03-06 15:50:392015年亚洲杯之阿联酋
日期:2015-03-19 17:39:302015年亚洲杯之中国
日期:2015-03-23 18:52:23巳蛇
日期:2014-12-14 22:44:03双子座
日期:2014-12-10 21:39:16处女座
日期:2014-12-02 08:03:17天蝎座
日期:2014-07-21 19:08:47
14 [报告]
发表于 2014-07-11 17:53 |只看该作者
回复 9# starwing83
  1.     push 1
  2. setvalue x
复制代码
很不幸,这个其实是原子操作~~
虽然它看起来很不原子。

论坛徽章:
0
15 [报告]
发表于 2014-07-11 20:53 |只看该作者

论坛徽章:
0
16 [报告]
发表于 2014-07-11 20:55 |只看该作者
回复 4# hanxin83


    看来你认为他想考查的是: 临界区, 我跟你有相同的想法。

论坛徽章:
0
17 [报告]
发表于 2014-07-11 20:56 |只看该作者
回复 2# 井蛙夏虫


    为什么,A和D也都修改了变量X.

论坛徽章:
0
18 [报告]
发表于 2014-07-11 20:57 |只看该作者
回复 5# hellioncu


    给的正确答案是 A, B, C

论坛徽章:
0
19 [报告]
发表于 2014-07-11 20:59 |只看该作者
回复 6# hanzhenlll


所以你认为的也是互斥问题

如果是这样,那我们就要分析,哪些操作是原子的,不会被中断的,哪些会被中断

论坛徽章:
0
20 [报告]
发表于 2014-07-11 21:03 |只看该作者
本帖最后由 newroot_phy 于 2014-07-11 21:03 编辑

回复 7# super皮波


x = y 的汇编指令个数(应该是) > 1, 是否有材料证明这些语句之间是否会被中断呢?
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP