1. linux socket 的程序如何在windows下编译并运行
本质区别是这样的,linux下用的是伯克利socket,windows底下用的WinSocket. 两者其实是大同小异的,不同的地方在以下几点: 1 头文件不同,在linux下用到的关键头文件<sys/socket.h> windows下用到的是 <Winsock2.h> 2 socket的初始化不一样,在windows下要有一个WSAStartup,而linux 下没有。 3 具体的细节不一样,linux下的c和windows下的c的一些语法有些出入,你自己找找。下面我把windows下的socket通讯的最基本的结构给你,你对照着修改就可以了,一下的程序我调试了一下,编译过了。客户端 #include <Winsock2.h> #include <stdio.h> void main() { WORD wVersionRequested; WSADATA wsaData; int err; wVersionRequested = MAKEWORD( 1, 1 ); err = WSAStartup( wVersionRequested, &wsaData ); if ( err != 0 ) { return; } if ( LOBYTE( wsaData.wVersion ) != 1 || HIBYTE( wsaData.wVersion ) != 1 ) { WSACleanup( ); return; } SOCKET sockClient=socket(AF_INET,SOCK_STREAM,0); SOCKADDR_IN addrSrv; addrSrv.sin_addr.S_un.S_addr=inet_addr("127.0.0.1"); addrSrv.sin_family=AF_INET; addrSrv.sin_port=htons(6000); connect(sockClient,(SOCKADDR*)&addrSrv,sizeof(SOCKADDR)); char recvBuf[100]; recv(sockClient,recvBuf,100,0); printf("%s\n",recvBuf); send(sockClient,"This is lisi",strlen("This is lisi")+1,0); closesocket(sockClient); WSACleanup(); } 服务器端 #include <Winsock2.h> #include <stdio.h> void main() { WORD wVersionRequested; WSADATA wsaData; int err; wVersionRequested = MAKEWORD( 1, 1 ); err = WSAStartup( wVersionRequested, &wsaData ); if ( err != 0 ) { return; } if ( LOBYTE( wsaData.wVersion ) != 1 || HIBYTE( wsaData.wVersion ) != 1 ) { WSACleanup( ); return; } SOCKET sockSrv=socket(AF_INET,SOCK_STREAM,0); SOCKADDR_IN addrSrv; addrSrv.sin_addr.S_un.S_addr=htonl(INADDR_ANY); addrSrv.sin_family=AF_INET; addrSrv.sin_port=htons(6000); bind(sockSrv,(SOCKADDR*)&addrSrv,sizeof(SOCKADDR)); listen(sockSrv,5); SOCKADDR_IN addrClient; int len=sizeof(SOCKADDR); while(1) { SOCKET sockConn=accept(sockSrv,(SOCKADDR*)&addrClient,&len); char sendBuf[100]; sprintf(sendBuf,"来自服务器端", inet_ntoa(addrClient.sin_addr)); send(sockConn,sendBuf,strlen(sendBuf)+1,0); char recvBuf[100]; recv(sockConn,recvBuf,100,0); printf("%s\n",recvBuf); closesocket(sockConn); } }
2. linux 配置DNS问题
上面说的错误确实是没有找到你修改的正反向区域文件 最好是你直接在/var/named/chroot/var/named/目录下面把named.local 还有localhost.zone两个文件从新复制重命名然后配置一下 并确保你的全局参数里面定义的正反向区域文件名字和你改的文件名字一致
3. linux下,C语言头文件在哪
一、 C标准库头文件,以及Linux的标准库文件的对应头文件,默认放在/usr/include下。 如图:
标识出回了最常用的几答个头文件。
二、 自定义头文件,或者集成头文件,需要在编译的时候指定。可以在命令行中指定,也可以在makefile中指定。
指定自定义头文件路径方式为:
-IPATH1 -IPATH2…
如当前目录下的inc文件夹,指定为头文件, 那么在编译a.c时,可以命令写作:
gcc a.c -I./inc -o a.out
4. linux 头文件
你也说了pfm_set_options这个函数,他包含的头文件里都是.h文件,而pfm_set_options(pfmlib_options_t *opt) 该函数的实现却在一个c文件中说明头文件里的函数都是在相应的c文件中实现的啊然后将这个实现的函数放在头文件中,这样把这个头文件包含在其他的c文件中,这样其他的c文件就可以使用这个函数而不怕找不到了打个比方:你生产了10种游戏(10个函数实现,在.c文件中实现)然后把这10个游戏的名字写在一张纸上(纸就是.h文件)最后你就可以拿这张纸给别人 然后告诉那个人:我有这些玩具你想要哪一个就给你哪一个
5. linux dns反向解析是总是多出0.168.192.in-addr.arpa,怎么才能只出主机名
反向解析记录vim 进入注意:NS这行最后要有点 .PTR这行最后也要有点 .如果PTR后面没有点 就是你这样
6. linux头文件include文件系统是什么
那是你的编辑器没有开启语法高亮功能,你是用什么写的程序?vi还是gedit……?或者你是用IDE写的?.
7. linux 有dns服务器 怎么解析地址
DNS解析分成正向解析和反向解析在redhat中,为了避免经常修改主配置文件named.conf而导致DNS服务出错,所以规则的区域信息保存在了"/etc/named.rfc1912.zones"文件中,这个文件用于定义域名与IP地址解析规则保存的文件位置以及区域服务类型等内容,一定要谨慎修改。正向解析区域文件格式:服务类型可以有三种:hint(根区域)、master(主区域)、slave(辅助区域)。反向解析区域文件格式:zone区域中IP信息必需反写(如上图演示),并且后面要写上"in-addr.arpa"。你可以跟着http://www.linuxprobe.com/chapter-13.html#133_DNS中的实验,分别对主配置文件、区域信息文件与区域数据文件做修改,当怀疑因配置参数而出错时可执行named-checkconf或named-checkzone命令来分别用于检查主配置与区域数据文件中语法或参数的错误。相信你做完实验后会清晰不少
8. 基于Linux的远程指令系统(使用udp而不是tcp)
一. Linux下UDP编程框架使用UDP进行程序设计可以分为客户端和服务器端两部分。1.服务器端程序包括:? 建立套接字? 将套接字地址结构进行绑定? 读写数据? 关闭套接字2.客户端程序包括:? 建立套接字? 读写数据? 关闭套接字3.服务器端和客户端程序之间的差别服务器端和客户端两个流程之间的主要差别在于对地址的绑定函数(bind()函数),而客户端可以不用进行地址和端口的绑定操作。二.Linux中UDP套接字函数从图可知,UDP协议的服务端程序设计的流程分为套接字建立,套接字与地址结构进行绑定,收发数据,关闭套接字;客户端程序流程为套接字建立,收发数据,关闭套接字等过程。它们分别对应socket(),bind(),sendto(),recvfrom(),和close()函数。网络程序通过调用socket()函数,会返回一个用于通信的套接字描述符。Linux应用程序在执行任何形式的I/O操作的时候,程序是在读或者写一个文件描述符。因此,可以把创建的套接字描述符看成普通的描述符来操作,并通过读写套接字描述符来实现网络之间的数据交流。1. socket1> 函数原型:int socket(int domain,int type,int protocol)2> 函数功能:函数socket()用于创建一个套接字描述符。3> 形参:? domain:用于指定创建套接字所使用的协议族,在头文件中定义。常见的协议族如下:AF_UNIX:创建只在本机内进行通信的套接字。AF_INET:使用IPv4 TCP/IP协议AF_INET6:使用IPv6 TCP/IP协议说明:AF_UNIX只能用于单一的UNIX系统进程间通信,而AF_INET是针对Interne的,因而可以允许在远程主机之间通信。一般把它赋为AF_INET。? type:指明套接的类型,对应的参数如下SOCK_STREAM:创建TCP流套接字SOCK_DGRAM:创建UDP数据报套接字SOCK_RAW:创建原始套接字? protocol:参数protocol通常设置为0,表示通过参数domain指定的协议族和参数type指定的套接字类型来确定使用的协议。当为原始套接字时,系统无法唯一的确定协议,此时就需要使用使用该参数指定所使用的协议。4> 返回值:执行成功后返回一个新创建的套接字;若有错误发生则返回一个-1,错误代码存入errno中。5> 举例:调用socket函数创建一个UDP套接字int sock_fd;sock_fd = socket(AF_INET,SOCK_DGRAM,0);if(sock_fd < 0){perror(“socket”);exit(1);}2. bind1> 函数原型:int bind(int sockfd,struct sockaddr *my_addr,socklen_taddrlen)2> 函数功能函数bind()的作用是将一个套接字文件描述符与一个本地地址绑定在一起。3> 形参:? sockfd:sockfd是调用socket函数返回的文件描述符;? addrlen是sockaddr结构的长度。? my_addr: 是一个指向sockaddr结构的指针,它保存着本地套接字的地址(即端口和IP地址)信息。不过由于系统兼容性的问题,一般不使用这个结构,而使用另外一个结构(struct sockaddr_in)来代替4> 套接字地址结构:(1)structsockaddr:结构struct sockaddr定义了一种通用的套接字地址,它在Linux/socket.h 中定义。struct sockaddr{unsigned short sa_family;/*地址类型,AF_XXX*/char sa_data[14];/*14字节的协议地址*/}a. sin_family:表示地址类型,对于使用TCP/IP协议进行的网络编程,该值只能是AF_INET.b. sa_data:存储具体的协议地址。(2)sockaddr_in每种协议族都有自己的协议地址格式,TCP/IP协议组的地址格式为结构体struct sockaddr_in,它在netinet/in.h头文件中定义。struct sockaddr_in{unsigned short sin_family;/*地址类型*/unsigned short sin_port;/*端口号*/struct in_addr sin_addr;/*IP地址*/unsigned char sin_zero[8];/*填充字节,一般赋值为0*/}a. sin_family:表示地址类型,对于使用TCP/IP协议进行的网络编程,该值只能是AF_INET.b. sin_port:是端口号c. sin_addr:用来存储32位的IP地址。d. 数组sin_zero为填充字段,一般赋值为0.e. structin_addr的定义如下:struct in_addr{unsignedlong s_addr;}结构体sockaddr的长度为16字节,结构体sockaddr_in的长度为16字节。可以将参数my_addr的sin_addr设置为INADDR_ANY而不是某个确定的IP地址就可以绑定到任何网络接口。对于只有一IP地址的计算机,INADDR_ANY对应的就是它的IP地址;对于多宿主主机(拥有多个网卡),INADDR_ANY表示本服务器程序将处理来自所有网络接口上相应端口的连接请求5> 返回值:函数成功后返回0,当有错误发生时则返回-1,错误代码存入errno中。6>举例:调用socket函数创建一个UDP套接字struct sockaddr_in addr_serv,addr_client;/*本地的地址信息*/memset(&serv_addr,0,sizeof(struct sockaddr_in));addr_serv.sin_family = AF_INET;/*协议族*/addr_serv.sin_port = htons(SERV_PORT);/*本地端口号*/addr_serv.sin_addr.s_addr = htonl(INADDR_ANY); /*任意本地地址*//*套接字绑定*/if(bind(sock_fd,(struct sockaddr *)&addr_serv),sizeof(structsockaddr_in)) <0){perror(“bind”);exit(1);}3.close1>函数原型:int close(intfd);2>函数功能:函数close用来关闭一个套接字描述符。3>函数形参:? 参数fd为一个套接字描述符。4>返回值:执行成功返回0,出错则返回-1.错误代码存入errno中。说明:以上三个函数中,前两个要包含头文件#include#include后一个包含:#include4.sendto1>函数原型:#include#includessize_t sendo(ints,const void *msg,size_t len,int flags,const struct sockaddr *to,socklen_ttolen);2>函数功能:向目标主机发送消息3>函数形参:? s:套接字描述符。? *msg:发送缓冲区? len:待发送数据的长度? flags:控制选项,一般设置为0或取下面的值(1)MSG_OOB:在指定的套接字上发送带外数据(out-of-band data),该类型的套接字必须支持带外数据(eg:SOCK_STREAM).(2)MSG_DONTROUTE:通过最直接的路径发送数据,而忽略下层协议的路由设置。? to:用于指定目的地址? tolen:目的地址的长度。4>函数返回值:执行成功后返回实际发送数据的字节数,出错返回-1,错误代码存入errno中。5>函数举例:char send_buf[BUFFERSIZE];struct sockaddr_in addr_client;memset(&addr_client,0,sizeof(struct sockaddr_in));addr_client.sin_family = AF_INET;addr_client.sin_port = htons(DEST_PORT);if(inet_aton(“172.17.242.131”,&addr_client.sin_addr)<0){perror(“inet_aton”);exit(1);}if(sendto(sock_fd,send_buf,len,0,(strut sockaddr*)&addr_client,sizeof(struct sockaddr_in)) <0){perror(“sendto”);exit(1);}5.recvfrom1>函数原型:#include#includessize_t recvfrom(int s,void *buf,size_t len,intflags,struct sockaddr *from,socklen_t *fromlen);2>函数功能:接收数据3>函数形参:? int s:套接字描述符? buf:指向接收缓冲区,接收到的数据将放在这个指针所指向的内存空间。? len:指定了缓冲区的大小。? flags:控制选项,一般设置为0或取以下值(1)MSG_OOB:请求接收带外数据(2)MSG_PEEK:只查看数据而不读出(3)MSG_WAITALL:只在接收缓冲区时才返回。? *from:保存了接收数据报的源地址。? *fromlen:参数fromlen在调用recvfrom前为参数from的长度,调用recvfrom后将保存from的实际大小。4>函数返回值:执行成功后返回实际接收到数据的字节数,出错时则返回-1,错误代码存入errno中。5>函数实例:char recv_buf[BUFFERSIZE];struct sockaddr_in addr_client;int src_len;src_len = sizeof(struct sockaddr_in);int src_len;src_len = sizeof(struct sockaddr_in);if(recvfrom(sock_fd,recv_buf,sizeof(recv_buf),0,(structsockaddr *)&src_addr,&src_len)<0){perror(“again_recvfrom”);exit(1);}三.UDP编程实例客户端向服务器发送字符串Hello tiger,服务器接收到数据后将接收到字符串发送回客户端。1.服务器端程序1 #include2 #include3 #include4 #include5 #include6 #include7 #include8 #include9 10 #define SERV_PORT 300011 12 int main()13 {14 int sock_fd; //套接子描述符号15 int recv_num;16 int send_num;17 int client_len;18 char recv_buf[20];19 struct sockaddr_in addr_serv;20 struct sockaddr_in addr_client;//服务器和客户端地址21 sock_fd = socket(AF_INET,SOCK_DGRAM,0);22 if(sock_fd < 0){23 perror("socket");24 exit(1);25 } else{26 27 printf("sock sucessful\n");28 }29 //初始化服务器断地址30 memset(&addr_serv,0,sizeof(struct sockaddr_in));31 addr_serv.sin_family = AF_INET;//协议族32 addr_serv.sin_port = htons(SERV_PORT);33 addr_serv.sin_addr.s_addr = htonl(INADDR_ANY);//任意本地址34 35 client_len = sizeof(struct sockaddr_in);36 /*绑定套接子*/37 if(bind(sock_fd,(struct sockaddr *)&addr_serv,sizeof(struct sockaddr_in))<0 ){38 perror("bind");39 exit(1);40 } else{41 42 printf("bind sucess\n");43 }44 while(1){45 printf("begin recv:\n");46 recv_num = recvfrom(sock_fd,recv_buf,sizeof(recv_buf),0,(struct sockaddr *)&addr_client,&client_len);47 if(recv_num < 0){48 printf("bad\n");49 perror("again recvfrom");50 exit(1);51 } else{52 recv_buf[recv_num]='\0';53 printf("recv sucess:%s\n",recv_buf);54 }55 printf("begin send:\n");56 send_num = sendto(sock_fd,recv_buf,recv_num,0,(struct sockaddr *)&addr_client,client_len);57 if(send_num < 0){58 perror("sendto");59 exit(1);60 } else{61 printf("send sucessful\n");62 }63 }64 close(sock_fd);65 return 0;66 }2.客户端程序1 #include2 #include3 #include4 #include5 #include6 7 #include8 #include9 #include10 11 #define DEST_PORT 300012 #define DSET_IP_ADDRESS "192.168.1.103"13 14 int main()15 {16 int sock_fd;/*套接字文件描述符*/17 int send_num;18 int recv_num;19 int dest_len;20 char send_buf[20]={"hello tiger"};21 char recv_buf[20];22 struct sockaddr_in addr_serv;/*服务端地址,客户端地址*/23 24 sock_fd = socket(AF_INET,SOCK_DGRAM,0);//创建套接子25 //初始化服务器端地址26 memset(&addr_serv,0,sizeof(addr_serv));27 addr_serv.sin_family = AF_INET;28 addr_serv.sin_addr.s_addr = inet_addr(DSET_IP_ADDRESS);29 addr_serv.sin_port = htons(DEST_PORT);30 31 dest_len = sizeof(struct sockaddr_in);32 printf("begin send:\n");33 send_num = sendto(sock_fd,send_buf,sizeof(send_buf),0,(struct sockaddr *)&addr_serv,dest_len);34 if(send_num < 0){35 perror("sendto");36 exit(1);37 } else{38 39 printf("send sucessful:%s\n",send_buf);40 }41 recv_num = recvfrom(sock_fd,recv_buf,sizeof(recv_buf),0,(struct sockaddr *)&addr_serv,&dest_len);42 if(recv_num <0 ){43 44 perror("recv_from");45 exit(1);46 } else{47 printf("recv sucessful\n");48 }49 recv_buf[recv_num]='\0';50 printf("the receive:%s\n",recv_buf);51 close(sock_fd);52 return 0;53 }
9. linux中怎么添加自己的头文件
楼上的 你的意思是把用到的函数生成库文件放到linux源码里? 头文件放到linux源码的内include文件夹下,库函容数放到源码的lib文件夹下,然后编译内核,这样会自动生成库文件吗? 是否要修改linux源码的Makefile?
未经允许不得转载:山九号 » linuxinaddr头文件|linux头文件include文件系统是什么