为什么char指针会被自动清除?

时间:2012-09-02 13:43:42

标签: c pointers

这是我的代码:

tmpip = get_public_ip();
pubip = strtok(tmpip, "\n");
sprintf(buffer, "220 FTPUtils Server [%s]", pubip);
len_string = strlen(buffer)+1;
if(send(newsockd, &len_string, sizeof(len_string), 0) < 0){
    perror("Errore invio len buffer");
    onexit(newsockd, sockd, 0, 2);
}
if(send(newsockd, buffer, len_string, 0) < 0){
    perror("Errore durante l'invio");
    onexit(newsockd, sockd, 0, 2);
}
pubip = NULL;
free(tmpip);
memset(buffer, 0, sizeof(buffer));


if(recv(newsockd, &len_string, sizeof(len_string), MSG_WAITALL) < 0){
    perror("Errore ricezione len user buffer");
    onexit(newsockd, sockd, 0, 2);
}
if(recv(newsockd, buffer, len_string, 0) < 0){
    perror("Errore ricezione del nome utente");
    onexit(newsockd, sockd, 0, 2);
}       
user_string = strtok(buffer, " ");
username = strtok(NULL, "\n");
fprintf(stdout, "%s %s\n", user_string, username);
sprintf(saved_user, "%s", username);
memset(buffer, 0, sizeof(buffer));

if(recv(newsockd, &len_string, sizeof(len_string), MSG_WAITALL) < 0){
    perror("Errore ricezione len pass buffer");
    onexit(newsockd, sockd, 0, 2);
}
if(recv(newsockd, buffer, len_string, 0) < 0){
    perror("Errore ricezione password");
    onexit(newsockd, sockd, 0, 2);
}
pass_string = strtok(buffer, " ");
password = strtok(NULL, "\n");
fprintf(stdout, "%s %s\n", pass_string, password);
memset(buffer, 0, sizeof(buffer));

printf("%s %s\n", username, password);

我上次调试时遇到问题printf:它打印到stdout 没有 !!
为什么我的指针(用户名和密码)被清除?
这很奇怪,因为2 fprintf完美无缺,但最后printf没有...

1 个答案:

答案 0 :(得分:5)

usernamepassword 都指向buffer 内的位置。这就是strtok的工作方式。

换句话说,当您使用memset将缓冲区归零时,您将usernamepassword指向的内存清零。一个简单的解决方法是复制该内存:

username = strtok(NULL, "\n");
username = strdup(username);

注意strdup不是标准的,但使用mallocstrcpy很容易实现。