一个测试字符串出现在
中 123-eee
它的名称:" inn "
我只想打印第一个 3 字符。
所有动作发生在这里:
strncpy(inn2, inn, 3);
printf(inn);
printf(inn2);
这实际上有效。它同时打印 inn 和 inn2 ,但如果我删除
printf(inn);
这个不会做的工作:
printf(inn2);
有什么问题?
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <netdb.h>
#include <arpa/inet.h>
#include <err.h>
#include <string.h>
char outt[15];
char inn[100];
char inn2[100];
int main()
{
int one = 1, client_fd;
struct sockaddr_in svr_addr, cli_addr;
socklen_t sin_len = sizeof(cli_addr);
int sock = socket(AF_INET, SOCK_STREAM, 0);
if (sock < 0)
err(1, "can't open socket");
setsockopt(sock, SOL_SOCKET, SO_REUSEADDR, &one, sizeof(int));
int port = 88;
svr_addr.sin_family = AF_INET;
svr_addr.sin_addr.s_addr = INADDR_ANY;
svr_addr.sin_port = htons(port);
if (bind(sock, (struct sockaddr *) &svr_addr, sizeof(svr_addr)) == -1) {
close(sock);
err(1, "Can't bind");
}
listen(sock, 5);
while (1) {
client_fd = accept(sock, (struct sockaddr *) &cli_addr, &sin_len);
ssize_t bytesRead = read(client_fd,inn,sizeof(inn) - 1);
if ( bytesRead > 0 )
{
inn[ bytesRead ] = ' ';
strncpy(inn2, inn, 3);
printf(inn);
printf(inn2);
}
snprintf(outt, sizeof outt, "%sn", inet_ntoa(cli_addr.sin_addr));
if (client_fd == -1) {
perror("Can't accept");
continue;
}
write(client_fd, outt, sizeof(outt) - 1); /*-1:' '*/
close(client_fd);
}
}
您只能打印字符串的前3个字符
printf("%.3s", inn);
提供了字符串至少3个字符,它不需要适当的nul终止字符串。
请记住,标准输出流是线条缓冲的,因此在打印新线字符或缓冲区完整之前,输出不会显示出来。在输出语句之后添加printf("n");
并查看是否有效。
-
strncpy(inn2, inn, 3);
如果inn
的第一个3
字节之间没有零字节,则将放置在inn2
中的字符串将不会被终止。因此,strncpy(inn2, inn, 3);
应遵循inn2[3] = ' '
-
printf(foo);
这样的代码通常表示错误,因为foo
可能包含%
字符。如果foo
来自不受信任的用户输入,则可能包含%n
,从而导致printf()
调用以写入内存并创建安全孔。改用printf("%s", foo);
。
inn2
必须为 null-termined printf()
?
char test_string[] = "Hello kitty!!!n";
printf("%.3s", test_string);
将仅打印字符串test_string
的三个第一个字符(或更短的字符串)。如果您不知道 priory 您需要打印的字符数:
printf("%.*s", number_of_char, test_string);
将完成工作。