5str other_str 把 str 与 other_str 进行比较,返回 -1(小于)、0(等于)或 1(大于)。比较是区分大小写的。...9array == other_array 如果两个数组包含相同的元素个数,且每个元素与另一个数组中相对应的元素相等(根据 Object.==),那么这两个数组相等。...13array.assoc(obj) 搜索一个数组,其元素也是数组,使用 obj.== 把 obj 与每个包含的数组的第一个元素进行比较。如果匹配则返回第一个包含的数组,如果未找到匹配则返回 nil。...如果数组本身没有包含元素,则返回 true。27array.eql?(other) 如果 array 和 other 是相同的对象,或者两个数组带有相同的内容,则返回 true。...50array.rassoc(key) 搜索一个数组,其元素也是数组,使用 == 把 key 与每个包含的数组的第二个元素进行比较。如果匹配则返回第一个包含的数组。
前言 本章将会讲解Ruby 数组(Array) Ruby 数组(Array) Ruby 数组是任何对象的有序整数索引集合。数组中的每个元素都与一个索引相关,并可通过索引进行获取。...9 array == other_array 如果两个数组包含相同的元素个数,且每个元素与另一个数组中相对应的元素相等(根据 Object.==),那么这两个数组相等。...13 array.assoc(obj) 搜索一个数组,其元素也是数组,使用 obj.== 把 obj 与每个包含的数组的第一个元素进行比较。...如果匹配则返回第一个包含的数组,如果未找到匹配则返回 nil。 14 array.at(index) 返回索引为 index 的元素。一个负值索引从 self 的末尾开始计数。...50 array.rassoc(key) 搜索一个数组,其元素也是数组,使用 == 把 key 与每个包含的数组的第二个元素进行比较。如果匹配则返回第一个包含的数组。
1.3、指定需要返回的键 在find方法的第二个参数进行指定。默认情况下,始终会返回”_id”,可以通过设置字段为0来表示不返回这个字段。 ?....find({"userId":{$not:{$ne:3}}}); > db.test1.find({"userId":{$not:/1/}}); 5:$mod:将查询的值除以第一个给定的值,如果余数等于等二个值则匹配成功...> db.test1.find({"age":{$mod:[100,3]}}); 说明: age除以100,如果余数为3,则满足条件 6:$in :查询一个键的多个值,只要键匹配其中一个即可 ,...}}); 3:可以使用索引指定查询数组特定位置, {“key.索引号”:value} > db.test1.find({"score.1":7}); 4:查询某个长度的数组,使用$size > db.test1...,那就可能需要使用$elemMatch,以实现对内嵌文档的多个键进行匹配操作 只有内嵌文档中的有key的值是数组 注意:内嵌文档的查询必须要整个文档完全匹配 4:$where查询 在查询中执行任意的JavaScript
运算符 操作运算符 +、-、*、/、%、** 比较运算符 >=、、=== == 运算符只能进行两个对象值的比较,如果要对对象进行比较,则需要使用特定的方法...前一种比较适合编写单行程序时使用,后一种比较适合多行程序的情况。...所以我们在编写程序时,要多所有可能发生的意外情况进行考虑。在没有例外处理的语言中,我们需要对每种可能发生错误的情况进行判断。幸好,Ruby中提供了例外处理机制,它使我们的工作量大大的减轻了。...Array类 数组在任何语言中都是非常重要的一个元素,数组提供了一个数据的容器,让我们可以通过索引快速的遍历和访问需要的数据元素。 Ruby中的数组可以扮演三种角色:普通的索引数组、集合、队列。...Hash的key理论上可以是任何对象,但是实际当中,我们一般选择Numberic、String、Date等做为key值,因为这样的key值在比较中更为准确,而其他的对象是否一致的比较则相对复杂。
具体是个啥意思呢,试想这样一种情况,假如我们要保存的数字有1,5,29,77,344,1908这6个数字,如果用一个数组来进行直接寻址,也就是直接查找数组的下标的方法来查询这几个关键字,那么我们的数组至少需要...将映射到4,1908将映射到3,那么我们就根据余数把这6个数字映射到了一个包含a[0]~a[4]的集合。...=xxx的SQL,而这些SQL又不停的命中上面的几个数据页,如果我们用二级索引number列去查询,那么会造成innodb的"回表"操作(关于回表操作,之前索引那篇文章有讲过),这样比较麻烦。...、有与哈希索引是K-V模式的,多个数据在存储关系上完全是无序的,所以哈希索引不能用于排序; 3、哈希索引不能支持多列联合索引的最左匹配规则,因为不同的值对应的hash结果不一样; 4、如果有大量的重复键值...,这个时候,哈希索引高概率发生碰撞,这种情况下效率会很低; 目前的理解就这么多了,后续有新的内容会进行补充。
类型的乘法 idiv 执行int类型的除法 ldiv 执行long类型的除法 irem 计算int类型除法的余数 lrem 计算long类型除法的余数 ineg 对一个int类型值进行取反操作...按位布尔运算 iand 对int类型值进行“逻辑与”操作 land 对long类型值进行“逻辑与”操作 ior 对int类型值进行“逻辑或”操作 lor 对long类型值进行“逻辑或...0,则跳转 ifne 如果不等于0,则跳转 iflt 如果小于0,则跳转 ifge 如果大于等于0,则跳转 ifgt 如果大于0,则跳转 ifle 如果小于等于0,则跳转 if_icmpcq...如果两个int值相等,则跳转 if_icmpne 如果两个int类型值不相等,则跳转 if_icmplt 如果一个int类型值小于另外一个int类型值,则跳转 if_icmpge 如果一个...类型值,则跳转 ifnull 如果等于null,则跳转 ifnonnull 如果不等于null,则跳转 if_acmpeq 如果两个对象引用相等,则跳转 if_acmpnc 如果两个对象引用不相等
·诊断查询操作符 ·地理空间查询操作符 ·数组查询操作符 ·按位查询操作符 1、比较查询操作符 比较查询操作符内容如下: 操作符 描述 举例 $eq 匹配等于指定的值 db.t_01.find( {..._01.find( { “name”:{ $exists:true,$in: [“david”,”grut”] } } ) $type 如果字段为指定类型,则返回文档 db.t_01.find( {“...--两个字段比较,返回”sal”比”age”大的文档:db.t_01.find( {$expr: { $gt: [“age”,”sal”] } } ) $jsonSchema $jsonSchema可以被用于文档验证器...描述 举例 $all 匹配包含查询中指定的所有元素的数组 --查询t_01集合的name字段同时包含”deng”,”groot”,”lily”的文档db.t_01.find( {“name”:{$all...: [“deng”,”groot”,”lily”]} } ) $elemMatch 返回数组字段中至少有一个元素与所有指定的元素匹配的文档 --查询students集合中的scores数组字段中,至少有一个大于或等于
按位布尔运算 iand 对int类型值进行“逻辑与”操作 land 对long类型值进行“逻辑与”操作 ior 对int类型值进行“逻辑或”操作 lor 对long类型值进行“逻辑或”操作 ixor...获取数组长度 multianewarray 分配新的多维数组 控制流 条件分支指令 ifeq 如果等于0,则跳转 ifne 如果不等于0,则跳转 iflt 如果小于0,则跳转 ifge 如果大于等于0,...则跳转 ifgt 如果大于0,则跳转 ifle 如果小于等于0,则跳转 if_icmpcq 如果两个int值相等,则跳转 if_icmpne 如果两个int类型值不相等,则跳转 if_icmplt 如果一个...if_icmple 如果一个int类型值小于或者等于另外一个int类型值,则跳转 ifnull 如果等于null,则跳转 ifnonnull 如果不等于null,则跳转 if_acmpeq 如果两个对象引用相等...,则跳转 if_acmpnc 如果两个对象引用不相等,则跳转 比较指令 lcmp 比较long类型值 fcmpl 比较float类型值(当遇到NaN时,返回-1) fcmpg 比较float类型值(当遇到
int类型除法的余数 lrem 计算long类型除法的余数 ineg 对一个int类型值进行取反操作 lneg 对一个long类型值进行取反操作...对long类型值进行“逻辑与”操作 ior 对int类型值进行“逻辑或”操作 lor 对long类型值进行“逻辑或”操作 ixor ...如果小于等于0,则跳转 if_icmpcq 如果两个int值相等,则跳转 if_icmpne 如果两个int类型值不相等,则跳转 if_icmplt 如果一个... 如果不等于null,则跳转 if_acmpeq 如果两个对象引用相等,则跳转 if_acmpnc 如果两个对象引用不相等,则跳转 比较指令 lcmp ... 无条件跳转(宽索引) 表跳转指令 tableswitch 通过索引访问跳转表,并跳转 lookupswitch 通过键值匹配访问跳转表,并执行跳转操作
=不等于,大于,=•=~ 匹配正则,!~不匹配正则•in 包含,not in不包含•and,or,nand 非与,xor非或•()复合表达式,!...string 否 分割字符匹配正则 Key-Value 切分 在很多情况下,日志内容本身都是一个类似于 key-value 的格式,但是格式具体的样式却是多种多样的。...重写参数的示例如下: 多项选择 有时候我们会碰上一个日志有多种可能格式的情况。这时候要写成单一正则就比较困难,或者全用 | 隔开又比较丑陋。...而在 filters/ruby 里,我们可以通过 "init" 参数预定义好由每个新字段的名字组成的数组, 然后在 "code" 参数指定的 Ruby 语句里通过两个数组的 zip 操作生成一个哈希并添加进数组里...有时候我们会变更 Logstash 的默认索引名称,通过 PUT 方法上传可以匹配你自定义索引名的模板。
这通常涉及使用哈希码除以桶的数量,然后取余数。例如,如果哈希码为h,桶的数量为N,则桶的索引为h mod N。处理冲突: 由于哈希函数的限制,可能会出现两个不同的键具有相同的哈希码,这就是冲突。...如果存在,则更新相应的值;如果不存在,则将新的键值对插入。检查是否需要进行扩容: 在插入键值对后,会检查当前HashMap的大小是否超过了阈值。...计算索引位置: 接下来,通过对哈希值进行一系列运算,例如取余数等,计算出键值对在数组中的索引位置。这个索引位置就是该键值对在哈希表中的存储位置。...get() 方法会在该位置的链表或红黑树上进行查找。比较键值: 在链表或红黑树中,会遍历每个节点,比较键值,直到找到匹配的键值对,或者确定没有匹配的键值对。...返回结果: 如果找到了匹配的键值对,则返回对应的值;如果没有找到匹配的键值对,则返回 null。
但是如果两个类有相同的 hashcode 怎么办那(我们假设上面的类的 ID 不是唯一的),例如 9 除以 8 和 17 除以 8 的余数都是 1,那么这是不是合法的,回答是:可以这样。...比较基本数据类型,如果两个值相同,则结果为 true,而在比较引用时,如果引用指向内存中的同一对象,结果为 true。 equals() 作为方法,实现对象的比较。...object 类的 equals() 方法的比较规则为:如果两个对象的类型一致,并且内容一致,则返回 true,这些类有:java.io.file,java.util.Date,java.lang.string...当 hashmap 中的元素个数超过数组大小 * loadFactor 时,就会进行数组扩容,loadFactor 的默认值为 0.75,也就是说,默认情况下,数组大小为 16,那么当 hashmap...总结 HashMap的实现原理: 利用 key 的 hashCode 重新 hash 计算出当前对象的元素在数组中的下标。 存储时,如果出现 hash 值相同的 key,此时有两种情况: (1).
这样做的目的是因为数组比较小,尽量避开红黑树结构,这种情况下变为红黑树结构,反而会降低效率,因为红黑树需要进行左旋,右旋,变色这些操作来保持平衡。同事数组长度小于64时,搜索时间相对快一些。...如果计算出来的索引空间没有数据,则直接将"斑"-55数据存储到数组中。跟上面的"A-王炸"数据差不多。...进行比较,如果都不相等,则规划出一个节点存储数据。...底层是采用key的hashCode方法的值结合数组长度进行无符号右移(>>>)、按位异或(^)、按位与(&)计算出索引的 还可以采用:平方取中法,取余数,伪随机数法。这三种效率都比较低。...如果数组长度不是2的n次幂,计算出的索引特别容易相同,及其容易发生hash碰撞,导致其余数组空间很大程度上并没有存储数据,链表或者红黑树过长,效率降低。
(2)取模法 选择一个合适的正整数p,令hash(Key) = key mod p。p如果选择的是比较大的素数,则效果比较好,一般选取p为TableSize,即哈希表的长度。...(6)除留余数法 除留余数法是一种比较常用的哈希函数,它的主要原理是取关键字除以某个数p(p不大于哈希表的长度TableSize)的余数作为哈希地址,即Hash(key)=key%p 使用除留余数法时...(2)链地址法 链地址法解决冲突的主要思想是:如果哈希表空间为[0,m-1],则设置一个由m个指针组成的一维数组CH[m],然后在寻找关键字哈希地址的过程中,所有哈希地址为i的数据元素都插入到头指针为...(3)索引 索引一般可以加速数据的检索速度,加速表与表之间的链接,提高性能,所以在对海量数据进行处理时,考虑到信息量比较大,应该对表建立索引,包括在主键上建立聚簇索引,将聚合索引建立在日期列上等。...一般情况下,Trie树的结构都是采用26叉树进行组织的,每个结点对应一个字母,查找的时候,就是一个字母一个字母地进行匹配,算法的时间复杂度就是单词的长度n,效率很高。
将两个对象相乘将递归合并它们:这类似于加法,但如果两个对象都包含相同键的值,并且值是对象,则两者将使用相同的策略合并。...sort可用于按对象的特定字段或应用任何 jq 过滤器进行排序。 sort_by(foo)通过比较每个元素的结果来比较两个元素 foo。...如果 B 中的所有元素都包含在 A 中的任何元素中,则数组 B 包含在数组 A 中。如果所有元素都包含在对象 B 中,则对象 B 包含在对象 A 中B 中的值包含在具有相同键的 A 中的值中。...如果所有其他类型相等,则假定它们相互包含。 indices(s) 输出一个数组,其中包含.where的索引s 。...输入可能是一个数组,在这种情况下,如果s是一个数组,那么索引输出将是所有元素.匹配的那些s。
这样做的目的是因为数组比较小,尽量避开红黑树结构,这种情况下变为红黑树结构,反而会降低效率,因为红黑树需要进行左旋,右旋,变色这些操作来保持平衡。同事数组长度小于64时,搜索时间相对快一些。...如果计算出来的索引空间没有数据,则直接将”斑”-55数据存储到数组中。跟上面的”A-王炸”数据差不多。...进行比较,如果都不相等,则规划出一个节点存储数据。...底层是采用key的hashCode方法的值结合数组长度进行无符号右移(>>>)、按位异或(^)、按位与(&)计算出索引的 还可以采用:平方取中法,取余数,伪随机数法。这三种效率都比较低。...如果数组长度不是2的n次幂,计算出的索引特别容易相同,及其容易发生hash碰撞,导致其余数组空间很大程度上并没有存储数据,链表或者红黑树过长,效率降低。
而是选择进行数组扩容。 这样做的目的是因为数组比较小,尽量避开红黑树结构,这种情况下变为红黑树结构,反而会降低效率,因为红黑树需要进行左旋,右旋,变色这些操作来保持平衡。...如果计算出来的索引空间没有数据,则直接将"斑"-55数据存储到数组中。跟上面的"A-王炸"数据差不多。...进行比较,如果都不相等,则规划出一个节点存储数据。...底层是采用key的hashCode方法的值结合数组长度进行无符号右移(>>>)、按位异或(^)、按位与(&)计算出索引的 还可以采用:平方取中法,取余数,伪随机数法。这三种效率都比较低。...如果数组长度不是2的n次幂,计算出的索引特别容易相同,及其容易发生hash碰撞,导致其余数组空间很大程度上并没有存储数据,链表或者红黑树过长,效率降低。
现在试想这样一种情况,你现在有个数组,这个数组中有1000个元素,这些元素都是不相同的,你现在要再向里面插入一个元素,如果你现在只有equals方法,那么你就得比较1000次,但是你现在有了hashcode...如果两个对象根据equals(Object o)方法是相等的,则调用这两个对象中任一对象的hashCode方法必须产生相同的整数结果。 3....如果两个对象根据equals(Object o)方法是不相等的,则调用这两个对象中任一个对象的hashCode方法,不要求产生不同的整数结果。但如果能不同,则可能提高散列表的性能。...intValue() == ((Integer) obj).intValue()); } 在 这个定义中,只有在包含相同的整数值的情况下这两个Integer对象是相等的。...其他情 况下,这两个函数是不需要定义的。 equals(): 它是用于进行两个对象的比较的,是对象内容的比较,当然也能用于进行对 象参阅值的比较。什么是对象参阅值的比较?
而是选择进行数组扩容。 这样做的目的是因为数组比较小,尽量避开红黑树结构,这种情况下变为红黑树结构,反而会降低效率,因为红黑树需要进行左旋,右旋,变色这些操作来保持平衡。...如果计算出来的索引空间没有数据,则直接将”斑”-55数据存储到数组中。跟上面的”A-王炸”数据差不多。...进行比较,如果都不相等,则规划出一个节点存储数据。...底层是采用key的hashCode方法的值结合数组长度进行无符号右移(>>>)、按位异或(^)、按位与(&)计算出索引的 还可以采用:平方取中法,取余数,伪随机数法。这三种效率都比较低。...如果数组长度不是2的n次幂,计算出的索引特别容易相同,及其容易发生hash碰撞,导致其余数组空间很大程度上并没有存储数据,链表或者红黑树过长,效率降低。
领取专属 10元无门槛券
手把手带您无忧上云