基于Tcp实现简单网络英译汉功能

这里就实现简单英译汉的功能(手动翻译嘻嘻嘻嘻,勿怪),既然需要把单词和翻译一一对应起来,这里就可以接需要借用map容器。搭建服务器端与客户端,然后让其进行通信(这里用Tcp)。
接下来就直接上代码:
服务端:Server.cc

#include<iostream>
#include<map>
#include<unistd.h>
#include<string>
#include<sys/types.h>
#include<sys/socket.h>
#include<stdlib.h>
#include<arpa/inet.h>
using namespace std;
map<string,string>m;//{{"apple","苹果"},{"banana","香蕉"},{"orange","橙子"},{"grape","葡萄"}};
void ServerIO(int sock)
{ 
   while(1)
   {
   char word[1024];
   string result;
   int ret1= recv(sock,word,sizeof(word),0);
   if(ret1<0)
   {
   cerr<<"recv fail..."<<endl;
   exit(6);
   }
   else if(ret1==0)
   {
   cerr<<"Client Close..."<<endl;
   break;
   }
   else
   {//success
       string s(word);
   if(m.find(s)==m.end())
   {
   result="Unknow";
   }
   else
       result=(m.find(s))->second;
   send(sock,result.c_str(),sizeof(result),0);
   }
   }
   close(sock);
}
int main()
{

    m.insert(make_pair("apple","苹果"));
    m.insert(make_pair("banana","香蕉"));
    m.insert(make_pair("orange","橙子"));
    m.insert(make_pair("grape","葡萄"));
    int sock=socket(AF_INET,SOCK_STREAM,0);
    if(sock<0)
    {
    cerr<<"socket fail..."<<endl;
    exit(1);
    }
    struct sockaddr_in local;
    local.sin_family=AF_INET;
    local.sin_addr.s_addr=htonl(INADDR_ANY);
    local.sin_port=htons(8080);
    socklen_t len1=sizeof(local);
    int num1=bind(sock,(struct sockaddr *)&local,len1);
    if(num1<0)
    {
    cerr<<"bind fail..."<<endl;
    exit(2);
    }
    int num2=listen(sock,6);
    if(num2<0)
    {
    cerr<<"listen fail..."<<endl;
    exit(3);
    }
    while(1)
    {
    struct sockaddr_in peer;
    socklen_t len2=sizeof(peer);
    int onesock=accept(sock,(struct sockaddr *)&peer,&len2);
    if(onesock<0)
    continue;
    cout<<"Get a new line..."<<endl;
    ServerIO(onesock);
    }
    close(sock);
    return 0;
}

客户端:Client.cc

#include<iostream>
#include<map>
#include<unistd.h>
#include<string>
#include<sys/types.h>
#include<sys/socket.h>
#include<stdlib.h>
#include<arpa/inet.h>
using namespace std;
int main()
{
    int sock=socket(AF_INET,SOCK_STREAM,0);
    if(sock<0)
    {
    cerr<<"socket fail..."<<endl;
    exit(1);
    }
    struct sockaddr_in local;
    local.sin_family=AF_INET;
    local.sin_addr.s_addr=inet_addr("127.0.0.1");
    local.sin_port=htons(8080);
    int len=sizeof(local);
    int ret=connect(sock,(struct sockaddr*)&local,len);
    if(ret<0)
    {
    cerr<<"connect fail..."<<endl;
    exit(2);
    }
    while(1)
    {
    string mas;
    cout<<"Please into word: ";
    cin>>mas;
    int ret2=send(sock,(void *)mas.c_str(),sizeof(mas),0);
    if(ret2<0)
    {
    cerr<<"send fail..."<<endl;
    exit(3);
    }
    char result[1024];
    int ret3=recv(sock,result,sizeof(result),0);
    if(ret3<0)
    {
    cerr<<"recv fail..."<<endl;
    exit(4);
    }
    cout<<result<<endl;
    }
    close(sock);
    return 0;
}

我是在Linux下写的,运行结果如下图:左边服务器端,右边客户端。
在这里插入图片描述
若有错误,欢迎指正:)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值