转载自知乎:https://zhuanlan.zhihu.com/p/37917910 一个程序在运行的时候发生了什么呢? 其实只是一些非常简单的事情:运行指令.处理器从内存中取出指令,译码然后执行.这条指令执行完毕后就又去执行新的指令,一直这样继续下去,直到程序执行完毕. 这里,我们所描绘的就是计算机的基本模型-冯诺依曼模型.听起来很简单不是吗?但是在这个课堂上,我们将学习程序在运行的时候,其他的一些不一样的知识,这些知识能够让系统更加的好用. 有一个软件,它负责让你更容易的运行程序(甚至可以…
一.设计目标 a)规则引擎语法能够满足分单,计费,WMS策略的配置要求.语法是一致和统一的 b)能够在不修改规则引擎模块的情况下,加入任意一个新的规则:实现上述需求之外的规则配置需求 c)运算速度快 d)有良好的展现效果,能够在售前阶段帮助销售 e)提供良好的调试和诊断手段,便于配置规则 二.基本语法及使用 在讲解以下章节的内容时,我们来模拟OMS中一个真实的分单业务场景:根据订单不同的出发地城市和目的地城市指派不一样的承运商并创建运单,如果目的地城市为北京则在天津进行中转. 首先:在相关类中增…
前段时间一直在学习多线程相关的知识,目前也算有了一个整体的认识,今天呢,主要从整体介绍一下,只谈造火箭,拧螺丝这种细节还需要自己深究. 首先是操作系统级别对于多线程的支持,由 CPU 的多级缓存.缓存一致性.乱序执行优化等问题而设计出 Java 内存模型.关于这部分我前面已经总结过. 彻底搞懂 CPU 中的内存结构 Java 内存模型 ,一篇就够了! 说完了操作系统级别的多线程的后备知识以及 Java 内存模型的设计,接着说说 多线程的实现以及Java 中的多线程是怎么实现的,具体可以看这篇.…
1 PyQt5整体介绍 PyQt5是基于图形程序框架Qt5的Python语言实现,由一组Python模块构成. PyQt5的官方网站是:www.riverbankcomputing.co.uk. PyQt5模块介绍的官网地址是:http://pyqt.sourceforge.net/Docs/PyQt5/introduction. html,如图A-1所示. PyQt5包括的主要模块如下. QtCore模块--涵盖了包的核心的非GUI功能,此模块被用于处理程序中涉及的时间.文件.目录.数据类型.…
(一) 安装与备份系统 1. 安装 Windows 7 先使用第三方分区工具(DiskGenius分区)在虚拟机中分区,然后将封装的母盘文件安装写入指定的安装盘,写入完成后重启系统开始部署. 2. 进入最适合封装的系统账户:Administrator 进入Administrator用户的方法有很多,但下面我为大家推荐一个最为直接的方法,且不易产生问题和残留. 系统安装完毕后,会进入OOBE阶段(如下图),此时不要输入任何信息,也不要“下一步”,直接按“Ctrl + Shift + F3”.  …
虚拟化(一):虚拟化及vmware产品介绍 虚拟化(二):虚拟化及vmware workstation产品使用 虚拟化(三):vsphere套件的安装注意及使用 虚拟化(四):vsphere高可用功能前提-共享存储搭建 虚拟化(五):vsphere高可用群集与容错 vmware桌面虚拟化产品包括3种,即vmware horizon view.horizon mirage.horizon workspace. vmware view客户端通过使用微软的RDP协议或vmware 专有的PCoIP协议…
前言 Flink 是一种流式计算框架,为什么我会接触到 Flink 呢?因为我目前在负责的是监控平台的告警部分,负责采集到的监控数据会直接往 kafka 里塞,然后告警这边需要从 kafka topic 里面实时读取到监控数据,并将读取到的监控数据做一些 聚合/转换/计算 等操作,然后将计算后的结果与告警规则的阈值进行比较,然后做出相应的告警措施(钉钉群.邮件.短信.电话等).画了个简单的图如下: 目前告警这块的架构是这样的结构,刚进公司那会的时候,架构是所有的监控数据直接存在 ElasticS…
此系列的总结文章,仅仅是我个人工作总结,有考虑不周之处还请各位同行多多指教. API(Application Programming Interface,应用程序编程接口)是一些预先定义的函数,目的是提供应用程序与开发人员基于某软件或硬件的以访问一组例程的能力,而又无需访问源码,或理解内部工作机制的细节. 开篇就不过多介绍细节了,首先把整体思路介绍一下,整体结构如下: API类库工程本质也是一个软件项目,因此相关的管理结构不可或缺,我要着重强调的是成果物的管理.还是那句好,大家已经做的很好了,只…
转载地址:http://www.cnblogs.com/2050/p/4198792.html gulpjs是一个前端构建工具,与gruntjs相比,gulpjs无需写一大堆繁杂的配置参数,API也非常简单,学习起来很容易,而且gulpjs使用的是nodejs中stream来读取和操作数据,其速度更快.如果你还没有使用过前端构建工具,或者觉得gruntjs太难用的话,那就尝试一下gulp吧. 本文导航: gulp的安装 开始使用gulp gulp的API介绍 一些常用的gulp插件 1.gulp…
C++分布式实时应用框架 (Cpp Distributed Real-time Application Framework) 版权声明:本文版权及所用技术归属smartguys团队所有,对于抄袭,非经同意转载等行为保留法律追究的权利! 在现今软件系统纷纷“云化”的浪潮下,各种支持“云化”的框架.工具层出不穷,但这些现成的工具大多基于JAVA,go等语言,且应用场景均为非实时系统.但基于C++语言,且支持毫秒级响应.大吞吐量的分布式实时应用框架一直是这一领域的空白,Cpp Distributed…
原文地址:https://www.cnblogs.com/wuxl360/p/5817471.html 一.分布式协调技术 在给大家介绍ZooKeeper之前先来给大家介绍一种技术——分布式协调技术.那么什么是分布式协调技术?那么我来告诉大家,其实分布式协调技术 主要用来解决分布式环境当中多个进程之间的同步控制,让他们有序的去访问某种临界资源,防止造成"脏数据"的后果.这时,有人可能会说这个简单,写一个调 度算法就轻松解决了.说这句话的人,可能对分布式系统不是很了解,所以才会出现这种误…
提到Spark Streaming,我们不得不说一下BDAS(Berkeley Data Analytics Stack),这个伯克利大学提出的关于数据分析的软件栈.从它的视角来看,目前的大数据处理可以分为如以下三个类型. 复杂的批量数据处理(batch data processing),通常的时间跨度在数十分钟到数小时之间. 基于历史数据的交互式查询(interactive query),通常的时间跨度在数十秒到数分钟之间. 基于实时数据流的数据处理(streaming data proces…
接触QlikSense(3.1 SR1)已经快一年了,在此记录自己的经验心得,为想了解QlikSense的小伙伴提供一个参考. 1.产品介绍 Qlik公司以QlikView产品成名,QlikSense是其2014年发布的交互式BI产品,相对于第一代引导式BI产品,强调人人BI的概念,产品更加简单易用. 其核心优势为:专利的数据索引技术提供的关联模型让业务用户能够探索数据之间的真正联系. QlikSense分为单机版和服务器版2种,2者报表功能相同,却别表现见下: 单机版——免费,安装到个人电脑,…
本文转载自:https://www.cnblogs.com/lfhy/p/6802781.html 以下为原文内容: 有时前端的项目中需要添加打印的功能,首先要知道打印分为整体打印和局部打印两种,而局部打印又可细分为局部打印指定的部分,和局部打印指定部分之外的部分.实例比文字看起来更清晰,下面我将用代码来描述 1.整体打印 这是最简单的部分 <button id="print1">打印全部</button> $('#print1').click(function…
本博客系列是学习并发编程过程中的记录总结.由于文章比较多,写的时间也比较散,所以我整理了个目录贴(传送门),方便查阅. 并发编程系列博客传送门 本文是转载文章,原文请见此博客,文章主要对java.util.concurrent.atomic开发包下的类进行整体概述与类别划分. 版本说明 在JDK1.5版本之前,多行代码的原子性主要通过synchronized关键字进行保证. 在JDK1.5版本,Java提供了原子类型专门确保变量操作的原子性. 开发包整体说明 原子类型位于java.util.co…
来源:http://blog.csdn.net/phoebin/article/details/3864590 介绍 这篇文章的目的是为了介绍std::vector,如何恰当地使用它们的成员函数等操作.本文中还讨论了条件函数和函数指针在迭代算法中使用,如在remove_if()和for_each()中的使用.通过阅读这篇文章读者应该能够有效地使用vector容器,而且应该不会再去使用C类型的动态数组了.   Vector总览 vector是C++标准模板库中的部分内容,它是一个多功能的,能够操作…
以前一直使用Github,最近看到CSDN出了CODE代码托管功能,由于国内的阿里云服务器很稳定,而且不会被国 墙,所以果断的迁移了,下面就简单的介绍一下CODE的配置使用.其实CSDN的code 何丽萍介绍的很全面了. 首先需要下载GIT客户端,http://git-scm.com/downloads...   然后再code.csdn.net上面创建一个项目,如果 你的项目已经存在,那么请建立项目的时候不要选择自动生成readme文件. 下面的就是配置本地客户端了,确认你在CSDN id,获…
今天的这一节,将从整体上对mina的源代码进行把握,网上已经有好多关于mina源码的阅读笔记,但好多都是列举了一下每个接口或者类的方法.我倒是想从mina源码的结构和功能上对这个框架进行剖析.源码的阅读一般有如下几种方法:第一,根据问题读源码,这种方法可能用的最多,哪里有问题了,然后F3一步步点进去:第二种,专门为了读源码而读,从整体到局部,总用法到设计.第三种,可是根据软件的设计特点,根据特点逐一解读.这几篇文章主要将根据第三种方法进行阅读,因为mina的各个模块很有条理,而且我关注的重点也主…
一.概述 Java是天生就支持并发的语言,支持并发意味着多线程,线程的频繁创建在高并发及大数据量是非常消耗资源的,因为java提供了线程池.在jdk1.5以前的版本中,线程池的使用是及其简陋的,但是在JDK1.5后,有了很大的改善.JDK1.5之后加入了java.util.concurrent包,java.util.concurrent包的加入给予开发人员开发并发程序以及解决并发问题很大的帮助.这篇文章主要介绍下并发包下的Executor接口,Executor接口虽然作为一个非常旧的接口(JDK…
C++分布式实时应用框架 (Cpp Distributed Real-time Application Framework) 在现今软件系统纷纷"云化"的浪潮下,各种支持"云化"的框架.工具层出不穷,但这些现成的工具大多基于JAVA,go等语言,且应用场景均为非实时系统.但基于C++语言,且支持毫秒级响应.大吞吐量的分布式实时应用框架一直是这一领域的空白,Cpp Distributed Real-time Application Framework(CDRAF)也因…
介绍:是一个java的安全(权限)框架 可以完成的功能:认证登录(Authentication).授权(Authorization).加密(cryptography).会话管理(session management).集成web(web support).缓存(caching).记住密码(remember me). 类似功能的框架:Spring security . shiro的执行流程(从外部来看):应用程序->subject->Shiro SecurityManager->Realm…
总结 我们讨论了实现CPU虚拟化的部分底层机制,及我们统称为直接执行(direct execution)的一组技术.基本的思想十分简单明了:直接在CPU上运行你想运行的代码,但是你先得确保将硬件设置好以便在没有操作系统的协助下去限制进程能做的事. 这些通用的方法也在真实生活中被运用.比如:你们中的有孩子的部分人,或者,总该听说过儿童吧,也许对婴儿防护室:一间将危险物品锁在柜中,插座被掩盖住的房间.在这样准备的房间中,你可以让你的孩子自由的玩耍,因为你明白房间中绝多数的潜在危险都被限制了. 以类似…
回顾 根据JVM内存区域的划分,简单的画了下方的这个示意图.区域主要分为两大块,一块是堆区(Heap),我们所New出的对象都会在堆区进行分配,在C语言中的malloc所分配的方法就是从Heap区获取的.而垃圾回收器主要是对堆区的内存进行回收的. 而另一部分则是非堆区,非堆区主要包括用于编译和保存本地代码的“代码缓存区(Code Cache)”.保存JVM自己的静态数据的“永生代(Perm Gen)”.存放方法参数局部变量等引用以及记录方法调用顺序的“Java虚拟机栈(JVM Stack)”和“…
Rookey.Frame v1.0是一套基于.NET MVC的极速开发框架,支持简单逻辑模块零代码编程.支持二次开发,具有高扩展性.高复用性.高伸缩性. 框架特点 (1)简单逻辑模块实现零代码编程,通过简单配置即可实现增.删.改.查.数据列表.导入.导出.单字段编辑.批量编辑.复制.回收站.草稿箱.附属模块显示配置.列表搜索框和表单外键字段自动完成.列表视图自定义.表单自定义.表单附件.权限控制.缓存配置.数据库配置.单据编号配置.模块功能控制等功能,可线上增加功能模块.可线上增加字段 (2)完…
来源 本文整理自 <Tomcat内核设计剖析>.<Tomcat结构解析> Tomcat 整体架构 ​ 如上图所示:包含了Tomcat内部的主要组件,每个组件之间的层次包含关系很清楚.Tomcat大体上可以看成由 Connector 和 Container 组件组成.Connector组件负责在服务器端处理客户端连接(客户端连接.接收客户端消息报文.消息报文的解析等),Container负责对客户端的请求进行逻辑处理,并把结果返回给客户端. 对应的server.xml中节点 <…
正如所有关心docker技术的人所知道的那样,docker是以容器虚拟化为技术为基础的软件,因此在学习docker具体的内容之前,有必要讨论一下虚拟化和容器技术. 虚拟化技术: 在了解虚拟化技术时,各位同学可以以自己机器上运行的虚拟机作为原型,方便理解. 一句话来描述虚拟化技术,就是把真实的计算机硬件资源(内存.CPU.网卡等)通过虚拟化技术虚拟化成虚拟的计算机资源供程序运行使用. 虚拟化为应用程序跨平台而生的: 在计算机技术发展的早期,各类计算平台.计算资源所提供的接口.调用方式十分杂乱,没有…
http://acm.hdu.edu.cn/showproblem.php?pid=4565 首先知道里面那个东西,是肯定有小数的,就是说小数部分是约不走的,(因为b限定了不是一个完全平方数). 因为(a - 1)^2 < b < (a ^ 2),所以其不是完全平方数,假如是,那么设其为c,则有a - 1 < c < a,这是矛盾的 所以,向上取整这个步骤,是必不可少的了. 那么,我在它后面加上一个< 1的数,同时使得它们结合成为整数,那就相当于帮它取整了.根据二项式定理 (…
一.循环嵌套的介绍 一个循环体内又包含另一个完整的循环结构,就称之为循环嵌套.内嵌的循环中还可以嵌套循环,这就是多层循环,也叫做多重循环. 二.在UiPath中结合使用循环嵌套生成99乘法表 1.打开设计器,在设计库中新建一个Sequence,并为Sequence命名 2.在Sequence1里添加Do While循环 3.在Do While1的Body里添加一个Sequence,并在Sequence2中添加Do While循环 4.在添加的Do While2循环的Body里添加一个Sequen…
一.键盘操作的介绍 模拟用户使用键盘操作的一种行为: 例如使用发送热键(Sendhotkey),输入信息 (Typeinto)的操作 二.键盘操作在UiPath中的使用 1.打开设计器,在设计库中新建一个Sequence,为序列命名及设置Sequence存放的路径 2.在Activities中搜索open browser,并将其拖至设计区,且设置打开网站,运行该流程“https://www.baidu.com/” 3.在Activities中搜索 输入信息 (Typeinto),并将其拖至设计区…
常用MQ介绍及对比--<MQ详解及四大MQ比较> RocketMQ环境搭建--<RocketMQ之三:RocketMQ集群环境搭建> RocketMQ物理部署结构 RocketMQ的消息存储--<RocketMQ之六:RocketMQ消息存储> RocketMQ各角色基本数据结构 RocketMQ生产者发送消息过程 RocketMQ消费者 RocketMQ Broker RocketMQ优化 一.RocketMQ介绍 RocketMQ 是阿里巴巴开源的分布式消息中间件.…