linux网络编程基础-常用函数错误处理封装
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了linux网络编程基础-常用函数错误处理封装,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3371字,纯文字阅读大概需要5分钟。
内容图文
![linux网络编程基础-常用函数错误处理封装](/upload/InfoBanner/zyjiaocheng/982/79a84ca23f0b4bc2979036122952c1cd.jpg)
my.c
#include <stdlib.h>
#include <errno.h>
#include <sys/socket.h>
#include <sys/types.h>
void perr_exit(const char *s)
{
perror(s);
exit(1);
}
//***************************网络*********************************
int Accept(int fd, struct sockaddr* addr, socklen_t* addrlen)
{
int n;
again:
if ( (n = accept(fd, addr, addrlen)) < 0)
{
if ((errno == ECONNABORTED) || (errno == EINTR))
goto again;
else
perr_exit("accept error");
}
return n;
}
int Bind(int fd, const struct sockaddr *addr, socklen_t addrlen)
{
int n;
if ((n = bind(fd, addr, addrlen)) < 0)
perr_exit("bind error");
return n;
}
int Connect(int fd, const struct sockaddr *addr, socklen_t addrlen)
{
int n;
if ((n = connect(fd, addr, addrlen)) < 0)
perr_exit("connect error");
return n;
}
int Listen(int fd, int backlog)
{
int n;
if ((n = listen(fd, backlog)) < 0)
perr_exit("listen error");
return n;
}
int Socket(int family, int type, int protocol)
{
int n;
if ( (n = socket(family, type, protocol)) < 0)
perr_exit("socket error");
return n;
}
//***************************读写操作*********************************
ssize_t Read(int fd, void *ptr, size_t nbytes)
{
ssize_t n;
again:
if ( (n = read(fd, ptr, nbytes)) == -1)
{
if (errno == EINTR)
goto again;
else
return -1;
}
return n;
}
ssize_t Write(int fd, const void *buf, size_t nbytes)
{
ssize_t n;
again:
if ( (n = write(fd, buf, nbytes)) == -1)
{
if (errno == EINTR)
goto again;
else
return -1;
}
return n;
}
//读指定字节数
ssize_t Readn(int fd, void *vptr, size_t n)
{
size_t nleft;
ssize_t nread;
char *ptr;
ptr = vptr;
nleft = n;
while (nleft > 0)
{
if ( (nread = read(fd, ptr, nleft)) < 0)
{
if (errno == EINTR)
nread = 0;
else
return -1;
}
else if (nread == 0)
break;
nleft -= nread;
ptr += nread;
}
return n - nleft;
}
//写指定的字节数
ssize_t Writen(int fd, const void *vptr, size_t n)
{
size_t nleft;
ssize_t nwritten;
const char *ptr;
ptr = vptr;
nleft = n;
while (nleft > 0)
{
if ( (nwritten = write(fd, ptr, nleft)) <= 0)
{
if (nwritten < 0 && errno == EINTR)
nwritten = 0;
else
return -1;
}
nleft -= nwritten;
ptr += nwritten;
}
return n;
}
//读100字节,通过ptr返回1字节,然后每次调用都返回 第一次读到的数据的 一个字节,直到100字节全部返回
static ssize_t my_read(int fd, char *ptr)
{
static int read_cnt;
static char *read_ptr;
static char read_buf[100];
if (read_cnt <= 0)
{
again:
if ((read_cnt = read(fd, read_buf, sizeof(read_buf))) < 0)
{
if (errno == EINTR)
goto again;
return -1;
}
else if (read_cnt == 0)
return 0;
read_ptr = read_buf;
}
read_cnt--;
*ptr = *read_ptr++;
return 1;
}
//读一行
ssize_t Readline(int fd, void *vptr, size_t maxlen)
{
ssize_t n, rc;
char c, *ptr;
ptr = vptr;
for (n = 1; n < maxlen; n++)
{
if ( (rc = my_read(fd, &c)) == 1)
{
*ptr++ = c;
if (c == '\n')
break;
}
else if (rc == 0)
{
*ptr = 0;
return n - 1;
}
else
return -1;
}
*ptr = 0;
return n;
}
my.h
#ifndef __WRAP_H_
#define __WRAP_H_
//socket相关
void perr_exit(const char *s);
int Accept(int fd, struct sockaddr* addr, socklen_t* addrlen);
int Bind(int fd, const struct sockaddr *addr, socklen_t addrlen);
int Connect(int fd, const struct sockaddr *addr, socklen_t addrlen);
int Listen(int fd, int backlog);
int Socket(int family, int type, int protocol);
//读写相关
ssize_t Read(int fd, void *ptr, size_t nbytes);
ssize_t Write(int fd, const void *buf, size_t nbytes);
ssize_t Readn(int fd, void *vptr, size_t n);
ssize_t Writen(int fd, const void *vptr, size_t n);
static ssize_t my_read(int fd, char *ptr);
ssize_t Readline(int fd, void *vptr, size_t maxlen);
#endif
内容总结
以上是互联网集市为您收集整理的linux网络编程基础-常用函数错误处理封装全部内容,希望文章能够帮你解决linux网络编程基础-常用函数错误处理封装所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。