Chinaunix首页 | 论坛 | 博客
  • 博客访问: 722582
  • 博文数量: 182
  • 博客积分: 2088
  • 博客等级: 大尉
  • 技术积分: 1698
  • 用 户 组: 普通用户
  • 注册时间: 2009-12-16 15:09
个人简介

.

文章分类

全部博文(182)

文章存档

2016年(1)

2015年(18)

2014年(14)

2013年(20)

2012年(129)

分类: LINUX

2012-06-15 20:22:45

xchg并不是交换两值,看一部分:
#define xchg(ptr,v) ((__typeof__(*(ptr)))__xchg((unsigned long) \
                                         (v),(ptr),sizeof(*(ptr))))

static inline unsigned long __xchg(unsigned long x, 
                                  volatile void * ptr, int size)
{
    switch (size) {
        case 1:
            __asm__ __volatile__("xchgb %b0,%1"
                :"=q" (x)
                :"m" (*__xg(ptr)), "0" (x)
                :"memory");
            break;
        case 2:
            __asm__ __volatile__("xchgw %w0,%1"
                :"=r" (x)
                :"m" (*__xg(ptr)), "0" (x)
                :"memory");
            break;
        case 4:
            __asm__ __volatile__("xchgl %0,%1"
                :"=r" (x)
                :"m" (*__xg(ptr)), "0" (x)
                :"memory");
            break;
    }
    return x;
}

它只是将第二个参数x放入寄存器中与第一个指针参数所指的内容交换,返回所指内容原先的值。谈不上两数交换值。但是它可以“原子”的设置ptr所指内容并取出原值,这正是我们想要的。

可以参考一下下面小程序的结果:
#include
int main()
{
     int i = 1,j = 2;
     printf("i=%d, j=%d\n", i, j);
     printf("xchg:%d\n", xchg(&i, j));
     printf("i=%d, j=%d\n", i, j);
     return 0;
}

结果为:
i=1, j=2
xchg:1
i=2, j=2
阅读(1967) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~