51dev.com IT技术开发者社区

51dev.com 技术开发者社区

bi数据

设计模式之责任链模式(Chain of Responsibility)详解及代码示例

设计模式之责任链模式(Chain of Responsibility)详解及代码示例

  责任链(ChainofResponsibility)模式的定义:责任链模式也叫职责链模式,为了避免请求发送者与多个请求处理者耦合在一起,将所有请求的处理者通过前一对象记住其下一个对象的引用而连成一条链;当有请求发生时,可将请求沿着这条链传递,直到有对象处理它为止。  在责任链模式中,客户只需要将请求发送到责任链上即...

IO模型之BIO代码详解及其优化演进

IO模型之BIO代码详解及其优化演进

  BIO是java1.4之前唯一的IO逻辑,在客户端通过socket向服务端传输数据,服务端监听端口。由于传统IO读数据的时候如果数据没有传达,IO会一直等待输入传入,所以当有请求过来的时候,新起一条线程对数据进行等待、处理,导致每一个链接都对应着服务器的一个线程。  BIO是同步阻塞的,如图所示:         ...

Redis学习之Jedis源码原理分析探究(BIO手写Jedis客户端)

Redis学习之Jedis源码原理分析探究(BIO手写Jedis客户端)

  在Redis的使用过程中,大多数人都是使用现成的客户端,如Jedis,Redisson,Lettuce。因此本文研究用BIO的方式手写Redis客户端尝试,对遇到的问题进行探究及总结。  如何从架构角度思考架构分层?  Redis通讯协议RESP是怎么回事?  如何基于BIO实现Redis客户端?  Redis客户...

二叉树BinaryTree构建测试(无序)

二叉树BinaryTree构建测试(无序)

  此测试仅用于二叉树基本的性质测试,不包含插入、删除测试(此类一般属于有序树基本操作)。//二叉树树类publicclassBinaryTree{publicTreeNoderoot;//有一个根节点publicstaticintindex;publicTreeNodeCreateBTree(int[]a){Tree...

Redis学习之Redis数据结构详解(RedisObject、SDS)

Redis学习之Redis数据结构详解(RedisObject、SDS)

  redis是一个key-value储存系统。和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)、zset(sortedset--有序集合)和hash(哈希类型)  redis字符串:在redis-Client中执行以下命令:SETUSER_NA...

SpringCloud之RabbitMQ消息队列原理及配置

SpringCloud之RabbitMQ消息队列原理及配置

  本篇章讲解RabbitMQ的用途、原理以及配置,RabbitMQ的安装请查看SpringCloud之RabbitMQ安装  1、同步变异步消息  场景:用户下单完成后,发送邮件和短信通知。  运用消息队列之后,用户下单完之后,下单信息写入数据库,再写入消息队列,发送邮件和发送短信各自去消息队列进行读取,节省时间,提...

SpringCloud之RabbitMQ安装

SpringCloud之RabbitMQ安装

  本文介绍Linux以及MACOS下的RabbitMQ安装及配置:  1、安装ErLang  Erlang(['ə:læŋ])是一种通用的面向并发的编程语言,它由瑞典电信设备制造商爱立信所辖的CS-Lab开发,目的是创造一种可以应对大规模并发活动的编程语言和运行环境。rpm--importhttps://packag...

mysql数据库导入与导出

mysql数据库导入与导出

导出数据和表结构:  mysqldump-u用户名-p数据库名>数据库名.sql  mysqldump-uroot-pdbname>dbname.sql       //之后输入密码只导出表结构  mysqldump-u用户名-p-d数据...

linux操作Mysql数据库基本命令

linux操作Mysql数据库基本命令

showdatabases;use数据库名;showtables;describe表名;SELECT*FROM表名createdatabse库名;createtable表名(字段设定列表);mysql>createtablename(->idintauto_incrementnotnullprimaryke...

Mongodb相对于关系型数据库的优缺点(转)

Mongodb相对于关系型数据库的优缺点(转)

与关系型数据库相比,MongoDB的优点:  ①弱一致性(最终一致),更能保证用户的访问速度:  举例来说,在传统的关系型数据库中,一个COUNT类型的操作会锁定数据集,这样可以保证得到“当前”情况下的精确值。这在某些情况下,例如通过ATM查看账户信息的时候很重要,但对于Wordnik来说,数据是不断更新和增长的,这种...

MongoDB的数据类型(四)

MongoDB的数据类型(四)

JSON   JSON是一种简单的数据表示方式,它易于理解、易于解析、易于记忆。但从另一方面来说,因为只有null、布尔、数字、字符串、数组和对象这几种数据类型,所以JSON有一定局限性。例如,JSON没有日期类型,JSON只有一种数字类型,无法区分浮点数和整数,更别说区分32为和64位数...

MongoDB的文档、集合、数据库(二)

MongoDB的文档、集合、数据库(二)

  为了理解MongoDB的名词,可以将其于关系型数据库进行对比:            一、文档  概述文档是MongoDB的核心概念,是数据的基本单元,非常类似于关系数据库中的行。在MongoDB中,文档表示为键值对的一个有序集。MongoDB使用Javascriptshell,文档的表示一般使用Javascrip...

Java SE-基本数据类型对应包装类

Java SE-基本数据类型对应包装类

包装类 Java是面向对象的编程语言,包装类的出现更好的体现这一思想。 其次,包装类作为类是有属性有方法的,功能比基本数据类型要强大。【八种基本数据类型的包装类】  byte——Byte  short——Short  int——Integer  long——Long  float——Float  d...

Redis学习之5种数据类型操作、实现原理及应用场景

Redis学习之5种数据类型操作、实现原理及应用场景

  Redis可以存储可以存储键与5种不同数据结构类型之间的映射。五种数据类型为:STRING(字符串)、LIST(列表)、SET(集合)、HASH(散列)、ZSET(有序集合)。  1、类型定义  String数据结构是简单的key-value类型,使用string时,redis(大多数情况下)并不会理解或者解析其含...

redis对比其余数据库

redis对比其余数据

  Redis属于常见的NoSQL数据库或者说非关系数据库:Redis不使用表,她的数据库也不会预定义或者强制去要求用户对Redis存储的不同数据进行关联。常见数据库对比:          和高性能键值缓存服务器memcached对比:  Redis和mencached都可用于存储键值映射,彼此性能也相差无几,但是①...