前言

map集合是key value的集合

HashMap与HashTable的区别

hashMap是线程不安全的,HashTable是读和写都加了synchronized锁,线程安全的,效率比较低,HashTabl不能存储key和value为null,HashMap可以存储key和value为null,存放在数组的第一个位置

HashCode的作用

hashCode是jdk根据对象的地址或者字符串或者数字算出来的int类型的数值,主要应用于:HashMap能够快速查找
HashCode和Equals区别:两个对象的HashCode相同,但是对象不一定相同,如果equals相同,则Hashcode一定相同。

手写HashMap

自定义Map接口
package com.mayikt.ext;/*** @Description: 自定义Map接口* @Author: ChenYi* @Date: 2020/06/20 11:19**/
public interface MayiktMap<K, V> {/*** 集合的大小** @return*/int size();/*** 添加** @param key* @param value* @return*/V put(K key, V value);/*** 获取元素** @param key* @return*/V get(K key);/*** 存在的key和value的对象** @param <K>* @param <V>*/interface Entry<K, V> {K getKey();V getValue();V setValue(V value);}
}
基于ArrayList实现HashMap的代码 数组实现
package com.mayikt.ext.impl;import com.mayikt.ext.MayiktMap;import java.util.ArrayList;
import java.util.List;/*** @Description: 使用ArrayList实现自定义的HashMap* @Author: ChenYi* @Date: 2020/06/20 11:40**/public class MayiktArrayListHashMap<K, V> implements MayiktMap<K, V> {List<MayiktEntry<K, V>> mayiktEntryList = new ArrayList<>();@Overridepublic int size() {return mayiktEntryList.size();}@Overridepublic V put(K key, V value) {MayiktEntry<K, V> mayiktEntry = new MayiktEntry<>(key, value);mayiktEntryList.add(mayiktEntry);return value;}@Overridepublic V get(K key) {for (MayiktEntry<K, V> mayiktEntry : mayiktEntryList) {if (mayiktEntry.getKey().equals(key)) {return mayiktEntry.getValue();}}return null;}class MayiktEntry<K, V> implements MayiktMap.Entry<K, V> {private K k;private V v;public MayiktEntry(K k, V v) {this.k = k;this.v = v;}@Overridepublic K getKey() {return k;}@Overridepublic V getValue() {return v;}@Overridepublic V setValue(V value) {this.v = value;return v;}}
}

存在key相同并且哈希值相同的同一个对象,没有解决hash冲突的问题。

基于LinkList实现HashMap 链表实现
package com.mayikt.ext.impl;import com.mayikt.ext.MayiktMap;import java.util.LinkedList;
import java.util.Objects;/*** @Description:自定义基于LinkList实现HashMap* @Author: ChenYi* @Date: 2020/06/20 12:41**/public class MayiktLinkListHashMap<K, V> implements MayiktMap<K, V> {LinkedList<MayiktLinkListHashMap.MayiktEntry>[] data = new LinkedList[100];@Overridepublic int size() {return data.length;}@Overridepublic V put(K key, V value) {int index = hash(key);LinkedList<MayiktLinkListHashMap.MayiktEntry> linkedList = data[index];MayiktEntry<K, V> mayiktEntry = new MayiktEntry<>(key, value);//说明不存在该linkListif (Objects.isNull(linkedList)) {linkedList = new LinkedList<>();linkedList.add(mayiktEntry);data[index] = linkedList;return value;}//之前存在,需要遍历LinkList集合看是否存在key是否一样,如果一样修改value就可以了for (MayiktEntry entry : linkedList) {if (entry.getKey().equals(key)) {entry.setValue(value);return value;}}//存在hashCode冲突并且key不一样,需要加入一个新的linkedList.add(mayiktEntry);return value;}private int hash(K key) {int hashCode = key.hashCode();return hashCode % data.length;}@Overridepublic V get(K key) {if (Objects.isNull(key)) {return null;}int index = hash(key);LinkedList<MayiktEntry> linkedList = (LinkedList<MayiktEntry>) data[index];if (Objects.isNull(linkedList)) {return null;}for (MayiktEntry mayiktEntry : linkedList) {if (mayiktEntry.getKey().equals(key)) {return (V) mayiktEntry.getValue();}}return null;}class MayiktEntry<K, V> implements MayiktMap.Entry<K, V> {private K k;private V v;public MayiktEntry(K k, V v) {this.k = k;this.v = v;}@Overridepublic K getKey() {return k;}@Overridepublic V getValue() {return v;}@Overridepublic V setValue(V value) {this.v = value;return v;}}
}

HashSet源码解析

底层代码
  public boolean add(E e) {return map.put(e, PRESENT)==null;}

HashSet底层是基于HashMap实现的,添加的值作为HashMap的Key,里面创建了一个对象来作为value,起到占位符的作用,因为HashMap不允许key重复,所以HashSet的值也是唯一的。

1.7HashMap的原理

下面展示一些 内联代码片

jdk1.7的HashMap代码
package com.mayikt.ext.impl;import com.mayikt.ext.MayiktMap;import java.util.HashMap;/*** @Description: 1.7HashMap类* @Author: ChenYi* @Date: 2020/06/21 20:57**/public class MayiktHashMap<K, V> implements MayiktMap<K, V> {/*** 默认的初始化容量*/static final int DEFAULT_INITIAL_CAPACITY = 1 << 4;/*** 默认的加载因子*/static final float DEFAULT_LOAD_FACTOR = 0.75f;/*** 最大的容量*/static final int MAXIMUM_CAPACITY = 1 << 30;/*** 实际的加载因子*/final float loadFactor;/*** 阈值*/int threshold;/*** 空的数组*/final MayiktHashMap.Entry<?, ?>[] EMPTY_TABLE = {};/*** 数组*/transient MayiktHashMap.Entry<K, V>[] table = (Entry<K, V>[]) EMPTY_TABLE;transient int hashSeed = 0;transient int size;transient int modCount;public MayiktHashMap() {this(DEFAULT_INITIAL_CAPACITY, DEFAULT_LOAD_FACTOR);}public MayiktHashMap(int initialCapacity, float loadFactor) {//设置初始容量if (initialCapacity < 0) {throw new IllegalArgumentException("Illegal initial capacity: " +initialCapacity);}if (initialCapacity > MAXIMUM_CAPACITY) {initialCapacity = MAXIMUM_CAPACITY;}if (loadFactor <= 0 || Float.isNaN(loadFactor)) {throw new IllegalArgumentException("Illegal load factor: " +loadFactor);}//设置实际的加载因子this.loadFactor = loadFactor;//实际的容量threshold = initialCapacity;init();}protected void init() {}@Overridepublic int size() {return 0;}@Overridepublic V put(K key, V value) {//第一次添加元素if (table == EMPTY_TABLE) {inflateTable(threshold);}//如果key为nullif (key == null) {//添加key为nullreturn putForNullKey(value);}//hash值int hash = hash(key);//计算数组中的索引位置int index = indexFor(hash, table.length);//遍历Entry,判断是不是同一个key,如果是同一个key则修改值for (MayiktHashMap.Entry<K, V> e = table[index]; e != null; e = e.next) {Object k;if (e.hash == hash && ((k = e.key) == key || key.equals(k))) {V oldValue = e.value;e.value = value;return oldValue;}}//添加元素addEntry(hash, key, value, index);size++;return null;}private V putForNullKey(V value) {//如果之前存在为null的时候,需要修改值for (MayiktHashMap.Entry<K, V> e = table[0]; e != null; e = e.next) {if (e.key == null) {V oldValue = e.value;e.value = value;
//                e.recordAccess(this);return oldValue;}}modCount++;addEntry(0, null, value, 0);return null;}void addEntry(int hash, K key, V value, int bucketIndex) {//看是否需要扩容if ((size >= threshold) && (null != table[bucketIndex])) {//扩容,扩大两倍resize(2 * table.length);hash = (null != key) ? hash(key) : 0;bucketIndex = indexFor(hash, table.length);}createEntry(hash, key, value, bucketIndex);}/*** 扩容** @param newCapacity*/void resize(int newCapacity) {MayiktHashMap.Entry[] oldTable = table;int oldCapacity = oldTable.length;if (oldCapacity == MAXIMUM_CAPACITY) {threshold = Integer.MAX_VALUE;return;}MayiktHashMap.Entry[] newTable = new MayiktHashMap.Entry[newCapacity];transfer(newTable, false);table = newTable;threshold = (int) Math.min(newCapacity * loadFactor, MAXIMUM_CAPACITY + 1);}/*** 扩容之后重新赋值** @param newTable* @param rehash*/void transfer(MayiktHashMap.Entry[] newTable, boolean rehash) {int newCapacity = newTable.length;for (MayiktHashMap.Entry<K, V> e : table) {while (null != e) {MayiktHashMap.Entry<K, V> next = e.next;//重新计算索引indexint i = indexFor(e.hash, newCapacity);e.next = newTable[i];newTable[i] = e;e = next;}}}private void createEntry(int hash, K key, V value, int bucketIndex) {//如果没有发生hash冲突,取出来为null,如果发生hash冲突,采用头插法,新添加的要放在前面Entry<K, V> next = table[bucketIndex];//设置数组中索引的entry对象table[bucketIndex] = new MayiktHashMap.Entry<>(hash, key, value, next);}/*** 根据hash值和数组长度计算对应的数组索引** @param hash* @param length* @return*/static int indexFor(int hash, int length) {//length都是2的幂次方偶数,为了减少index冲突,所以需要减1,变成基数,这个是计算机的位运算return hash & (length - 1);}/*** 计算hash** @param k* @return*/final int hash(Object k) {int h = hashSeed;if (0 != h && k instanceof String) {return sun.misc.Hashing.stringHash32((String) k);}h ^= k.hashCode();h ^= (h >>> 20) ^ (h >>> 12);return h ^ (h >>> 7) ^ (h >>> 4);}private void inflateTable(int toSize) {//设置初始容量为2的幂次方,都是偶数来的int capacity = roundUpToPowerOf2(toSize);threshold = (int) Math.min(capacity * loadFactor, MAXIMUM_CAPACITY + 1);table = new MayiktHashMap.Entry[capacity];
//        initHashSeedAsNeeded(capacity);}private static int roundUpToPowerOf2(int number) {// assert number >= 0 : "number must be non-negative";int rounded = number >= MAXIMUM_CAPACITY? MAXIMUM_CAPACITY: (rounded = Integer.highestOneBit(number)) != 0? (Integer.bitCount(number) > 1) ? rounded << 1 : rounded: 1;return rounded;}@Overridepublic V get(K key) {if (key == null) {return getForNullKey();}MayiktHashMap.Entry<K, V> entry = getEntry(key);return null == entry ? null : entry.getValue();}/*** 获取key为null的值** @return*/private V getForNullKey() {if (size == 0) {return null;}for (MayiktHashMap.Entry<K, V> e = table[0]; e != null; e = e.next) {if (e.key == null) {return e.value;}}return null;}private Entry<K, V> getEntry(K key) {if (size == 0) {return null;}int hash = (key == null) ? 0 : hash(key);for (MayiktHashMap.Entry<K, V> e = table[indexFor(hash, table.length)]; e != null; e = e.next) {Object k;if (e.hash == hash && ((k = e.key) == key || (key != null && key.equals(k)))) {return e;}}return null;}static class Entry<K, V> implements MayiktMap.Entry<K, V> {final K key;V value;MayiktHashMap.Entry<K, V> next;int hash;/*** Creates new entry.*/Entry(int h, K k, V v, MayiktHashMap.Entry<K, V> next) {value = v;this.next = next;key = k;hash = h;}@Overridepublic final K getKey() {return key;}@Overridepublic final V getValue() {return value;}@Overridepublic final V setValue(V newValue) {V oldValue = value;value = newValue;return oldValue;}}
}

总结:

  • 底层是基于数组+链表来实现的,通过使用Entry对象来存储key和value值,并且Entry是一个单向链表,只记录下个节点的指针,没有记录上一个的节点的指针
  • 默认的初始容量是16,加载因子是0.75
  • 支持key为null的存放,存放在数组中索引为0的位置,第一个位置
  • 数组的长度都是2的幂次方,偶数来的,即使在new出一个HashMap指定的初始容量为奇数的时候,但是在第一次添加元素的时候会通过计算,取离当前指定容量最小的2的幂次方作为数组的容量,比如当前指定数组为3,则取4,如果为9则取16
  • 为了减少数组index冲突,使用了hash & (length - 1)的位运算,因为length都是偶数,为了减少index冲突,所以减1变成奇数,这样在进行与运算的时候能够减少index冲突
  • 为了能够充分利用资源,在达到扩容的阈值的时候,准备resize的时候,还需要判断对应的数组索引有没有发生冲突了,如果没有的时候不会扩容先,(size >= threshold) && (null != table[bucketIndex]),扩容都是扩大两倍
  • 数组的长度扩大两倍之后,还需要调用transfer函数进行计算新的index值,放到扩容后的数组中
  • load_factor加载因子为0.75的原因,因为如果加载因子很大的时候,说明阈值很大,数组快要满的时候才进行resize,这个时候发生index冲突很多,如果加载因子过小的时候,阈值比较小,很快就会扩容,数组的空间内存不能够充分的利用,为了保证冲突的机会和空间利用率之间保持一种平衡,所以使用0.75是最好的
  • put方法的实现先计算出key的哈希值,然后再通过indexFor方法计算出在数组中的索引位置
  • index冲突和hash冲突的区别,index冲突是因为底层使用二进制运算产生相同的index,对象不同,但是二进制产生相同的index,hash冲突对象不同,但是hashCode相同
  • 根据key查询的时间复杂度
    1.如果该key没有发生hash冲突,直接根据index从数组中获取,时间复杂度为O(1)
    2.如果该key发生了hash冲突,则需要从链表中查询,查询效率比较慢

jdk7存在的问题

  • 线程不安全,链表如果过长,会导致查询效率低,时间复杂度O(n)
  • 扩容的时候会存在死循环的问题
    1.当在多线程的情况下,同时对HashMap实现扩容,因为每次数组在扩容的时候,新的数组长度发生了变化,需要重新计算index值,需要将原来的table中的数据移动到新的table中,e.next=new Table[i],操作的是共享变量,因为之前是同一个链表的,重新计算index值的时候还是会在同一个链表中的(hash值是不变的),如之前是B-A,然后两个线程进行同时操作,由于是采用的是头插法,当线程1重新计算index完成并且已经把指针改成A-B,但线程2这个时候才开始计算,这个时候B-A-B,就会造成循环引用,死循环了。
  • jdk7中的hashMap计算hash非常均摊,减少hash冲突问题,降低查询效率
  • jdk8中的hashMap计算hash非常简单,存在hash冲突的概率比较大,但是jdk8使用了红黑树解决了查询效率慢的问题

jdk8HashMap

总结:

  • 底层是才有数组+链表+红黑树(一种平衡二叉树)来实现的,时间复杂度是O(logn)
  • 计算hash的函数比较简单,因为当发生了冲突之后,会才有红黑树来存储,不会导致链表过长,查询效率降低
  • 当链表的长度超过8的时候,并且数组的容量大于64的情况下链表才会转为红黑树,如果链表长度超过了8但数组的长度没有超过64的时候只是会扩容,容量扩大两倍,超过了64的情况下就会将整个单向链表转换成双向链表,再将整个双向链表转成红黑树
  • 扩容的时候会重新计算index值,但是注意之前是同一个链表的还是会在同一个链表中,因为同一个链表hash值都是相同的,经过index= (n - 1) & hash
    计算处理的index都是相同的,所以扩容的时候如果之前是同一个链表的,扩容之后也是在同一链表的
    如果链表的长度小于6的情况下,红黑树就会变成链表

ConcurrentHashMap源码

1.7

  • 默认分成了16个Segment,采用了分段锁,每个Segment有独立的table,Segment继承了ReentrantLock的重入锁,HashEntry来存储数据
  • 根据key计算index存放在Segment位置

1.8

  • 采用了cas无锁机制
  • 使用Node节点来存储数据,new Node采用了cas乐观锁机制保证线程安全性的问题
  • 如果计算index产生了冲突,使用synchronized上锁
  • 锁的粒度比jdk1.7更加精细

参考:来自蚂蚁课堂

查看全文
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

相关文章

  1. python将图片转换成视频(直接粘帖运行)

    粘帖复制时注意改变代码第4、9行的路径为你的图片文件夹、视频文件名.avi import cv2 import osimg_root = G:/01_test_image/image_/#这里写你的文件夹路径,比如:/home/youname/data/img/,注意最后一个文件夹要有斜杠 fps = 3 #保存视频的FPS,可以适当调整 size=(1280,7…...

    2024/4/14 20:46:50
  2. 第5章-架构篇之Spring-卷3-SpEL

    文章目录一、Evaluation1. EvaluationContext2. 配置二、使用1. 基于XML2. 基于注解三、语法1. 文本2. 属性、数组 、集合3. 行内List4. 行内Maps5. 数组构造器6. 方法7. 运算符8. 类型9. 构造器10. 变量11. 函数12. Bean引用13. 三元运算符(If-Then-Else)14. Elvis 运算符15…...

    2024/4/25 0:09:28
  3. vim替换命令

    目标:将 content 全部替换成 copy正则:「 :%s/content/copy/g 」,有风险改进:「 逐个替换 」 vim a.txt 「 内容如下」 ...Were waiting for content before the site can go live......If you are content with this, lets go ahead with it......Well launch as soon …...

    2024/4/25 0:09:33
  4. 『杭电1228』A + B

    Problem Description读入两个小于100的正整数A和B,计算A+B. 需要注意的是:A和B的每一位数字由对应的英文单词给出.Input测试输入包含若干测试用例,每个测试用例占一行,格式为"A + B =",相邻两字符串有一个空格间隔.当A和B同时为0时输入结束,相应的结果不要输出.Outpu…...

    2024/4/25 0:09:25
  5. 【JS】你不知道的ES6 (一)

    链判断运算符 ES5 我们判断一个深层级的对象是否有某一个 key 需要一层一层去判断,现在我们可以通过?.的方式去获取 // es5 // 错误的写法(当某一个key不存在undefined.key就会代码报错) const firstName = message.body.user.firstName;// 正确的写法 const firstName = …...

    2024/5/4 16:47:05
  6. Linux内核深度解析之中断、异常和系统调用——中断

    中断中断是外围设备通知处理器的一种机制。1. 中断控制器外围设备不是把中断请求直接发送给处理器,而是发给中断控制器,由中断控制器转发给处理器。不同种类的中断控制器的访问方法存在差异,为了屏蔽差异,内核定义了中断控制器描述符irq_chip,每种中断控制器自定义各种操作…...

    2024/5/4 14:47:22
  7. 16.待写

    16.待写...

    2024/5/4 15:35:45
  8. 页面布局方式有哪些?

    静态布局: pc页面无论宽高是否发生改变,元素的布局方式都不会发生改变 双飞翼布局(圣杯布局): 左右固定,中间内容区域随着窗口变大而变大,缩小而缩小 100%布局: 屏幕尺寸越大,显示的内容越多(高度固定) Rem布局(等比缩放布局,弹性布局): 不同的尺寸,显示的内容大…...

    2024/4/25 0:09:22
  9. [PTA] 求组合数

    本题要求编写程序,根据公式C​n​m​​=​m!(n−m)!​​n!​​算出从n个不同元素中取出m个元素(m≤n)的组合数。建议定义和调用函数fact(n)计算n!,其中n的类型是int,函数类型是double。输入格式:输入在一行中给出两个正整数m和n(m≤n),以空格分隔。输出格式:按照格式“…...

    2024/5/4 15:49:37
  10. JNDI

    JNDI含义 JNDI是 Java命名与目录接口(Java Naming and Directory Interface) 是一个为Java应用程序提供命名服务的应用程序接口,为我们提供了查找和访问各种命名和目录服务的通用统一的接口.通过JNDI统一接口我们可以来访问各种不同类型的服务 JNDI可以把java应用程序访问数据库…...

    2024/4/25 0:09:19
  11. 开发常用快捷键

    开发常用快捷键IDEAVSVSCode浏览器 IDEA 复制当前行到下一行:CTRL+D 添入getset方法:Alt+Insert 快速创建主函数:PSVM 快速选中代码:CTRL+W 切换标签:Ctrl+Tab 下方插入一行空行:Shift+Enter 移动一行代码:Ctrl+Shift+↑/↓ 或者 Alt+Shift+↑/↓ 删除一行代码:Ctrl+…...

    2024/4/25 0:09:19
  12. ontextmenu事件

    简介它属于DOM元素事件 所有浏览器都支持ontextmenu事件详情点击 使用<body><div id="wrap"></div> </body>document.oncontextmenu=function(ev){ev = ev||event;var x = ev.clientX;var y = ev.clientY;var wrap =document.querySelector(…...

    2024/4/24 4:18:13
  13. 嵌入式计算机视觉开发

    嵌入式计算机视觉开发...

    2024/5/3 2:04:43
  14. 【剑指offer】序列化二叉树

    问题描述 请实现两个函数,分别用来序列化和反序列化二叉树 二叉树的序列化是指:把一棵二叉树按照某种遍历方式的结果以某种格式保存为字符串,从而使得内存中建立起来的二叉树可以持久保存。序列化可以基于先序、中序、后序、层序的二叉树遍历方式来进行修改,序列化的结果是…...

    2024/4/25 0:09:18
  15. Unity简单自定义窗口的创建(Unity3d / C#)

    在Assets里面创建一个Editor文件夹,创建一个新的 C# 脚本叫MyWindow(名字可以自己修改,对应代码也要修改),写入代码,点击unity界面的Window菜单栏,然后点击EditColor即可打开界面(可自行修改) 界面样式:代码: using UnityEngine; using UnityEditor;public class My…...

    2024/4/25 0:09:17
  16. Leetcode 437. Path Sum III (python+cpp)

    Leetcode 437. Path Sum III题目错误解法:正确解法: 题目错误解法: 这道题目坑爹的地方在于路径可以不从根节点开始。刚看到题目的时候天真的以为是从根节点开始,于是就有了下面的错误解法: class Solution:def pathSum(self, root: TreeNode, sum: int) -> int:self.c…...

    2024/4/25 0:09:13
  17. JAVA之对象的转型(向上自动转型、向下的强制转型、特殊转型int类型)

    ...

    2024/4/25 0:09:13
  18. HBASE LSM树 以及针对读操作的优化方式(多路归并(compact),布隆过滤器)

    LSM存储引擎是在B+树的基础上衍生过来的,目的就是为了在读和写之间,提高写的性能。所以,LSM树的弊端也由此可见,对读并不是很友好,所以,针对LSM树,有后续compact,布隆过滤器,blockCache等优化方式。来弥补对读的查询。LSM树的索引一般由2部分构成,一部分是内存部分,…...

    2024/4/14 20:46:57
  19. 局部搜索、模拟退火和遗传算法求解TSP问题

    模拟退火和遗传算法求解TSP问题 源代码传送门:GITHUB 数据传送门:TSPLIB 文章目录模拟退火和遗传算法求解TSP问题摘要1 导言1.1 问题重述1.2 TSP问题选择1.3 思路设计1.4 结果简览2 实验过程2.1 TSPbase2.2 LocalSearch2.2.1 流程图2.2.2 满意度、活跃度机制2.2.3 邻域操作2.…...

    2024/4/25 13:38:39
  20. C++ primer plus pre 4.6 chapter source code

    2.3.1. 使用cin 2.3.2. 使用cout进行拼接carrot();2.4.1. 函数sqrt();2.4.2. 函数变体pow();random1();2.4.3. 用户定义的函数cinNumFunc();2.4.4. 用户定义有返回值的函数userCustom();3.1.3. 整型short、int、long和long longshowClimit(); see_exceed();3.1.8. char 类型:…...

    2024/4/26 1:31:46

最新文章

  1. linux下C热补丁

    linux运行进程热补丁&#xff08;一&#xff09;之函数替换_linux 热补丁的实现-CSDN博客 一、实现目标 在Linux环境下&#xff08;x86_64&#xff09;对正在运行进程的函数替换&#xff0c;不改变该进程的可执行文件内容&#xff0c;通过使用汇编指令JMP完成运行中进程的函数…...

    2024/5/4 16:53:44
  2. 梯度消失和梯度爆炸的一些处理方法

    在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言&#xff0c;在此感激不尽。 权重和梯度的更新公式如下&#xff1a; w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...

    2024/3/20 10:50:27
  3. JVM学习笔记

    文章目录 一、内存模型1. 程序计数器2. 栈3. 本地方法栈4. 堆5. 方法区方法区位置字符串常量池位置 6. 直接内存 二、虚拟机参数设置三、类的生命周期1. 加载2. 连接1&#xff09;验证2&#xff09;准备3&#xff09;解析 3. 初始化4. 卸载 四、类加载器1. 启动类加载器2. 扩展…...

    2024/5/1 13:33:02
  4. Redis Stack十部曲之三:理解Redis Stack中的数据类型

    文章目录 前言String字符串作为计数器限制 List限制列表阻塞列表自动创建和删除聚合类型键限制 Set限制 Hash限制 Sorted Set范围操作字典操作更新分数 JSON路径限制 BitMapBitfieldProbabilisticHyperLogLogBloom filterCuckoo filtert-digestTop-KCount-min sketchConfigurat…...

    2024/5/4 13:36:16
  5. 【外汇早评】美通胀数据走低,美元调整

    原标题:【外汇早评】美通胀数据走低,美元调整昨日美国方面公布了新一期的核心PCE物价指数数据,同比增长1.6%,低于前值和预期值的1.7%,距离美联储的通胀目标2%继续走低,通胀压力较低,且此前美国一季度GDP初值中的消费部分下滑明显,因此市场对美联储后续更可能降息的政策…...

    2024/5/1 17:30:59
  6. 【原油贵金属周评】原油多头拥挤,价格调整

    原标题:【原油贵金属周评】原油多头拥挤,价格调整本周国际劳动节,我们喜迎四天假期,但是整个金融市场确实流动性充沛,大事频发,各个商品波动剧烈。美国方面,在本周四凌晨公布5月份的利率决议和新闻发布会,维持联邦基金利率在2.25%-2.50%不变,符合市场预期。同时美联储…...

    2024/5/2 16:16:39
  7. 【外汇周评】靓丽非农不及疲软通胀影响

    原标题:【外汇周评】靓丽非农不及疲软通胀影响在刚结束的周五,美国方面公布了新一期的非农就业数据,大幅好于前值和预期,新增就业重新回到20万以上。具体数据: 美国4月非农就业人口变动 26.3万人,预期 19万人,前值 19.6万人。 美国4月失业率 3.6%,预期 3.8%,前值 3…...

    2024/4/29 2:29:43
  8. 【原油贵金属早评】库存继续增加,油价收跌

    原标题:【原油贵金属早评】库存继续增加,油价收跌周三清晨公布美国当周API原油库存数据,上周原油库存增加281万桶至4.692亿桶,增幅超过预期的74.4万桶。且有消息人士称,沙特阿美据悉将于6月向亚洲炼油厂额外出售更多原油,印度炼油商预计将每日获得至多20万桶的额外原油供…...

    2024/5/3 23:10:03
  9. 【外汇早评】日本央行会议纪要不改日元强势

    原标题:【外汇早评】日本央行会议纪要不改日元强势近两日日元大幅走强与近期市场风险情绪上升,避险资金回流日元有关,也与前一段时间的美日贸易谈判给日本缓冲期,日本方面对汇率问题也避免继续贬值有关。虽然今日早间日本央行公布的利率会议纪要仍然是支持宽松政策,但这符…...

    2024/4/27 17:58:04
  10. 【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响

    原标题:【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响近日伊朗局势升温,导致市场担忧影响原油供给,油价试图反弹。此时OPEC表态稳定市场。据消息人士透露,沙特6月石油出口料将低于700万桶/日,沙特已经收到石油消费国提出的6月份扩大出口的“适度要求”,沙特将满…...

    2024/4/27 14:22:49
  11. 【外汇早评】美欲与伊朗重谈协议

    原标题:【外汇早评】美欲与伊朗重谈协议美国对伊朗的制裁遭到伊朗的抗议,昨日伊朗方面提出将部分退出伊核协议。而此行为又遭到欧洲方面对伊朗的谴责和警告,伊朗外长昨日回应称,欧洲国家履行它们的义务,伊核协议就能保证存续。据传闻伊朗的导弹已经对准了以色列和美国的航…...

    2024/4/28 1:28:33
  12. 【原油贵金属早评】波动率飙升,市场情绪动荡

    原标题:【原油贵金属早评】波动率飙升,市场情绪动荡因中美贸易谈判不安情绪影响,金融市场各资产品种出现明显的波动。随着美国与中方开启第十一轮谈判之际,美国按照既定计划向中国2000亿商品征收25%的关税,市场情绪有所平复,已经开始接受这一事实。虽然波动率-恐慌指数VI…...

    2024/4/30 9:43:09
  13. 【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试

    原标题:【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试美国和伊朗的局势继续升温,市场风险情绪上升,避险黄金有向上突破阻力的迹象。原油方面稍显平稳,近期美国和OPEC加大供给及市场需求回落的影响,伊朗局势并未推升油价走强。近期中美贸易谈判摩擦再度升级,美国对中…...

    2024/4/27 17:59:30
  14. 【原油贵金属早评】市场情绪继续恶化,黄金上破

    原标题:【原油贵金属早评】市场情绪继续恶化,黄金上破周初中国针对于美国加征关税的进行的反制措施引发市场情绪的大幅波动,人民币汇率出现大幅的贬值动能,金融市场受到非常明显的冲击。尤其是波动率起来之后,对于股市的表现尤其不安。隔夜美国股市出现明显的下行走势,这…...

    2024/5/2 15:04:34
  15. 【外汇早评】美伊僵持,风险情绪继续升温

    原标题:【外汇早评】美伊僵持,风险情绪继续升温昨日沙特两艘油轮再次发生爆炸事件,导致波斯湾局势进一步恶化,市场担忧美伊可能会出现摩擦生火,避险品种获得支撑,黄金和日元大幅走强。美指受中美贸易问题影响而在低位震荡。继5月12日,四艘商船在阿联酋领海附近的阿曼湾、…...

    2024/4/28 1:34:08
  16. 【原油贵金属早评】贸易冲突导致需求低迷,油价弱势

    原标题:【原油贵金属早评】贸易冲突导致需求低迷,油价弱势近日虽然伊朗局势升温,中东地区几起油船被袭击事件影响,但油价并未走高,而是出于调整结构中。由于市场预期局势失控的可能性较低,而中美贸易问题导致的全球经济衰退风险更大,需求会持续低迷,因此油价调整压力较…...

    2024/4/26 19:03:37
  17. 氧生福地 玩美北湖(上)——为时光守候两千年

    原标题:氧生福地 玩美北湖(上)——为时光守候两千年一次说走就走的旅行,只有一张高铁票的距离~ 所以,湖南郴州,我来了~ 从广州南站出发,一个半小时就到达郴州西站了。在动车上,同时改票的南风兄和我居然被分到了一个车厢,所以一路非常愉快地聊了过来。 挺好,最起…...

    2024/4/29 20:46:55
  18. 氧生福地 玩美北湖(中)——永春梯田里的美与鲜

    原标题:氧生福地 玩美北湖(中)——永春梯田里的美与鲜一觉醒来,因为大家太爱“美”照,在柳毅山庄去寻找龙女而错过了早餐时间。近十点,向导坏坏还是带着饥肠辘辘的我们去吃郴州最富有盛名的“鱼头粉”。说这是“十二分推荐”,到郴州必吃的美食之一。 哇塞!那个味美香甜…...

    2024/4/30 22:21:04
  19. 氧生福地 玩美北湖(下)——奔跑吧骚年!

    原标题:氧生福地 玩美北湖(下)——奔跑吧骚年!让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 啊……啊……啊 两…...

    2024/5/1 4:32:01
  20. 扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!

    原标题:扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!扒开伪装医用面膜,翻六倍价格宰客!当行业里的某一品项火爆了,就会有很多商家蹭热度,装逼忽悠,最近火爆朋友圈的医用面膜,被沾上了污点,到底怎么回事呢? “比普通面膜安全、效果好!痘痘、痘印、敏感肌都能用…...

    2024/5/4 2:59:34
  21. 「发现」铁皮石斛仙草之神奇功效用于医用面膜

    原标题:「发现」铁皮石斛仙草之神奇功效用于医用面膜丽彦妆铁皮石斛医用面膜|石斛多糖无菌修护补水贴19大优势: 1、铁皮石斛:自唐宋以来,一直被列为皇室贡品,铁皮石斛生于海拔1600米的悬崖峭壁之上,繁殖力差,产量极低,所以古代仅供皇室、贵族享用 2、铁皮石斛自古民间…...

    2024/4/28 5:48:52
  22. 丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者

    原标题:丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者【公司简介】 广州华彬企业隶属香港华彬集团有限公司,专注美业21年,其旗下品牌: 「圣茵美」私密荷尔蒙抗衰,产后修复 「圣仪轩」私密荷尔蒙抗衰,产后修复 「花茵莳」私密荷尔蒙抗衰,产后修复 「丽彦妆」专注医学护…...

    2024/4/30 9:42:22
  23. 广州械字号面膜生产厂家OEM/ODM4项须知!

    原标题:广州械字号面膜生产厂家OEM/ODM4项须知!广州械字号面膜生产厂家OEM/ODM流程及注意事项解读: 械字号医用面膜,其实在我国并没有严格的定义,通常我们说的医美面膜指的应该是一种「医用敷料」,也就是说,医用面膜其实算作「医疗器械」的一种,又称「医用冷敷贴」。 …...

    2024/5/2 9:07:46
  24. 械字号医用眼膜缓解用眼过度到底有无作用?

    原标题:械字号医用眼膜缓解用眼过度到底有无作用?医用眼膜/械字号眼膜/医用冷敷眼贴 凝胶层为亲水高分子材料,含70%以上的水分。体表皮肤温度传导到本产品的凝胶层,热量被凝胶内水分子吸收,通过水分的蒸发带走大量的热量,可迅速地降低体表皮肤局部温度,减轻局部皮肤的灼…...

    2024/4/30 9:42:49
  25. 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...

    解析如下&#xff1a;1、长按电脑电源键直至关机&#xff0c;然后再按一次电源健重启电脑&#xff0c;按F8健进入安全模式2、安全模式下进入Windows系统桌面后&#xff0c;按住“winR”打开运行窗口&#xff0c;输入“services.msc”打开服务设置3、在服务界面&#xff0c;选中…...

    2022/11/19 21:17:18
  26. 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。

    %读入6幅图像&#xff08;每一幅图像的大小是564*564&#xff09; f1 imread(WashingtonDC_Band1_564.tif); subplot(3,2,1),imshow(f1); f2 imread(WashingtonDC_Band2_564.tif); subplot(3,2,2),imshow(f2); f3 imread(WashingtonDC_Band3_564.tif); subplot(3,2,3),imsho…...

    2022/11/19 21:17:16
  27. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...

    win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面&#xff0c;在等待界面中我们需要等待操作结束才能关机&#xff0c;虽然这比较麻烦&#xff0c;但是对系统进行配置和升级…...

    2022/11/19 21:17:15
  28. 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...

    有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows&#xff0c;请勿关闭计算机”的提示&#xff0c;要过很久才能进入系统&#xff0c;有的用户甚至几个小时也无法进入&#xff0c;下面就教大家这个问题的解决方法。第一种方法&#xff1a;我们首先在左下角的“开始…...

    2022/11/19 21:17:14
  29. win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...

    置信有很多用户都跟小编一样遇到过这样的问题&#xff0c;电脑时发现开机屏幕显现“正在配置Windows Update&#xff0c;请勿关机”(如下图所示)&#xff0c;而且还需求等大约5分钟才干进入系统。这是怎样回事呢&#xff1f;一切都是正常操作的&#xff0c;为什么开时机呈现“正…...

    2022/11/19 21:17:13
  30. 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...

    Win7系统开机启动时总是出现“配置Windows请勿关机”的提示&#xff0c;没过几秒后电脑自动重启&#xff0c;每次开机都这样无法进入系统&#xff0c;此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一&#xff1a;开机按下F8&#xff0c;在出现的Windows高级启动选…...

    2022/11/19 21:17:12
  31. 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...

    有不少windows10系统用户反映说碰到这样一个情况&#xff0c;就是电脑提示正在准备windows请勿关闭计算机&#xff0c;碰到这样的问题该怎么解决呢&#xff0c;现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法&#xff1a;1、2、依次…...

    2022/11/19 21:17:11
  32. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...

    今天和大家分享一下win7系统重装了Win7旗舰版系统后&#xff0c;每次关机的时候桌面上都会显示一个“配置Windows Update的界面&#xff0c;提示请勿关闭计算机”&#xff0c;每次停留好几分钟才能正常关机&#xff0c;导致什么情况引起的呢&#xff1f;出现配置Windows Update…...

    2022/11/19 21:17:10
  33. 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...

    只能是等着&#xff0c;别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚&#xff0c;只能是考虑备份数据后重装系统了。解决来方案一&#xff1a;管理员运行cmd&#xff1a;net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...

    2022/11/19 21:17:09
  34. 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?

    原标题&#xff1a;电脑提示“配置Windows Update请勿关闭计算机”怎么办&#xff1f;win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢&#xff1f;一般的方…...

    2022/11/19 21:17:08
  35. 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...

    关机提示 windows7 正在配置windows 请勿关闭计算机 &#xff0c;然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;关机提示 windows7 正在配…...

    2022/11/19 21:17:05
  36. 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...

    钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...

    2022/11/19 21:17:05
  37. 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...

    前几天班里有位学生电脑(windows 7系统)出问题了&#xff0c;具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面&#xff0c;长时间没反应&#xff0c;无法进入系统。这个问题原来帮其他同学也解决过&#xff0c;网上搜了不少资料&#x…...

    2022/11/19 21:17:04
  38. 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...

    本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法&#xff0c;并在最后教给你1种保护系统安全的好方法&#xff0c;一起来看看&#xff01;电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中&#xff0c;添加了1个新功能在“磁…...

    2022/11/19 21:17:03
  39. 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...

    许多用户在长期不使用电脑的时候&#xff0c;开启电脑发现电脑显示&#xff1a;配置windows更新失败&#xff0c;正在还原更改&#xff0c;请勿关闭计算机。。.这要怎么办呢&#xff1f;下面小编就带着大家一起看看吧&#xff01;如果能够正常进入系统&#xff0c;建议您暂时移…...

    2022/11/19 21:17:02
  40. 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...

    配置windows update失败 还原更改 请勿关闭计算机&#xff0c;电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;配置windows update失败 还原更改 请勿关闭计算机&#x…...

    2022/11/19 21:17:01
  41. 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...

    不知道大家有没有遇到过这样的一个问题&#xff0c;就是我们的win7系统在关机的时候&#xff0c;总是喜欢显示“准备配置windows&#xff0c;请勿关机”这样的一个页面&#xff0c;没有什么大碍&#xff0c;但是如果一直等着的话就要两个小时甚至更久都关不了机&#xff0c;非常…...

    2022/11/19 21:17:00
  42. 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...

    当电脑出现正在准备配置windows请勿关闭计算机时&#xff0c;一般是您正对windows进行升级&#xff0c;但是这个要是长时间没有反应&#xff0c;我们不能再傻等下去了。可能是电脑出了别的问题了&#xff0c;来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...

    2022/11/19 21:16:59
  43. 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...

    我们使用电脑的过程中有时会遇到这种情况&#xff0c;当我们打开电脑之后&#xff0c;发现一直停留在一个界面&#xff1a;“配置Windows Update失败&#xff0c;还原更改请勿关闭计算机”&#xff0c;等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢&#xff0…...

    2022/11/19 21:16:58
  44. 如何在iPhone上关闭“请勿打扰”

    Apple’s “Do Not Disturb While Driving” is a potentially lifesaving iPhone feature, but it doesn’t always turn on automatically at the appropriate time. For example, you might be a passenger in a moving car, but your iPhone may think you’re the one dri…...

    2022/11/19 21:16:57