分而治之,保持胜利果实

分而治之,保持胜利果实

大家好,又见面了,我是全栈君。

    測完考试系统。去找米老师说了一下測试结果。由于考试系统涉及到大数据问题,主要是并发问题,米老师顺便给我们几个出了一个面试题,“假设须要遍历上百万条。或者上千万条。或者上亿条数据,我们该怎么办?”

    当然。我们几个人都各自说了一下自己的想法。比方分布式啦。多线程啦,还有服从二八定律把经常使用的搜集起来啦等等。最后,米老师在我们的基础上,又继续给我们升华了一下,那就是。分而治之,保持胜利果实。

    数据量大。所以我们能够分开管理。能够利用数据表分区。分布式。多线程,这都是分而治之的实现,仅仅有分而治之是不够的。当我们分而治之后,还要继续保持胜利的果实,比方。我们用索引,数据冗余等形式来实现对已经查询数据进行保持,假设我们须要查询近三年一个饭店的营业情况,我们就能够利用平时,把每一个月的情况放到一个表里,然后再依据每一个月的情况把每年的情况放到一个表里。最后。当我们查询近三年的情况的时候,仅仅须要总和每年的情况就能够了。当然,这里每一个月和每年的情况属于冗余数据,由于我们全然能够通过计算每天的营业情况获得,可是为了我们查询的更快。我们这里须要这种冗余表,同一时候,每一个月、每年的情况,属于我们保存胜利的果实。

    除了数据查询,这样的思想也能够用在其它非常多方面,比方我们须要缓冲一个特别大的文件的时候,就能够才用“分而治之”的思想。先缓冲一部分。在能够使用这部分的同一时候。在缓冲下一部分。给用户更好的体验,事实上这样的思想从百度、谷歌这样的搜索引擎中就能够看到,即使你查询的东西有几百万条数据。它也不会一下子所有查询出。而是一部分、一部分的显示,让你有一个舒适的使用过程。而每次查询出的第一页,都是最经常使用的,也是谷歌百度运用“保持胜利果实”这样的思想的一个实力,由于它把用户经常查询的东西进行整理保持。然后继续给后面的用户使用。它们把这样的从用户那里获取来的“果实”,继续为用户服务。

    当然,跳出程序,在生活中我们依然须要这样的思想。当我们做程序时。总会被这样或那样的问题所困扰。这个时候,我认为我们必须想一想。是不是我把这个问题想得太复杂了,假设这些问题是一个大西瓜的话,我们是不是总是在想假设一口气把这个西瓜吃掉。而不是把它切成一块一块的。或者说如今的英语,假设告诉你你要背三千个单词。你是不是一下子要被吓晕的感觉,可是假设告诉你你仅仅须要每天背60个单词,然后背一个多月不到两个月就背完了是不是有没有轻松一些,然后继续告诉你每天尽管是60个单词可是你仅仅须要花费二十分钟的时候是不是又能够松一口气。假设继续往下说,二十分钟仅仅是两个课间的长度哦亲。是不是一下子认为这件事情太简单了。由于每天学习的时间在九到十个小时,两个十分钟的话那就显得太少了。由于或许你每天酝酿睡觉,想想吃啥都不止二十分钟,这就是“分而治之”的一种思想实现。当然。我们知道如今用的背单词的“百词斩”,会把你常错单词重复出现。这也是一种“保持胜利果实”的实现。

    有时候非常多困难看起来非常难,事实上仅仅要一点点去分析。然后把分析的结果加以利用,我想,不论什么事情都会变得简单,用简单的眼光是看事物,这个世界上就没有了难事。

 

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/116048.html原文链接:https://javaforall.net

(0)
上一篇 2022年1月26日 下午7:00
下一篇 2022年1月26日 下午8:00


相关推荐

  • MVC三层架构的实现

    MVC三层架构的实现在MVC设计模式中认为,任何软件都可以分为三部分组成:1.控制程序流转的控制器Controller2.封装数据处理数据的模型Model3.负责展示数据的视图View在MVC设计思想中要求符合MVC设计思想的软件应该保证MVC这三部分相互独立,互不干扰,每一部分只负责自己擅长的部分。即某一个模块发生变化,应该尽量做到不影响其他两个模块,这样有利于后期的扩展和维护,代码也可复用…

    2022年6月25日
    38
  • open 函数[通俗易懂]

    open 函数[通俗易懂]open函数用来打开一个文件open返回值为一个文件句柄,从操作系统托付给你的python程序,一旦处理完文件,需要归还句柄,只有这样你的程序不会超过一次能打开的文件句柄的数量上限withopen(‘photo.jpg’,’r+’)asf: jpgdata=f.read()open的第⼀个参数是⽂件名。第⼆个(mode打开模式)决定了这个⽂件如何被打开。如果你想读…

    2022年5月25日
    44
  • mysql一主多从 读写分离_MySQL主从复制原理

    mysql一主多从 读写分离_MySQL主从复制原理文章目录前言一、基本概念1.读写分离(1)什么是读写分离(2)为什么要读写分离(3)什么时候要读写分离(4)主从复制与读写分离2.MySQL主从复制(1)mysql支持的复制类型(2)主从复制的工作过程(3)mysql主从复制高延迟的原因(4)mysql主从复制高延迟的解决办法3.常见的MySQL读写分离方式(1)基于程序代码内部实现(2)基于中间代理层实现二、MySQL主从复制架构搭建1.服务器配置2.实验前准备3.mysql主从服务器时间同步4.主服务器

    2022年8月13日
    7
  • Delphi 延迟函数 比sleep 要好的多

    Delphi 延迟函数 比sleep 要好的多

    2021年8月24日
    64
  • Android Studio的Logcat/Run/Terminal/Build等窗口没有了怎么调出

    Android Studio的Logcat/Run/Terminal/Build等窗口没有了怎么调出

    2021年10月2日
    77
  • CORBA的基本内容

    CORBA的基本内容回顾上一讲中在介绍 CORBA 体系结构时 曾强调 CORBA 在提高组件重用性 增强分布计算功能方面具有的突出特点 引入中间件作为事务代理 客户程序与服务器程序完全分离 与面向对象的建模概念相结合 引入接口定义语言描述服务对象功能 CORBA 规范只是描述了 CORBA 系统中各个构件的基本情况以及构件在系统中承担的任务 并没有从功能

    2026年3月26日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号