static char *TCPCommand; static pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER; int SetUpTCPtoSendInformation(char option[], char **command) { static int isFirstCall = 1; pthread_mutex_lock(&mutex); // 加锁 if (isFirstCall && strstr(option, "set")) { CON_LOG("33\n"); if (TCPCommand != NULL) { free(TCPCommand); CON_LOG("33\n"); } CON_LOG("33\n"); TCPCommand = malloc(strlen(*command) + 1); CON_LOG("33\n"); if (TCPCommand == NULL) { printf("Failed to set and obtain TCP command variable memory allocation\n"); goto fail; } CON_LOG("33\n"); strcpy(TCPCommand, *command); CON_LOG("set:%s\n", TCPCommand); isFirstCall = 0; goto succeed; } else if (!isFirstCall && strstr(option, "get") && TCPCommand != NULL && strlen(TCPCommand)) { free(*command); *command = malloc(strlen(TCPCommand) + 1); strcpy(*command, TCPCommand); CON_LOG("get:%s\n", *command); memset(TCPCommand, '\0', strlen(TCPCommand)); free(TCPCommand); TCPCommand = NULL; isFirstCall = 1; goto succeed; }else { *command = malloc(1); if (*command == NULL) { CON_LOG("Failed to allocate memory for command\n"); goto fail; } **command = '\0'; CON_LOG("Invalid option\n"); goto fail; } fail: pthread_mutex_unlock(&mutex); // 解锁 return 0; succeed: pthread_mutex_unlock(&mutex); // 解锁 return 1; }char* command = "echo `uci get m_system.usesiminfo.operator;uci get m_system.usesiminfo.card_slot; \ uci get m_system.usesiminfo.iccid;uci get m_system.usesiminfo.lock;uci get m_system.system.simnum`"; SetUpTCPtoSendInformation("set", &command);char* command = "echo `uci get m_system.usesiminfo.operator;uci get m_system.usesiminfo.card_slot; \ uci get m_system.usesiminfo.iccid;uci get m_system.usesiminfo.lock;uci get m_system.system.simnum`"; SetUpTCPtoSendInformation("set", &command);程序对么,指针可以第二次赋值么
时间: 2024-04-13 14:29:56 浏览: 128
C++11中的mutex, lock, condition variable实现分析
5星 · 资源好评率100%
根据您提供的代码,第一个调用 `SetUpTCPtoSendInformation("set", &command)` 是有效的,因为在第一次调用时,`TCPCommand` 指针是空的,可以进行动态内存分配和赋值。但是在第二次调用中,由于 `TCPCommand` 在第一次调用中已经被赋值并释放,再次对其进行赋值可能会导致错误。
如果您希望多次调用 `SetUpTCPtoSendInformation` 函数来设置不同的命令,您可以通过重新分配内存来处理。在每次调用之前,先释放 `TCPCommand` 指向的内存块,并将其置为 NULL,然后再进行动态内存分配和赋值。
以下是相应的修改代码示例:
```c
char* command1 = "echo `uci get m_system.usesiminfo.operator;uci get m_system.usesiminfo.card_slot; \
uci get m_system.usesiminfo.iccid;uci get m_system.usesiminfo.lock;uci get m_system.system.simnum`";
SetUpTCPtoSendInformation("set", &command1);
// 进行其他操作...
char* command2 = "其他命令";
if (TCPCommand != NULL) {
free(TCPCommand);
TCPCommand = NULL;
}
SetUpTCPtoSendInformation("set", &command2);
// 继续其他操作...
```
在第二次调用之前,我们首先释放 `TCPCommand` 指向的内存,并将其置为 NULL。然后再次调用 `SetUpTCPtoSendInformation` 函数来设置新的命令。
这样做可以确保在每次调用之前进行必要的内存管理,避免悬空指针和内存泄漏问题。
请注意,在每次调用 `SetUpTCPtoSendInformation` 函数之前,确保 `command` 指针已经被初始化为正确的字符串地址。
希望这可以帮助到您!如果您有任何其他问题,请随时提问。
阅读全文