(1)功能:打开或关闭命令回显(即命令运行时的显示)/显示信息
(2)语法:echo [{on|off}] [message]
(3)参数:on 打开命令回显。
off 关闭命令回显。
message 指定要显示的文本激乱拆(例:执行“@echo This a ECHO command.”,显示“This a ECHO command.”)。
(4)特殊用法:“echo”不带任何参数将显示当前回显设置。“echo.”显示一个空行。
echo好像还有些复杂的用法,明枣但作为作业应该只是实现回显吧。
你的程序只能一个字符一个字符的输入,要一次回显应该用带参数的main:陪戚
void main(int argc ,char *argv[])
{
for (int i=1i<argci++)
cout<<argv[i]<<' '
cout<<endl
}
下面将实现一个简单的TCP回射服务器,即从客户端收到什么数据,就发送什么数据。[cpp] view plain copy
#include <stdio.h>
#include <string.h>
#include <unistd.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <stdlib.h>
#define BUFFER_SIZE 1024
int main(int argc, char** argv)
{
if(argc != 2)
{
printf("Usage:\n%s <port>"隐改, argv[0])
return 0
}
struct sockaddr_in myAddr, clientAddr
int socketFd, clientFd
unsigned int clientAddrLen = sizeof(clientAddr)
int receivedLength
char buffer[BUFFER_SIZE]
memset(&clientAddr, 0, sizeof(clientAddr))
memset(&myAddr, 0, sizeof(myAddr))
myAddr.sin_family = AF_INET
myAddr.sin_port = htons(atoi(argv[1]))
myAddr.sin_addr.s_addr = htonl(INADDR_ANY)
socketFd = socket(AF_INET, SOCK_STREAM, 0)
bind(socketFd, (struct sockaddr*)&myAddr, sizeof(myAddr))
listen(socketFd, 5)
clientFd = accept(socketFd, (struct sockaddr *)&clientAddr, &clientAddrLen)
receivedLength = recv(clientFd, buffer, BUFFER_SIZE, 0)
buffer[receivedLength] = '\0'
printf("Received a message from %s:%u:\n%s\n"
, inet_ntoa(clientAddr.sin_addr)
, ntohs(clientAddr.sin_port),buffer)
send(clientFd, buffer, receivedLength, 0)
close(clientFd)
close(socketFd)
return 0
}
假设这个程序的名字是TcpServer,在编译好的可执行文件的目录下,输入:./TcpServer 2333启动服务器程序
然后使用netcat来向它发起来接:nc 127.0.0.1 2333
在netcat里输入一些字符,按回车以后,可以在TcpServer的输出中看到皮携拍收到的数据,在netcat里可以看到服务器返回的数据燃羡。
也可以和《Linux网络编程(1)》里面的程序相互测试一下效果。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)