gpt4 book ai didi

c++ - 为什么 _stprintf_s 会覆盖其他变量而 _stprintf 不会?

转载 作者:太空狗 更新时间:2023-10-29 20:38:48 27 4
gpt4 key购买 nike

我在 win32 编程课上使用 visual studio。我有一个声明为 TCHAR **bufTh 的全局字符串数组,分配在内存中,如

bufTh = (TCHAR**)malloc(nOfTh*sizeof(TCHAR*));
for (i = 0; i < nOfTh; i++)
bufTh[i] = (TCHAR*)malloc(BUF_LEN*sizeof(TCHAR));

然后我有一些线程,每个线程都写入此数组中的不同字符串。我注意到如果我使用 _stprintf_s(bufTh[iTh], BUF_LEN, _T("%s\\"), findData.cFileName);,在这个操作之后,一些其他的全局变量(在我的例子中信号量)被覆盖,而如果我使用 _stprintf(没有 _s)一切顺利。

为什么?我哪里错了?

我还尝试使用包含字符串的结构数组作为实验,例如 typedef struct{TCHAR buf[BUF_LEN];} mystr_t; 然后分配 bufTh = (mystr_t*) malloc(nOfTh*sizeof(mystr_t));。在这种情况下,_stprintf_s 按预期工作,没有问题。

编辑:这是一个 mcve

#define UNICODE
#define _UNICODE
#define _CRT_SECURE_NO_WARNINGS
#define _CRT_NON_CONFORMING_SWPRINTFS
#include <Windows.h>
#include <tchar.h>
#include <stdio.h>
#include <stdlib.h>
#define BUF_LEN _MAX_PATH+1

typedef struct{
DWORD iTh;
} tdata_t;

TCHAR **bufTh;
PHANDLE sem;

//DWORD WINAPI rThread(LPVOID pThParam);

int _tmain(int argc, LPTSTR argv[]){
DWORD i, nOfTh;
PHANDLE hthread;
tdata_t *tdata;

nOfTh = 1;

// global array of buffers, one for each reading thread
bufTh = (TCHAR**)malloc(nOfTh*sizeof(TCHAR*));
for (i = 0; i < nOfTh; i++)
bufTh[i] = (TCHAR*)malloc(BUF_LEN*sizeof(TCHAR));

// array of thread data, to pass to threads
tdata = (tdata_t*)malloc(nOfTh*sizeof(tdata_t));
for (i = 0; i < nOfTh; i++){
tdata[i].iTh = i;
}

// array of semaphores, one for each thread
sem = (PHANDLE)malloc((nOfTh)*sizeof(HANDLE));
for (i = 0; i < nOfTh; i++)
sem[i] = CreateSemaphore(NULL, 0, 1, NULL);

// array of threads
/*hthread = (PHANDLE)malloc(nOfTh*sizeof(HANDLE));
for (i = 0; i < nOfTh; i++)
hthread[i] = CreateThread(NULL, 0, &rThread, (LPVOID)&tdata[i], 0, NULL);*/

i = 0;
// BREAKPOINT HERE
_stprintf_s(bufTh[i], BUF_LEN, _T("%s\\"), _T("the string that I want to write there"));
// BREAKPOINT HERE
WaitForSingleObject(sem[i], INFINITE);



//WaitForMultipleObjects(nOfTh, hthread, TRUE, INFINITE);
system("pause");
return 0;
}

最佳答案

also in my runs semaphores are overwritten with value 0xfefefefe

这是一个“魔法值”,它是由安全的 CRT 函数(如 _stprintf_s)编写的,可帮助您调试传递的缓冲区长度中的错误。这些函数的调试构建填充了整个缓冲区,使用 0xfe 作为填充值。

   _stprintf_s(bufTh[i], BUF_LEN, ...));

所以您知道的是 thBuf[0] 的缓冲区大小实际上不是 BUF_LEN。换句话说,malloc() 调用不正确。

   #define BUF_LEN _MAX_PATH+1

这是一个邪恶的宏,会导致您的问题。它扩展为

   bufTh[i] = (TCHAR*)malloc(_MAX_PATH + 1*sizeof(TCHAR));

当然不是你的意思。修复:

   #define BUF_LEN (_MAX_PATH+1)

额外的括号很关键。否则,这是开始使用 const 关键字的一个很好的理由。

关于c++ - 为什么 _stprintf_s 会覆盖其他变量而 _stprintf 不会?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30479199/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com