linux 编程中出现中断 [send_mutex_lock()]:[128]: mutex is null!
时间: 2023-06-15 17:03:01 浏览: 48
这个错误提示表明在调用 send_mutex_lock() 函数时,传入的 mutex 参数为 NULL,因此无法对 NULL 进行加锁操作。需要检查代码中是否正确地初始化了 mutex 变量,并在调用 send_mutex_lock() 函数前,确保 mutex 变量已经被正确地赋值。如果 mutex 变量在调用 send_mutex_lock() 函数前没有被正确地初始化,则需要对其进行初始化。
相关问题
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); TCPCommand = NULL; CON_LOG("33\n"); } CON_LOG("33\n"); TCPCommand = malloc(strlen(*command) + 1); CON_LOG("33\n"); strcpy(TCPCommand, *command); 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"); CON_LOG("set:%s\n", TCPCommand); isFirstCall = 0; goto succeed; } else if (!isFirstCall && strstr(option, "get") && TCPCommand != NULL && strlen(TCPCommand)) { CON_LOG("33"); 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 { if(!isFirstCall) CON_LOG("!isFirstCall"); if(strstr(option, "get")) CON_LOG("strstr(option, \"get\")"); if(TCPCommand != NULL) CON_LOG("TCPCommand != NULL"); if(strlen(TCPCommand)) CON_LOG("strlen(TCPCommand)"); *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; }为什么我调用SetUpTCPtoSendInformation("get", &SendString)没有进else if判断里面而是走进else里面 ,else里面输出!isFirstCall,TCPCommand != NULL,strlen(TCPCommand),CON_LOG为printf
根据你提供的代码,当调用 `SetUpTCPtoSendInformation("get", &SendString)` 时,没有进入 `else if` 判断而是走进了 `else` 分支,输出了 `!isFirstCall`、`TCPCommand != NULL` 和 `strlen(TCPCommand)` 的日志。
这是因为在你的条件判断语句中,由于 `isFirstCall` 的初始值为1,在第一次调用 `SetUpTCPtoSendInformation` 函数时会进入 `if (isFirstCall && strstr(option, "set"))` 分支。这会将 `isFirstCall` 设置为0,并在成功设置 TCPCommand 后跳转到 `succeed` 标签处。
在第二次调用 `SetUpTCPtoSendInformation` 函数时,由于 `isFirstCall` 不再为1,因此不会进入 `if (isFirstCall && strstr(option, "set"))` 分支,而是进入 `else if (!isFirstCall && strstr(option, "get") && TCPCommand != NULL && strlen(TCPCommand))` 分支。但根据你的描述,它似乎没有进入该分支。
这可能是由于 `TCPCommand` 的长度为0,导致条件 `strlen(TCPCommand)` 不满足而没有进入分支。你可以在调试时添加一些打印语句来检查 `TCPCommand` 的值和长度是否符合预期。
另外,请确保在调用 `SetUpTCPtoSendInformation` 函数之前,`TCPCommand` 已经被正确地初始化为指向有效内存的指针。
希望这些信息可以帮助你找到问题所在。如果你有更多的问题,请随时提问。
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; } memset(*command, 0, sizeof(*command)); strcpy(*command, ""); fail: pthread_mutex_unlock(&mutex); // 解锁 return 0; succeed: pthread_mutex_unlock(&mutex); // 解锁 return 1; } char *SendString = NULL; SetUpTCPtoSendInformation("get",&SendString); if(SendString == NULL && strlen(SendString)){ }程序有误
根据你提供的代码,我注意到在调用 `SetUpTCPtoSendInformation("get", &SendString)` 后,你正在检查 `SendString` 是否为 `NULL` 并且长度是否为零。这是一个逻辑错误。如果 `SendString` 为 `NULL`,则无法访问其长度。
你可以更改代码如下:
```c
char *SendString = NULL;
int result = SetUpTCPtoSendInformation("get", &SendString);
if (result && SendString != NULL && strlen(SendString) > 0) {
// 在这里执行发送 SendString 的操作
printf("SendString: %s\n", SendString);
} else {
printf("Failed to obtain SendString\n");
}
```
这样,你可以在 `SetUpTCPtoSendInformation` 函数中根据条件设置 `SendString` 的值,并在返回成功时执行发送操作。请确保在使用 `SendString` 之前检查其是否为 `NULL`,以避免访问空指针错误。