Chinaunix首页 | 论坛 | 博客
  • 博客访问: 567321
  • 博文数量: 493
  • 博客积分: 2891
  • 博客等级: 少校
  • 技术积分: 4960
  • 用 户 组: 普通用户
  • 注册时间: 2010-03-17 17:11
文章分类

全部博文(493)

文章存档

2010年(493)

分类:

2010-05-12 19:51:03

1 现象:问题描述
某程序从Windows移植到AIX环境下后,运行时,总是在进入pthread_mutex_lock函数后不返回。
2 关键过程:根本原因分析
此程序涉及到的数据结构如下:
Class A
{
char m_cValue;
CRITICAL_SECTION m_csLock;   // CRITICAL_SECTION是通过pthread_mutex_t实现
……….
}
像这样的定义无可厚非,但由于将程序从Windows移植到Unix时,将类A包含在一字节对齐的声明中,导致了问题。
虽然pthread_mutex_t中的结构不会受一定节对齐的影响(参见备注中的AIX下pthread_mutex_t结构定义),但pthread_mutex_lock函数却由于某些未知的原因导致阻塞。对于库函数底层的实现我们不得而知,在移植中发生多次类似的现象使我们总结出此经验。
3 结论:解决方案及效果
修改代码,将类A放到一字节对齐声明外面,问题得到解决。
4 经验总结:预防措施和规范建议
像锁这样的东西一般不会出现在消息中,不会涉及到需要一字节对齐这样的问题,不应包含在一字节对齐声明中。
如果将锁包含在一字节对齐声明中,没有经验的话,很难定位这样的问题:往往会误认为是死锁问题来定位。
5 备注
pthread_mutex_t在AIX下的定义如下:
typedef struct
{
#ifdef __64BIT__
        long    __mt_word[8];
#else
        int     __mt_word[13];
#endif /* __64BIT__ */
} pthread_mutex_t;
6 考核点
一字节对齐应用在锁变量上,可能会导致加锁函数不返回。
7 试题
以下结构不应该放在一字节对齐声明中的是(D)
A. 
Class A
{
char m_cValue;
int m_iValue;
}
B. 
Class A
{
char m_cValue;
unsigned long m_ulValue;
}
C. 
Class A
{
char m_cValue;
pthread_t m_ThradID;
unsigned long m_ulValue;
}
D. 
Class A
{
char m_cValue;
CRITICAL_SECTION m_csLock;   // CRITICAL_SECTION是通过pthread_mutex_t实现
unsigned long m_ulValue;
}
阅读(1059) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~