我的程序有问题。我在无限循环中从stdin读取它工作正常但是当我将超过4096个字符放入stdin时它开始表现不好我不是真的为什么。是getc有限?我会把你放在这里输入和输出多个ilustust
#define NFDS 1
#define h_addr h_addr_list[0]
#define BUFFER_LEN 4096
void *sending(void *arguments)
{
struct arg_struct *args = arguments;
int i = 0, j = 1;
if(signal(SIGINT, receive_signal) == SIG_ERR) {
fprintf(stderr, "Error setting signal handler for SIGINT.\n");
}
fd_set myset;
struct timeval tim;
int result;
int data_cap = 4096;
while(running)
{
tim.tv_sec = 0;
tim.tv_usec = 500;
FD_ZERO(&myset);
FD_SET(STDIN_FILENO, &myset);
result = select(STDIN_FILENO + 1, &myset, NULL, NULL, &tim);
if(result != 0)
{
str = calloc(data_cap,sizeof(char));
while((c = getc(stdin)) != '\n')
{
if (j >= data_cap)
{
str = realloc(str,sizeof(char) * data_cap * 2);
data_cap = data_cap * 2;
}
str[i] = c;
i++;
j++;
}
if (j >= data_cap)
{
str = realloc(str,sizeof(char) * data_cap * 2);
}
str[i] = '\0';
if(strlen(str)!=0)
{
bufferIn = message(args->arg2,str);
if(send(args->arg1,bufferIn,strlen(bufferIn),0) < 0)
{
callError("ERROR: cannot send socked");
}
free(bufferIn);
}
free(str); i = 0; j = 1; data_cap = 4096;
}
}
return NULL;
}
//in main threads
struct arg_struct args;
args.arg1 = client_socket;
args.arg2 = username;
pthread_t t22;
pthread_t t11;
pthread_create(&t22, NULL, &sends, (void *)&args);
pthread_create(&t11, NULL, &reci, (void *)&args);
pthread_join(t22, NULL);
pthread_cancel(t22);
pthread_join(t11, NULL);
pthread_cancel(t11);
输入例如:aaaaaaaa .....aaaaaaaa这是这个词
让我们想象有4096&#39; a&#39;按照第一个&#39; a&#39;顺序排列的字符持续的#39; 但是当我打印出我从stdin得到的东西时,我得到了这个:
这是这个词 aaaaaa ...... aaaaaa这就是这个词它真正做的是起初,它读取所有字符形式4096. char。在这个例子中它是&#34;这是词#34;并先打印出来。它确实打印了它应该首先打印的内容。
在行符号的无末尾的所有字符之间 起初我认为内存分配有一些不好因为我将乳房放在4096字节,但没有。我测试了它。 求你帮忙 抱歉英文不好
答案 0 :(得分:0)
这更像是一个答案的评论,但因为很长时间我在这里发布了它。
其他一些必须是错误的,因为将“有问题”的部分隔离为:
char c;
int i=0, j=1, data_cap=4096;
char *str = calloc(data_cap,sizeof(char));
while((c = getc(stdin)) != '\n') {
if (j >= data_cap) {
str = realloc(str,sizeof(char) * data_cap * 2);
data_cap = data_cap * 2;
}
str[i] = c;
i++;
j++;
}
if (j >= data_cap) {
str = realloc(str,sizeof(char) * data_cap * 2);
}
str[i] = '\0';
if(strlen(str)!=0) {
char *bufferIn = message("test",str);
printf("%s\n",bufferIn);
free(bufferIn);
}
free(str); i = 0; j = 1; data_cap = 4096;
效果很好。
由于你没有告诉我们函数的论证是什么,我们不能说更多......