1、

2、

>>>   int socket(int af, int type,int protocol);//创建套接字,返回从文件描述表中取出新的索引号(int);AF_INET,SOCK_DGRAM/SOCK_STREAM,0;阻塞式socket

int close(int d);/int shutdown(int socket,int direction);//关闭

//将int s套接字转成nonblock

void nonblock(int s)

{

  int flags;

flags = fcntl(s, F_GETEL,0);//获取

flags != O_NONBLOCK;

if(fcntl(s,F_SETFL,flags)<0) exit(1);//设置

}

struct sockaddr{

u_short sa_family;

char sa_data[14];

}

struct in_addr{

u_long s_addr;

};

struct sockaddr_in{

short sin_family;

u_short sin_port;

struct in_addr sin_addr;

char sin_zero[8];

}

>>>  int connect(int s, const struct sock* name, socklen_t namelen);

int connectToServer(int sock)

{

struct sockaddr_in  s_addr_in;

s_addr_in.sin_family = AF_INET;

s_addr_in.sin_port = htos(8001);

s_addr_in.sin_addr.s_addr = inet_addr(“127.0.0.1”);//ip转为usigned long 二进步数,相反 char*  inet_ntoa(struct in_addr in);

if(connect(sock,(struct sockaddr*)&s_addr_in,sizeof(s_addr_in))<0)

        return 0;

return 1;

}

//域名转成long 类型二进制地址

unsigned long getaddrbydomain(char* addr)

{

struct hostent *ph;

struct in_addr in;

ph = gethostbyname(addr);

memcpy((char**)&(in),ph->_addr,ph->h_length);

return (in.s_addr);

}

struct hostent

{

char h_name;

char **h_aliases;

int h_addrtype;

int h_length;

char **h_addr_list;//名字服务器上的地址列表

}

>>>  int bind(int s, const struct sockaddr* addr, socklen_t addrlen);

>>>  int listen(int s, int backing);

>>>  int accept(int s, struct sockaddr *addr, socklen_t *addrlen);//返回分配到的套接字

>>>  ssize_t send(int s,const void *msg,size_t len, int flags);

>>>  int recv(int s, void *buf, size_t len, int flags);//buf 接收到的数据,返收的数据长度;flags{MSG_OOB,MSG_PEEK/*从receive_queue取出数据到buf后不删除原来的*/}

>>>  int write(int s, void *buf, size_t len);//与send相同

>>>  int read(int s, void *buf ,size_t len);//recv

>>>  int sendto (int s,const void *msg,size_t len, int flags, const struct sockaddr* to, socklen_t tolen);//相当于connect 与send组合

>>>  int recvfrom(int s, void *buf ,size_t len, int  flags, struct sockaddr* from, socklen_t  * fromlen);//相当于accept与recv合并

>>>  int select(int nfds, fd_set *readfds, fd_set * writefds, fd_set *exceptfds, struct timeval * timeout);

>>>   int setsockopt(int s,int level, int optname, const void* optval, unsigned int optlen);/getsockopt

>>>  void (*signal(int signum,void(*handler)(int)))int);

>>> errno

3. winsock

>>> int WASStartup(WORD wVersionRequest,LPWSADATA lpWSAData);

>>>  int WSACleanup();

struct WSAData {    WORD             wVersion;    WORD             wHighVersion;    char             szDescription[WSADESCRIPTION_LEN+1];    char             szSystemStatus[WSASYSSTATUS_LEN+1];    unsigned short   iMaxSockets;    unsigned short   iMaxUdpDg;    char FAR *       lpVendorInfo;
};
>>>  SOCKET socket(int af,int type,int protocol);
>>>  int closesocket(SOCKET s);
>>>  int ioctlsocket(SOCKET s,long cmd, u_long FAR* argp);//fcntl/ioctl
>>>  int connect(SOCKET s, const struct sockaddr FAR* name,int namelen);
>>>  int bind(SOCKET s, const struct sockaddr FAR* name,int namelen);
>>> int listen(SOCKET s, int backlog);
>>>  SOCKET accept( SOCKET s,struct sockaddr FAR*addr,int FAR*addrlen);
>>>  int send ( SOCKET s, const char FAR * buf, int len, int flags ); 
>>> int recv ( SOCKET s, char FAR* buf, int len, int flags ); 
>>> sendto /recvfrom
>>>  select/WSAAsyncSelect/WSAEventSelect
>>> getsockopt/setsockopt
>>>  WSAGetLastError

TCP/IP学习笔记的更多相关文章

  1. tcp/ip学习笔记-TCP

    tcp/ip学习笔记-TCP 彭会锋 报文发送采用的是tcp_output函数,

  2. TCP/IP学习笔记(3)-IP、ARP、RARP协议

    这三个协议放到一起学习是因为这三个协议处于同一层,ARP协议用来找到目标主机的Ethernet网卡Mac地址,IP则承载要发送的消息.数据链路层可以从ARP得到数据的传送信息,而从IP得到要传输的数据 ...

  3. TCP/IP学习笔记(3)----IP,ARP,RARP协议

    把这三个协议放到一起学习是因为这三个协议处于同一层(网络层协议),ARP协议用来找到目标主机的Ethernet网卡Mac地址,IP则承载要发送的消息.数据链路层可以从ARP得到数据的传送信息,而从IP ...

  4. TCP/IP学习笔记17--TCP-- 窗口控制 重发控制 流控制

    事业无穷年 -- 韩愈 利用窗口控制提高速度: TCP传输数据是,以一个段为单位(每次发送一个数据包),每发一个段需要一次确认应答,这样就难免存在这样的缺点:包的往返时间越长,通信性能就越低. 为解决 ...

  5. TCP/IP学习笔记(2)-数据链路层

    数据链路层有三个目的: 为IP模块发送和接收IP数据报. 为ARP模块发送ARP请求和接收ARP应答. 为RARP发送RARP请求和接收RARP应答 ip大家都听说过.至于ARP和RARP,ARP叫做 ...

  6. tcp/ip学习笔记(1)-基本概念

    为什么会有tcp/ip 在世界上各地,各种各样的电脑运行着各自不同的操作系统为大家服务,这些电脑在表达同一种信息的时候所使用的方法是千差万别.就好像圣经中上帝打乱了各地人的口音,让他们无法合作一样.计 ...

  7. TCP/IP学习笔记(5)------IP选路

    静态IP选路 一个简单的路由表 选路是IP层最重要的一个功能之一.前面的部分已经简单的讲过路由器是通过何种规则来根据IP数据包的IP地址来选择路由.这里就不重复了.首先来看看一个简单的系统路由表. D ...

  8. TCP/IP学习笔记1--概述,分组交换协议

    1.TCP/IP 互联网是由许多独立发展的网络通信技术融合而成的,能够使它们不断融合并实现统一的正式TCP/IP技术,TCP/IP使通信协议的统称. TCP/IP协议模型(Transmission C ...

  9. TCP/IP学习笔记18--TCP--拥塞控制 (慢开始, 拥塞避免, 快重传和快恢复)

                                                            用最多的梦面对未来   -- 李嘉诚 在某段时间,若对网络资源的需求超过了该资源所能提供 ...

  10. TCP/IP学习笔记16--TCP--特点,数据重发,连接管理,段

    TCP充分实现了数据传输时各种控制功能,可以进行丢包时的重发控制,还可以对次序乱掉的包进行顺序控制,这些在UDP中都是没有的.UDP是一种没有复杂控制,提供面向无连接通信服务的一种协议.TCP是面向有 ...

随机推荐

  1. openStack windows2008 centos6.* img

    1,下载 windows2008 系统iso介质包 http://download.microsoft.com/download/F/3/8/F384E78B-8F1D-42A6-A308-63E45 ...

  2. InnoDB引擎Myslq数据库数据恢复

    首先祝愿看到这片文章的你永远不要有机会用到它... 本文指针对用InnoDB引擎的Mysql数据库的数据恢复,如果是其它引擎的Mysql或其它数据库请自行google... 如果有一天你手挫不小心删掉 ...

  3. Reorder the Books(规律)

    Reorder the Books Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Othe ...

  4. 数字信号处理Day1自制电子音乐

    第一天的课程感觉比較简单,主要介绍Karplus-Strong Algorithm 给出方程 y[n]=αy[n−M]+x[n], x[n]是输入,M是延迟,α是衰弱系数 我们要衰减D次,总的採样数就 ...

  5. js字面量

    以前一直对js字面量模棱两可. '字面量是一种表示值的记法.' js字面量(literal) 分为以下几个 number literal        8   就是数字字面量 string liter ...

  6. Visual Studio 继续并运行上次的成功生成,未提示直接运行上一个版本解决方案!

    Visual Studio ==>工具 ==> 选项==>项目和解决方案 ==>生成并运行_运行时,当出现生成或部署错误时_选择,提示启动

  7. UVA1471( LIS变形)

    这是LIS的变形,题意是求一个序列中去掉某个连续的序列后,能得到的最长连续递增序列的长度. 用DP的解法是:吧这个序列用数组a来记录,再分别用两个数组f记录以i结尾的最长连续递增序列的长度,g[i]记 ...

  8. Laravel5 学习与使用(一)

    2015-07-04 (1)  安装Laravel框架 ① 安装前的准备工作 使用Apache24 + PHP 5.6 + MySQL 开发环境完成PHP网站开发,所以Laravel的安装是建立在以上 ...

  9. BZOJ 1602: [Usaco2008 Oct]牧场行走( 最短路 )

    一棵树..或许用LCA比较好吧...但是我懒...写了个dijkstra也过了.. ---------------------------------------------------------- ...

  10. BZOJ 1050: [HAOI2006]旅行comf( 并查集 )

    将edge按权值排序 , O( m² ) 枚举边 , 利用并查集维护连通信息. ------------------------------------------------------------ ...