C++:执行i++时,汇编是怎么操作的

int main(int argc, char* argv[])
{
	int i = 1;
	i = i + 1;
	return 0;
}

首先设置一个断点,然后转到反汇编

 这里的dword表示双字,即四字节,ptr表示指针。eax是一个寄存器。

假如有两个线程同时操作一个全局变量i自加,是什么样子?理想情况下应该是下面这个样子

 但实际情况下(线程没有加锁的时候),有可能会是这个样子

 我预期应该是i的值为12,实际却为11。

每个线程都有它自己的一组CPU寄存器和它自己的堆栈。
每个线程都有它自己的堆栈好理解。CPU的寄存器只有一组吧,如何理解每个线程都有它自己的一组CPU寄存器?

这里说的一组不是物理上的,而是逻辑上的,即每个线程都有一块地址,在线程让出CPU所有权时用来保存cpu各个寄存器的值,好在线程重新拥有cpu的时候恢复运行状态。

CPU切换前把当前任务的状态保存下来,以便下次切换回这个任务时可以再次加载这个任务的状态,然后加载下一任务的状态并执行。任务的状态保存及再加载, 这段过程就叫做上下文切换。

每个线程都有一个程序计数器(记录要执行的下一条指令),一组寄存器(保存当前线程的工作变量),堆栈(记录执行历史,其中每一帧保存了一个已经调用但未返回的过程)。

寄存器 是 CPU 内部的数量较少但是速度很快的内存(与之对应的是 CPU 外部相对较慢的 RAM 主内存)。寄存器通过对常用值(通常是运算的中间值)的快速访问来提高计算机程序运行的速度。

程序计数器是一个专用的寄存器,用于表明指令序列中 CPU 正在执行的位置,存的值为正在执行的指令的位置或者下一个将要被执行的指令的位置。

 这就引出了锁。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值