echo命令程序

echo命令程序,第1张

echo命令

(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)》里面的程序相互测试一下效果。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/8239960.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-14
下一篇 2023-04-14

发表评论

登录后才能评论

评论列表(0条)

保存