目前已经linux64位系统中g++4.4.7下发现了该bug。其他的版本还未测试。
经测试,如果传入wcsncpy函数第一个参数(即目标缓冲区)的地址不能被4整除的话就必定会发生段错误。
经调试,函数的汇编代码中有使用到movdqa指令,该指令要求参数必须内存对齐,如果参数(目标缓存区)不是内存对齐的,就会造成段错误.
#include <wchar.h> #pragma pack(1) struct Kom { char c; wchar_t s[32]; }; #pragma pack() int main(int argc, char** argv) { Kom kom; const wchar_t* k = L"Kom"; wcsncpy(kom.s, k, sizeof(kom.s) / sizeof(kom.s[0])); return 0; }
linux64位系统中g++4.4.7下使用wcsncpy函数有造成段错误的BUG(其他g++版本未知)
原文地址:http://blog.csdn.net/kibaamor/article/details/41248027