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`"; char* command2 = "echo `uci get m_system.sim1.operator;uci get m_system.sim1.card_slot;uci get m_system.sim1.iccid; \ uci get m_system.sim2.operator;uci get m_system.sim2.card_slot;uci get m_system.sim2.iccid; \ uci get m_system.sim3.operator;uci get m_system.sim3.card_slot;uci get m_system.sim3.iccid; \ uci get m_system.sim4.operator;uci get m_system.sim4.card_slot;uci get m_system.sim4.iccid`"; SetGetTCPCommand("set", &command1); SetGetTCPCommand("set", &command2);一个程序执行这个代码,另一个进程执行这个代码while (1) { char* SendString = NULL; SetGetTCPCommand("get", &SendString);} 而SetGetTCPCommand程序放在公用库,这样get取值两个set都能取到么
时间: 2024-04-18 17:33:41 浏览: 110
如果`SetGetTCPCommand`程序放在一个公共库中,并且两个进程分别调用这个库中的函数,那么它们可以共享并获取到同一个TCPCommand的值。
这是因为在共享库中的静态变量(如`static char *TCPCommand`)是在进程的地址空间中唯一的,无论哪个进程调用该库中的函数,都会访问到同一个静态变量。
因此,当第一个进程调用`SetGetTCPCommand("set", &command1)`和`SetGetTCPCommand("set", &command2)`时,它们会设置TCPCommand的值。然后,第二个进程调用`SetGetTCPCommand("get", &SendString)`时,它可以获取到第一个进程设置的TCPCommand的值。
请注意,公共库中的静态变量和互斥锁(如`pthread_mutex_t mutex`)应该是线程安全的,以确保多个进程之间的正确同步和互斥操作。
希望这个解答对你有帮助!如果你还有其他问题,请随时提问。
相关问题
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")) { if (TCPCommand != NULL) { free(TCPCommand); } TCPCommand = malloc(strlen(*command) + 1); if (TCPCommand == NULL) { printf("Failed to set and obtain TCP command variable memory allocation\n"); goto fail; } strcpy(TCPCommand, *command); printf("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); printf("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* 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`"; char* command2 = "echo `uci get m_system.sim1.operator;uci get m_system.sim1.card_slot;uci get m_system.sim1.iccid; \ uci get m_system.sim2.operator;uci get m_system.sim2.card_slot;uci get m_system.sim2.iccid; \ uci get m_system.sim3.operator;uci get m_system.sim3.card_slot;uci get m_system.sim3.iccid; \ uci get m_system.sim4.operator;uci get m_system.sim4.card_slot;uci get m_system.sim4.iccid`"; SetUpTCPtoSendInformation(setExeCmd,&command1);SetUpTCPtoSendInformation(setExeCmd,&command2);另一个是whlie(1){SetUpTCPtoSendInformation("get", &SendString);}请问同时运行这两个进程get能获取到这两个set的值,如果娶不到请帮我优化程序
根据给出的代码,同时运行这两个进程时,第一个进程执行`SetUpTCPtoSendInformation(setExeCmd, &command1)`会设置TCPCommand的值,第二个进程执行`SetUpTCPtoSendInformation(setExeCmd, &command2)`也会设置TCPCommand的值。但是,在第二个进程执行`SetUpTCPtoSendInformation("get", &SendString)`时,由于第一个进程已经将TCPCommand的值释放并设为NULL,因此第二个进程无法获取到第一个进程设置的值。
为了优化程序,可以使用线程间共享的全局变量来存储TCPCommand的值,而不是在`SetUpTCPtoSendInformation`函数内部使用静态变量。这样,两个进程就可以共享该全局变量的值。
以下是一个修改后的示例代码:
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <pthread.h>
static char *TCPCommand = NULL;
static pthread_mutex_t mutex = P_MUTEX_INITIALIZER;
int SetTCPCommand(char *command) {
pthread_mutex_lock(&mutex); // 加锁
if (TCPCommand != NULL) {
free(TCPCommand);
}
TCPCommand = malloc(strlen(command) + 1);
if (TCPCommand == NULL) {
printf("Failed to allocate memory for TCP command\n");
pthread_mutex_unlock(&mutex); // 解锁
return 0;
}
strcpy(TCPCommand, command);
printf("set: %s\n", TCPCommand);
pthread_mutex_unlock(&mutex); // 解锁
return 1;
}
int GetTCPCommand(char **command) {
pthread_mutex_lock(&mutex); // 加锁
if (TCPCommand == NULL || strlen(TCPCommand) == 0) {
printf("TCP command is empty\n");
pthread_mutex_unlock(&mutex); // 解锁
return 0;
}
*command = malloc(strlen(TCPCommand) + 1);
if (*command == NULL) {
printf("Failed to allocate memory for command\n");
pthread_mutex_unlock(&mutex); // 解锁
return 0;
}
strcpy(*command, TCPCommand);
printf("get: %s\n", *command);
free(TCPCommand);
TCPCommand = NULL;
pthread_mutex_unlock(&mutex); // 解锁
return 1;
}
```
同时运行这两个进程时,第一个进程可以调用`SetTCPCommand`函数设置TCPCommand的值,第二个进程可以调用`GetTCPCommand`函数获取到第一个进程设置的值。
希望这个优化后的代码对你有帮助!如果你还有其他问题,请随时提问。
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);程序对么,指针可以第二次赋值么
根据您提供的代码,第一个调用 `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` 指针已经被初始化为正确的字符串地址。
希望这可以帮助到您!如果您有任何其他问题,请随时提问。
阅读全文