/*********************程序相关信息*********************
* 程序编号:015
* 程序编写起始日期:2013.11.30
* 程序编写完成日期:2013.11.30
* 程序修改日期: 修改备注:
* 程序目的:学习UNIX域套接字
* 所用主要函数:socket() bind() accept() listen()
* 程序说明: 同一台机器不同进程间通信。
* 程序完成地点:
* *********************程序相关信息*********************/ #define UNIX_PATH_MAX 108 #include <sys/types.h>
#include <sys/socket.h>
#include <sys/un.h> #include <stdio.h> #define BUFSIZE 32 int main(void)
{
int sd, newsd;
char buf[BUFSIZE];
struct sockaddr_un myend,*p;
int ret; sd = socket(PF_LOCAL, SOCK_STREAM, 0);
if (sd == -1) {
perror("socket()");
goto socket_err;
}
// #define UNIX_PATH_MAX 108
//
// struct sockaddr_un {
// sa_family_t sun_family; /* AF_UNIX */
// char sun_path[UNIX_PATH_MAX]; /* pathname*/
// };
//
myend.sun_family = AF_UNIX;
//int snprintf(char *str, size_t size, const char *format);
snprintf(myend.sun_path, UNIX_PATH_MAX, "rcv_sock");
// fprintf("rcv_sock","%s",myend.sun_path); //wrong unlink(myend.sun_path);
// Call the unlink function to remove the specified FILE
ret = bind(sd, (struct sockaddr *)&myend, sizeof(myend));
if (ret == -1) {
perror("bind()");
goto bind_err;
}
//调用 listen 使其能够自动接收到来的连接并且为连接队列指定一个长度限制
listen(sd, 20); newsd = accept(sd, NULL, 0);
if (newsd == -1) {
perror("accept()");
goto accept_err;
} while (1) {
ret = read(newsd, buf, BUFSIZE);
/* if error */
if (ret == 0) {
break;
} write(1, buf, ret);
write(newsd, "xxxxx\n", 6);
} close(newsd);
close(sd); return 0; close(newsd);
accept_err:
bind_err:
close(sd);
socket_err:
return 1;
}
 
/*********************程序相关信息*********************
* 程序编号:015
* 程序编写起始日期:2013.11.30
* 程序编写完成日期:2013.11.30
* 程序修改日期: 修改备注:
* 程序目的:学习unix
* 所用主要函数:pipe(),read(),fork()
* 程序说明:在本机上运行时,可以把程序中的“./test.c”修改成自己机器上的某个文件(要带路径)
* 程序完成地点:
* *********************程序相关信息*********************/ #define UNIX_PATH_MAX 108 #include <sys/types.h>
#include <sys/socket.h>
#include <sys/un.h> #include <stdio.h> #define BUFSIZE 32 int main(void)
{
int sd;
char buf[BUFSIZE];
struct sockaddr_un hisend;
int ret; sd = socket(PF_LOCAL, SOCK_STREAM, 0);
if (sd == -1) {
perror("socket()");
goto socket_err;
} hisend.sun_family = AF_UNIX;
snprintf(hisend.sun_path, UNIX_PATH_MAX, "rcv_sock"); ret = connect(sd, (struct sockaddr *)&hisend, sizeof(hisend));
if (ret == -1) {
perror("connect()");
goto connect_err;
} while (1) {
ret = read(0, buf, BUFSIZE);
/* if error */
if (ret == 0) {
break;
} write(sd, buf, ret);
ret = read(sd, buf, BUFSIZE);
write(1, buf, ret);
} close(sd); return 0; accept_err:
connect_err:
close(sd);
socket_err:
return 1;
}

UNIX 域套接字——UNIX domain socket的更多相关文章

  1. UNIX域套接字——UNIX domain socket(DGRAM)

    #define UNIX_PATH_MAX 108 #include <sys/types.h> #include <sys/socket.h> #include <sy ...

  2. Unix域套接字(Unix Domain Socket)介绍【转】

    本文转载自:http://blog.csdn.net/roland_sun/article/details/50266565 版权声明:本文为博主原创文章,未经博主允许不得转载. 在Linux系统中, ...

  3. 《网络编程》Unix 域套接字

    概述 Unix 域套接字是一种client和server在单主机上的 IPC 方法.Unix 域套接字不运行协议处理,不须要加入或删除网络报头,无需验证和,不产生顺序号,无需发送确认报文,比因特网域套 ...

  4. Unix域套接字简介

    在Linux系统中,有很多进程间通信方式,套接字(Socket)就是其中的一种.但传统的套接字的用法都是基于TCP/IP协议栈的,需要指定IP地址.如果不同主机上的两个进程进行通信,当然这样做没什么问 ...

  5. UNIX域套接字(unix domain)

    UNIX域套接字用于在同一台机器上运行的进程之间的通信. UNIX域套接字提供流和数据报两种接口. 说明:UNIX域套接字比因特网套接字效率更高.它仅赋值数据:不进行协议处理,如添加或删除网络报头.计 ...

  6. 高级进程间通信之UNIX域套接字

    UNIX域套接字用于在同一台机器上运行的进程之间的通信.虽然因特网域套接字可用于同一目的,但UNIX域套接字的效率更高.UNIX域套接字仅仅复制数据:它们并不执行协议处理,不需要添加或删除网络报头,无 ...

  7. UNIX网络编程——UNIX域套接字编程和socketpair 函数

    一.UNIX Domain Socket IPC socket API原本是为网络通讯设计的,但后来在socket的框架上发展出一种IPC机制,就是UNIX Domain Socket.虽然网络soc ...

  8. UNIX域套接字编程和socketpair 函数

    一.UNIX Domain Socket IPC socket API原本是为网络通讯设计的,但后来在socket的框架上发展出一种IPC机制,就是UNIX Domain Socket.虽然网络soc ...

  9. unix进程间通信方式(下)-unix域套接字(转)

    在之前的博客中已经总结了其它7种进程间的通信方式.unix域套接字用于在同一台计算机上的进程间通信,虽然因特网域套接字可用于同一目的,但是unix域套接字的效率更高.unix域套接字并不进行协议处理, ...

随机推荐

  1. thinkphp中如何是实现多表查询

    多表查询经常使用到,但如何在thinkphp中实现多表查询呢,其实有三种方法. 1 2 3 4 5 6 7 8 9 10 11 12 // 1.原生查询示例: $Model = new Model() ...

  2. JAVA特性-跨平台/面向对象

    JAVA特点概述 一,跨平台 这无疑是java最大的特点了,我相信大多数人第一次听说java语言大都从跨平台开开始的.实际上java跨平台特性主要体现在两个方面:编码和运行机制. 1,编码 java语 ...

  3. [leetcode tree]100. Same Tree

    判断输入的两棵树是不是相同 判断当前root值,左子树和右子树是否相同 ####注意最后用的是 is 而不是 ==,因为最后判断p和q是不是None, 应该判断是不是同一个对象 class Solut ...

  4. Block的基本用法

    NSString* (^myBlock)(NSString*, int); myBlock = ^(NSString *name, int age){ return [NSString stringW ...

  5. 家谱(gen)

    家谱(gen) 时间限制  2S [问题描述]     现代的人对于本家族血统越来越感兴趣,现在给出充足的父子关系,请你编写程序找到某个人的最早的祖先. [输入格式]gen.in 输入文件由多行组成, ...

  6. yyyy-MM-dd HH:mm:ss is Invalid Date in Safari, IE等浏览器下

    一.踩坑背景 在做某个项目的过程中,系统要求兼容safari,在使用Element-ui情况下,用到了datepicker组件,但是datepicker在type为daterange情况下,页面首次加 ...

  7. Google Code Jam 2009 Qualification Round Problem B. Watersheds

    https://code.google.com/codejam/contest/90101/dashboard#s=p1 Problem Geologists sometimes divide an ...

  8. 最小生成树-普利姆算法eager实现

    算法描述 在普利姆算法的lazy实现中,参考:普利姆算法的lazy实现 我们现在来考虑这样一个问题: 我们将所有的边都加入了优先队列,但事实上,我们真的需要所有的边吗? 我们再回到普利姆算法的lazy ...

  9. MySql篇

    CentOS6下通过yum安装的MySQL是5.1版的,比较老,所以就想通过源代码安装高版本的5.6.26. 一:卸载旧版本 使用下面的命令检查是否安装有MySQL Server rpm -qa | ...

  10. MyBatis入门实例-包括实体类与数据库字段对应&CLOB字段处理

    1.我的开发环境是 jdk1.7+ecplise+oracle 11g 用到的jar包:mybatis-3.1.1.jar ojdbc6.jar 2.项目整体结构     3.首先配置conf.xml ...