zoukankan      html  css  js  c++  java
  • “管道和过滤器”模式中管道的种类

         管道和过滤器模式,与职责链模式相比。一者是适用范围不一样,管道和过滤器模式是在架构层次的模式,它的元素是各个子系统或者程序。而职责链体现了组件间的调用关系。另外一个显著区别是,职责链模式中,一个对象指针的函数调用,就将指令转移到另外一个组件了。而“管道和过滤器”模式存在一个可以用多种技术实现的管道。
        管道
            严格的先进先出,
        消息队列
            非严格先进先出,可以选择性地读取想要的消息
        文件
            不提供同步机制,需要应用程序考虑
        共享内存
            不提供同步机制,需要应用程序考虑
        SOCKET
            适用于跨主机计算
     
        如果单主机情况,消息队列使用的频率较高。由于存在需要传递较大数据体的情况,可以将消息队列和共享内存封装为个性化的“消息队列”。比如实际要传递的数据放在共享内存,而将消息体中记录实际数据在共享内存中的位置。这种方式结合了消息队列的灵活性和共享内存的较高访问速度。
        管道是消息队列的有力竞争对手。性能方面,与消息队列在一个数量级上。但在使用方面,消息队列更加灵活。
        如果对于管道中的数据的正确性和完整性有特别严格的要求,或者要将数据提供给第三方使用,那么通过文件落地管道数据,是更安全的选择。
  • 相关阅读:
    oracle_jdbc_insert_into
    MySQL 性能比较测试:MySQL 5.6 GA -vs- MySQL 5.5
    centos去下载mysql应该怎么选择linux版本
    centos_radhat升级系统
    phpmyadmin 配置方法
    js 判断js函数,变量是否存在
    mysqlbinlog- 处理二进制日志文件的实用工具 学习笔记
    linux基本命令
    4 MySQL程序概述(包含mysql配置文件配置原理)-学习笔记
    Python学习笔记4 高级特性_20170618
  • 原文地址:https://www.cnblogs.com/yubing/p/3780869.html
Copyright © 2011-2022 走看看