linux-socket通信示例(传送文件)

本文提供了一组基于TCP协议的简单文件传输示例代码,包括服务器端和客户端实现。通过这些示例,读者可以了解如何使用socket编程进行基本的文件传输操作。
服务器端代码:
#include "creatSocket.h"
#include <string.h>
#include <stdio.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <netdb.h>
#include <fcntl.h>
#include <sys/stat.h>
#include <errno.h>
//#include "error.h"

#define BUFFSIZE 20
extern int errno;
main()
{
  int temp_sock;
  int ssock;
  char buff[BUFFSIZE+1];
 
  struct sockaddr_in pin;
  int size_pin = sizeof(pin);
  int count_receive ;       /* count the receive world */
  int fd;                   /* mark the file */
  int count;                /* count the number of reading */
  
  ssock = passiveTCP("8000",5);
  while(1)
  {
    printf("listen.../n");
    temp_sock = accept(ssock,(struct sockaddr *)&pin,&size_pin);
    count_receive = read(temp_sock,buff,BUFFSIZE);
    printf("has receive message:%s/n",buff);
    
    fd = open(buff,O_RDWR);
    if(fd < 0)
       errexit("can't open the file:%s/n",strerror(errno));
    while(count = read(fd,buff,BUFFSIZE))
    {
          buff[count] = '/0';
          printf("%s",buff);
          write(temp_sock,buff,count);
    }
    close(temp_sock);
    printf("the connect has closed!/n");
  }
}
客户端代码:
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <errno.h>
#include "error.h"
#include <netdb.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <string.h>
extern int errno;
#define BUFFSIZE 20

void menu();
void TCPclient();
void UDPclient();

main()
{
  int c_choose;
  while(1)
  {
    menu();
    scanf("%d",&c_choose);
    switch(c_choose)
    {
      case 1:TCPclient();break;
      case 2:UDPclient();break;
      default:exit(0);
    }
  }
}

void menu()
{
  printf("Please choose the client:/n");
  printf("1.TCPclient/n");
  printf("2.UDPclient/n");
  printf("3.exit/n");
  printf("please input you choose:");
} 

void UDPclient()
{}

void TCPclient()
{
  char filename[20];
  char buff[BUFFSIZE+1];
  int count;
  int port = 8000;
  struct sockaddr_in sin;
  sin.sin_family = AF_INET;
  sin.sin_addr.s_addr = INADDR_ANY;
  sin.sin_port = htons(port);
  
  int csock = socket(AF_INET,SOCK_STREAM,0);
  if(connect(csock,(void *)&sin,sizeof(sin)))
    errexit("has't connect to the server !:%s/n",strerror(errno));
  else
    printf("has connect to the server!/n");
  
  printf("please input the file name:");
  scanf("%s",buff);
  
  write(csock,buff,sizeof(buff));
  printf("the text content is :/n");
  int i =0 ;
  
  strcpy(filename,buff);
  int fd = creat(filename,O_WRONLY|O_CREAT);
  while(count = read(csock,buff,BUFFSIZE))
  {
    if(count < 0)
      exit(0);
    printf("%d,%d/n",i++,count);
    buff[count] = '/0';
    write(fd,buff,count);
    printf("%s",buff);
    memset(buff,0,sizeof(buff));
  }
  close(fd);
  printf("the file %s has receive!/n",filename);  
}
创建服务器端socket通用头文件:
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <stdlib.h>
#include <string.h>
#include <netdb.h>
#include <errno.h>
#include "error.h"

extern int errno;

unsigned short portbase = 0;

int passivesock(const char *service,const char *transport,int qlen)
{
  struct servent *pse;      //pointer to service information entry
  struct protoent *ppe;     //pointer to protocol information entry
  struct sockaddr_in sin;   //an Internet endpoint address
  int s,type;               //socket descriptor and socket type

  memset(&sin,0,sizeof(sin));
  sin.sin_family = AF_INET;
  sin.sin_addr.s_addr = INADDR_ANY;

  //Map service name to port number 
  if( pse = getservbyname(service,transport))
    sin.sin_port = htons(ntohs((unsigned short)pse->s_port)+portbase);
  else if((sin.sin_port = htons((unsigned short)atoi(service))) == 0)
    errexit("can't get /"%s/"service entry/n",service);

  //Map protocol name to protocol number
  if((ppe = getprotobyname(transport)) == 0)
    errexit("can't get/"%s/"protocol entry/n",transport);
  
  //Use protocol to choose a socket type
  if(strcmp(transport,"udp") == 0)
    type = SOCK_DGRAM;
  else
    type = SOCK_STREAM;

  //Allocate a socket
  s = socket(PF_INET,type,ppe->p_proto);
  if(s <0 )
    errexit("can't create socket :%s/n",strerror(errno));
  
  //Bind the socket
  if(bind(s,(struct sockaddr*)&sin,sizeof(sin)) < 0)
    errexit("can't bind to %s port:%s/n",service,strerror(errno));
  if(type == SOCK_STREAM && listen(s,qlen) < 0 )
    errexit("can't listen on %s port:%s/n",service,strerror(errno));
  
  return s;
}

int passiveUDP(const char*service)
{
  return passivesock(service,"udp",0);
}

int passiveTCP(const char *service,int qlen)
{
  return passivesock(service,"tcp",qlen);
}
错误处理头文件:
#include <stdio.h>
#include <stdlib.h>
#include <stdarg.h>

int errexit(const char * format,...)
{
  va_list args;
  va_start(args,format);
  vfprintf(stderr,format,args);
  va_end(args);
  exit(1);
} 

基于径向基函数神经网络RBFNN的自适应滑模控制学习(Matlab代码实现)内容概要:本文介绍了基于径向基函数神经网络(RBFNN)的自适应滑模控制方法,并提供了相应的Matlab代码实现。该方法结合了RBF神经网络的非线性逼近能力和滑模控制的强鲁棒性,用于解决复杂系统的控制问题,尤其适用于存在不确定性和外部干扰的动态系统。文中详细阐述了控制算法的设计思路、RBFNN的结构与权重更新机制、滑模面的构建以及自适应律的推导过程,并通过Matlab仿真验证了所提方法的有效性和稳定性。此外,文档还列举了大量相关的科研方向和技术应用,涵盖智能优化算法、机器学习、电力系统、路径规划等多个领域,展示了该技术的广泛应用前景。; 适合人群:具备一定自动控制理论基础和Matlab编程能力的研究生、科研人员及工程技术人员,特别是从事智能控制、非线性系统控制及相关领域的研究人员; 使用场景及目标:①学习和掌握RBF神经网络与滑模控制相结合的自适应控制策略设计方法;②应用于电机控制、机器人轨迹跟踪、电力电子系统等存在模型不确定性或外界扰动的实际控制系统中,提升控制精度与鲁棒性; 阅读建议:建议读者结合提供的Matlab代码进行仿真实践,深入理解算法实现细节,同时可参考文中提及的相关技术方向拓展研究思路,注重理论分析与仿真验证相结合。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值