Spring源码分析衍生篇四:后处理器 BeanPostPorcess
一、前言
本文是 Spring源码分析:单例bean的获取 - createBean 的衍生文章。主要是因为本人菜鸡,在分析源码的过程中还有一些其他的内容不理解,故开设衍生篇来完善内容以学习。
二、BeanPostProcessor
所谓的 BeanPostProcessor
翻译过来就是Bean后处理器。实际上Spring还有一类后处理器BeanFactoryPostProcessor
,源码还没看到这,暂不分析。
1. 什么是 BeanPostProcessor
BeanPostProcessor
是 Spring提供给我们的一个非常重要的扩展接口,并且Spring内部的很多功能也是通过 BeanPostProcessor 来完成的(目前看到最典型的就是 AnnotationAwareAspectJAutoProxyCreator
的 注入)。
2. BeanPostProcessor 的种类
BeanPostProcessor
在Spring 中的子类非常多(idea 显是有46个),比如
InstantiationAwareBeanPostProcessorAdapter
: 在Spring 的bean加载过程中起了非常重要的作用AnnotationAwareAspectJAutoProxyCreator
: bean 创建过程中的 属性注入时起作用AspectJAwareAdvisorAutoProxyCreator
: Aspect 的 AOP 功能实现也全仰仗BeanPostProcessor 的特性。
三、基本介绍
日常使用中,我们一般编写一个类来实现 BeanPostProcessor
或者 InstantiationAwareBeanPostProcessor
接口,根据每个方法的调用时机,来完成响应的工作。
下面介绍一下接口方法,这里通过 InstantiationAwareBeanPostProcessor
接口来介绍 。InstantiationAwareBeanPostProcessor
是 BeanPostProcessor
的子接口,在 BeanPostProcessor
基础上又扩展了三个方法。
@Component
public class DemoPostProcesser implements InstantiationAwareBeanPostProcessor {//InstantiationAwareBeanPostProcessor 提供的方法, 在 Class<T> -> T 的转换过程中// 此时bean还没创建,可以通过这方法代替 Spring 容器创建的方法@Overridepublic Object postProcessBeforeInstantiation(Class<?> beanClass, String beanName) throws BeansException {System.out.println("DemoPostProcesser.postProcessBeforeInstantiation ### 1");return null;}//InstantiationAwareBeanPostProcessor 提供的方法, 返回的值代表是否需要继续注入属性,// 如果返回true,则会调用postProcessProperties和postProcessPropertyValues 来注入属性// 此时bean已经创建,属性尚未注入@Overridepublic boolean postProcessAfterInstantiation(Object bean, String beanName) throws BeansException {System.out.println("DemoPostProcesser.postProcessAfterInstantiation ### 2");return true;}//InstantiationAwareBeanPostProcessor 提供的方法,可以在这个方法中进行bean属性的注入,Aop 就是在此方法中进行了代理的创建// 只有postProcessAfterInstantiation 返回true 时才会调用@Overridepublic PropertyValues postProcessProperties(PropertyValues pvs, Object bean, String beanName) throws BeansException {System.out.println("DemoPostProcesser.postProcessProperties ### 3");return pvs;}//InstantiationAwareBeanPostProcessor 提供的方法,可以在这个方法中进行bean属性的注入, 这个方法已经过时,使用postProcessProperties 代理// 只有postProcessAfterInstantiation 返回true 时 且 postProcessProperties 返回 null 时调用@Overridepublic PropertyValues postProcessPropertyValues(PropertyValues pvs, PropertyDescriptor[] pds, Object bean, String beanName) throws BeansException {System.out.println("DemoPostProcesser.postProcessPropertyValues ### 4");return pvs;}// BeanPostProcessor 提供的方法,在bean初始化前调用,这时候的bean大体已经创建完成了,在完成一些其他属性的注入@Overridepublic Object postProcessBeforeInitialization(Object bean, String beanName) throws BeansException {System.out.println("DemoPostProcesser.postProcessBeforeInitialization ### 5");return bean;}// BeanPostProcessor 提供的方法,在bean初始化后调用,这时候的bean 已经创建完成了@Overridepublic Object postProcessAfterInitialization(Object bean, String beanName) throws BeansException {System.out.println("DemoPostProcesser.postProcessAfterInitialization ### 6");return bean;}
}
其调用顺序也和标注相同
注意:
这里可以看到 postProcessPropertyValues
方法并没有调用,因为对于一个 过时的方法 没必要必须要调用它,前面也提到 postProcessAfterInstantiation
返回true 并且 postProcessProperties
返回不为null 才会调用该方法,这里postProcessProperties
返回不为null ,所以不会调用postProcessPropertyValues
方法
四、源码中的调用场景
下面为了方便描述,进行一些简化写法,为了后面描述方便
BP : BeanPostProcessor
IBP : InstantiationAwareBeanPostProcessor
SBP : SmartInstantiationAwareBeanPostProcessor
其结构如下图:
这里就不具体贴出多少代码。简单解释一下调用场景
Spring 在启动过程中,会将所有实现了 BeanPostProcessor 接口的子类保存到 AbstractBeanFactory 中的 beanPostProcessors 集合中,如下:
private final List<BeanPostProcessor> beanPostProcessors = new CopyOnWriteArrayList<>();
在适当的时候(这个适当的时候就根据 每个接口方法定义的意义来判断), Spring会获取 所有的BeanPostProcessor 子类集合,即 beanPostProcessors ,经过类型过滤后,调用对应的方法。比如,就是对 InstantiationAwareBeanPostProcessor.postProcessBeforeInstantiation
方法的调用流程(其余方法的调用也类似):
protected Object applyBeanPostProcessorsBeforeInstantiation(Class<?> beanClass, String beanName) {for (BeanPostProcessor bp : getBeanPostProcessors()) {// 因为只有 InstantiationAwareBeanPostProcessor 类型才有postProcessBeforeInstantiation 方法,所以这里要判断一下是不是 InstantiationAwareBeanPostProcessor 类型if (bp instanceof InstantiationAwareBeanPostProcessor) {InstantiationAwareBeanPostProcessor ibp = (InstantiationAwareBeanPostProcessor) bp;Object result = ibp.postProcessBeforeInstantiation(beanClass, beanName);if (result != null) {return result;}}}return null;}
1. InstantiationAwareBeanPostProcessor
下面来介绍在 Spring 创建流程中 每个方法的实际调用位置:
1.1. IBP.postProcessBeforeInstantiation
IBP.postProcessBeforeInstantiation
方法在 Bean 创建 之前调用,我所理解的目的是替换Spring 容器创建bean, 当 IBP.postProcessBeforeInstantiation
返回不为null时,则不会再通过Spring 创建bean,而是使用 IBP.postProcessBeforeInstantiation
返回的bean。
...// 该方法中 调用了postProcessBeforeInstantiation 方法,并且可能调用 postProcessAfterInitialization 方法Object bean = resolveBeforeInstantiation(beanName, mbdToUse);if (bean != null) {return bean;}...// 真正去创建beanObject beanInstance = doCreateBean(beanName, mbdToUse, args);...
resolveBeforeInstantiation
方法内容如下,可以看到 当 applyBeanPostProcessorsBeforeInstantiation
方法(applyBeanPostProcessorsBeforeInstantiation
调用了 postProcessBeforeInstantiation
方法) 返回值不为 null,则会调用 postProcessAfterInstantiation
方法。因为这里bean返回不为null,则代表bean创建成功了,就会调用创建成功后的方法,即 postProcessAfterInstantiation
。
protected Object resolveBeforeInstantiation(String beanName, RootBeanDefinition mbd) {Object bean = null;if (!Boolean.FALSE.equals(mbd.beforeInstantiationResolved)) {// Make sure bean class is actually resolved at this point.if (!mbd.isSynthetic() && hasInstantiationAwareBeanPostProcessors()) {Class<?> targetType = determineTargetType(beanName, mbd);if (targetType != null) {bean = applyBeanPostProcessorsBeforeInstantiation(targetType, beanName);if (bean != null) {bean = applyBeanPostProcessorsAfterInitialization(bean, beanName);}}}mbd.beforeInstantiationResolved = (bean != null);}return bean;}
这里需要注意,在 resolveBeforeInstantiation
方法中,当 bean != null
时 调用了 applyBeanPostProcessorsAfterInitialization
方法,即 BP.postProcessAfterInitialization
方法。这是因为如果 bean != null
, 则说明 bean 的创建已经完成,那么这里则是最后调用bean 的后置处理的机会,即调用BP.postProcessAfterInitialization
方法的最后机会。
1.2. IBP.postProcessAfterInstantiation & IBP.postProcessProperties & IBP.postProcessPropertyValues
IBP.postProcessAfterInstantiation
、IBP.postProcessProperties
、 IBP.postProcessPropertyValues
的调用场景只有一处,在AbstractAutowireCapableBeanFactory#populateBean
方法中,此时bean已经创建完成,正在进行属性注入。而 IBP.postProcessAfterInstantiation
的返回值决定是否继续注入
大致代码如下
protected void populateBean(String beanName, RootBeanDefinition mbd, @Nullable BeanWrapper bw) {...// 调用 postProcessAfterInstantiation 方法吗,如果返回false,直接return;if (!mbd.isSynthetic() && hasInstantiationAwareBeanPostProcessors()) {for (BeanPostProcessor bp : getBeanPostProcessors()) {if (bp instanceof InstantiationAwareBeanPostProcessor) {InstantiationAwareBeanPostProcessor ibp = (InstantiationAwareBeanPostProcessor) bp;if (!ibp.postProcessAfterInstantiation(bw.getWrappedInstance(), beanName)) {return;}}}}... if (hasInstAwareBpps) {if (pvs == null) {pvs = mbd.getPropertyValues();}for (BeanPostProcessor bp : getBeanPostProcessors()) {if (bp instanceof InstantiationAwareBeanPostProcessor) {InstantiationAwareBeanPostProcessor ibp = (InstantiationAwareBeanPostProcessor) bp;// 调用 postProcessProperties 注入属性PropertyValues pvsToUse = ibp.postProcessProperties(pvs, bw.getWrappedInstance(), beanName);if (pvsToUse == null) {if (filteredPds == null) {filteredPds = filterPropertyDescriptorsForDependencyCheck(bw, mbd.allowCaching);}// 调用 postProcessPropertyValues 注入属性pvsToUse = ibp.postProcessPropertyValues(pvs, filteredPds, bw.getWrappedInstance(), beanName);if (pvsToUse == null) {return;}}pvs = pvsToUse;}}}...}
通过代码我们可以比较清楚的看到整体逻辑:
- 若
IBP.postProcessAfterInstantiation
返回true,才会执行下面步骤 - 调用
IBP.postProcessProperties
注入属性, - 若
IBP.postProcessProperties
返回为null,才会执行下面步骤 - 调用
IBP.postProcessPropertyValues
注入属性
2. BeanPostProcessor
2.1. BP.postProcessBeforeInitialization
BP.postProcessBeforeInitialization
调用时机是bean已经创建完成,但是尚未初始化,即一些属性配置尚未完成(我看到的就一个 init-method 的配置)。使用场景也只有一处,即
AbstractAutowireCapableBeanFactory#initializeBean(String, Object, RootBeanDefinition)
。
程序走到这里,代表 resolveBeforeInstantiation
方法 中的 IBP.postProcessBeforeInstantiation
并未代理 bean的创建,在这里则是由Spring 创建的bean的时候来调用。
代码如下,
protected Object initializeBean(final String beanName, final Object bean, @Nullable RootBeanDefinition mbd) {....// 调用 BP.postProcessBeforeInitializationif (mbd == null || !mbd.isSynthetic()) {wrappedBean = applyBeanPostProcessorsBeforeInitialization(wrappedBean, beanName);}// 初始化属性,貌似就初始化了 一个 init-method...if (mbd == null || !mbd.isSynthetic()) {// 调用 BP.postProcessAfterInitializationwrappedBean = applyBeanPostProcessorsAfterInitialization(wrappedBean, beanName);}return wrappedBean;}
2.2. BP.postProcessAfterInitialization
IBP.postProcessAfterInstantiation
的调用都被封装到 AbstractAutowireCapableBeanFactory#applyBeanPostProcessorsAfterInitialization
方法中。
而applyBeanPostProcessorsAfterInitialization
方法的调用
applyBeanPostProcessorsAfterInitialization
方法在下面三个方法中调用:
- AbstractAutowireCapableBeanFactory#resolveBeforeInstantiation
- AbstractAutowireCapableBeanFactory#initializeBean(String, Object, RootBeanDefinition)
- AbstractAutowireCapableBeanFactory#postProcessObjectFromFactoryBean
2.2.1 resolveBeforeInstantiation
resolveBeforeInstantiation
方法的调用有如下三处
-
AbstractAutowireCapableBeanFactory#createBean(String, RootBeanDefinition, Object[]) 这里的调用实际上就是上面讲的 IBP.postProcessBeforeInstantiation 的调用后续,所以这里不再重复
-
AbstractAutowireCapableBeanFactory#getSingletonFactoryBeanForTypeCheck
-
AbstractAutowireCapableBeanFactory#getNonSingletonFactoryBeanForTypeCheck
2.2.2 initializeBean
上面介绍 BP.postProcessBeforeInitialization
的时候已经说了,所以这里不再赘述
2.2.3 postProcessObjectFromFactoryBean
在 FactoryBeanRegistrySupport#getObjectFromFactoryBean
中调用,在从 FactoryBean 中获取 bean时调用,在此调用可以替换掉 FactoryBean 中的返回的bean。
3. SmartInstantiationAwareBeanPostProcessor
SmartInstantiationAwareBeanPostProcessor
在 IBP 之上又扩展了三个方法,不过我们一般不会使用,所以这里简单叙述一下SmartInstantiationAwareBeanPostProcessor
三个方法的作用
-
Class<?> predictBeanType(Class<?> beanClass, String beanName) : 在进行bean类型匹配时调用,返回值和期望值进行匹配。
-
Constructor<?>[] determineCandidateConstructors(Class<?> beanClass, String beanName) : 在 Spring 加载bean 的时候,判断是否需要通过构造注入时,如果返回的值不为空,则进行有参构造注入。
// determineConstructorsFromBeanPostProcessors 中调用了 determineCandidateConstructors 方法,如果ctors != null, 则进行有参构造autowireConstructorConstructor<?>[] ctors = determineConstructorsFromBeanPostProcessors(beanClass, beanName);if (ctors != null || mbd.getResolvedAutowireMode() == AUTOWIRE_CONSTRUCTOR ||mbd.hasConstructorArgumentValues() || !ObjectUtils.isEmpty(args)) {return autowireConstructor(beanName, mbd, ctors, args);}
-
Object getEarlyBeanReference(Object bean, String beanName) : 在 Spring 解决循环依赖时候使用,返回的值将作为ObjectFactory 的 保存的Object,用于循环依赖的提前暴露。
if (earlySingletonExposure) {if (logger.isTraceEnabled()) {logger.trace("Eagerly caching bean '" + beanName +"' to allow for resolving potential circular references");}// getEarlyBeanReference 的返回值作为 ObjectFactory 的返回值保存到singletonFactories缓存中addSingletonFactory(beanName, () -> getEarlyBeanReference(beanName, mbd, bean));}
最后,附一张自己画的调用流程图,由于完全有本人自己阅读绘制,可能会出现些许纰漏,如果发现,麻烦指正,谢谢。
以上:内容部分参考
《Spring源码深度解析》
如有侵扰,联系删除。 内容仅用于自我记录学习使用。如有错误,欢迎指正
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
相关文章
- vue脚手架2版本——项目启动的流程
windows中快捷键 & dos命令 windows + R 调出运行模板 ; 输入 cmd 调出dos窗口(cmd文件:windows环境下的可执行文件) windows + E 调出(我的电脑)资源管理器 cls : 清屏操作 set : 查看当前windows操作系统的环境变量 set name : 查看指定的环境变量 set name=val : 设…...
2024/4/23 15:24:02 - hackme web题 15 - 24
hackme web题 15 - 24 15 hide and seek 点开的网址的源代码205行 16 guestbook 这题太卡了太卡了 点开message list的链接可以得到具体的信息数字型注入id=148 order by 4正常 id=148 order by 5错误,表有四列 后三列都会显示-1 union select 1,(select group_concat(table…...
2024/4/23 15:24:04 - 【路由交换】路由器与交换机
一、路由器1、工作原理1)路由器是三层设备,当数据包进入路由器时,路由器先查看数据包中的目标MAC地址(1)广播:解封装到3层(2)组播:每一个组播地址均存在自己的MAC地址,基于目标MAC就可以判断本地是否需要解封装;若本地加入了该组将解包,否则直接丢弃。(3)单播:目…...
2024/4/23 15:24:03 - LeetCode每日一题1372每个元音包含偶数次的最长子字符串
昨天因有事学习中断,应该批评。后续要补上一题。 今天的题虽然官方给的标签是字符串,但实际上综合性比较强,包括了字符串、位运算、前缀和、哈希表等内容。话不多说,一起来捋一捋思路。 1371.给你一个字符串 s ,请你返回满足以下条件的最长子字符串的长度:每个元音字母,…...
2024/4/23 15:24:03 - 八大排序之插入排序
插入排序 插入排序原理很简单,讲一组数据分成两组,我分别将其称为有序组与待插入组。每次从待插入组中取出一个元素,与有序组的元素进行比较,并找到合适的位置,将该元素插到有序组当中。就这样,每次插入一个元素,有序组增加,待插入组减少。直到待插入组元素个数为0。当…...
2024/4/17 22:09:36 - 计算机网络(4)——分层结构、协议、接口、服务
文章目录0.总揽全局1.为什么分层2.分层结构3.概念总结 视频来源:https://www.bilibili.com/video/BV19E411D78Q?p=5 0.总揽全局1.为什么分层发送文件前要完成的工作:发起通信的计算机必须将数据通信的通路进行激活。 要告诉网络如何识别目的主机。 发起通信的计算机要查明目…...
2024/4/23 15:23:58 - Saltstack (九) --- salt-api 简介及配置
一、salt-api简介 SaltStack 官方提供有REST API格式的 salt-api 项目,将使Salt与第三方系统集成变得尤为简单。 官方提供了三种api模块: rest_cherrypy rest_tornado rest_wsgi官方链接:https://docs.saltstack.com/en/latest/ref/netapi/all/index.html#all-netapi-modules…...
2024/4/23 15:23:57 - 已献出膝盖!GitHub上的宝藏级SpringBoot核心文档,讲得太清晰了
SpringBoot 以其轻量级、内嵌 Web 容器、一键启动、方便调试等特点被越来越多的微服务实践者所采用。然而知其然还要知其所以然,本 Chat 就来讲解 SpringBoot 核心模块的实现原理,在面试的时候也是会被经常问到的,核心内容主要包括:spring-boot-load 模块,正常情况下一个类…...
2024/4/23 15:23:59 - 街景字符编码识别 1
1 比赛说明 比赛链接:https://tianchi.aliyun.com/competition/entrance/531795/introduction 比赛任务:以计算机视觉中字符识别为背景,要求参赛者预测真实场景下的字符识别,这是一个典型的字符识别问题——零基础入门CV赛事之街景字符识别。2.2 数据集训练集:3W张照片验证…...
2024/4/28 13:50:41 - 【Embedding】Airbnb:实时个性化搜索排序
今天学习的是一篇 2018 年的工业论文《Real-time Personalization using Embeddings for Search Ranking at Airbnb》,介绍的是 Word2Vec 在 Airbnb 推荐场景中的应用。大概内容就是从用户日志中抽取用户行为并组成序列,然后通过 Word2Vec 完成训练,最后得到 Item 的 Embedd…...
2024/4/23 15:23:53 - tokitsukaze and Soldier
tokitsukaze and Soldier 枚举 对每个士兵尝试选择 如果比前面的价值更大(且不超过人数限制),更新 每次选择,如果超过人数限制(删人)优先删价值最少的人(优先队列)。 因为删除之后已选人数一定是当前人数限制,要保证删除之后再选下一个人时可以满足这个人的人数限制,…...
2024/4/23 15:23:53 - 02黑马Java笔记之数组
数组及数组的定义 /*数组的概念:是一种容器,可以同时存放多个数据值 * * 数组的特点 * 1.数组是一种引用数据类型 * 2.数组当中的多个数据,类型必须统一 * 3.数组的长度在程序运行期间不可改变 * * 数组的初始化:在内存当中创建一个数组,并且向其中赋予一些默认值。 * * 两…...
2024/4/23 15:23:58 - 【宁泊云】Shiro 介绍 + MD5 加密
什么是 Apache Shiro? Apache Shiro 是 Java 的一个安全框架。目前,使用 Apache Shiro 的人越来越多,因为它相当简单,对比 Spring Security,可能没有 Spring Security 做的功能强大,但是在实际工作时可能并不需要那么复杂的东西,所以使用小而简单的 Shiro 就足够了。对于…...
2024/4/23 15:23:50 - 使用Streamdian播放rtsp视频报错[transport:ws] [ctrl] close. code: 4000 Invalid Domain (credentials)
作者因为这个问题困扰了两天,后面发现是因为域名没有激活的问题。解决办法就是购买激活域名后,在代理视频的主服务器上只能用激活域名代理视频。...
2024/4/23 15:23:52 - 零基础入门CV赛事- 街景字符编码识别-01
写在前面 赛题来源自Google街景图像中的门牌号数据集(The Street View House Numbers Dataset, SVHN),并根据一定方式采样得到比赛数据集。任务链接【阿里云天池大赛】零基础入门CV赛事-街景字符编码识别。 1.赛题分析 1.1数据集样本 数据集报名后可见并可下载,该数据来自真…...
2024/4/17 3:07:49 - 今天毕业啦
虽然今天回答问题时回答的不好,虽然论文的价值可能还没有博客高,但是无论如何都是要毕业啦~希望本科时遇到的所有挫折都变成经验,希望gap的半年里充分利用时间做点东西出来,希望半年后可以顺利出墙,希望下一阶段的学习生涯顺顺利利~...
2024/4/17 3:08:19 - 虚拟机安装 Linux 最完整攻略
工作中如果你是Linux运维,或者程序员,一定经常需要一个Linux的环境来让你折腾。这个时候使用虚拟机对我们来说是一个不错的选择。虚拟化技术目前主要有两种:一、原生架构,这种虚拟机产品直接安装在计算机硬件上,不需要操作系统的支持,这类虚拟机拥有强大的性能,主要用于…...
2024/4/17 3:08:13 - 7-2 真的恭喜你 (10分)
#include <iostream>using namespace std; int main() {int x;cin >> x;if (x >= 90)printf("gong xi ni kao le %d fen!", x);else if (x < 90)printf("kao le %d fen bie xie qi!", x);return 0; }...
2024/4/18 10:55:20 - 天池实战-街景字符编码识别-task1赛题理解
写在前面的话 在写这篇文章的时候,我其实已经把整个项目的流程都过完了,包括Pytorch对于模型的训练等等,所以这篇题目为赛题理解但实际也会说到后面的内容,不光是题目所说的赛题理解这么简单 总之,请你按整个项目的流程去走,去了解整个项目的背景、数据和目的,以及要求的…...
2024/4/23 15:23:55 - 1139 First Contact (30分)
1139 First Contact (30分) 题目:如果a要和b通信,则a要通过其同性朋友c与b的同性朋友d通信后,d才能将信息传递给b。 注意:a,b可能同性。 分析: 1.由于这里要表示是否是朋友的关系,所以一般都是用一个bool型二维数组来表示。但是这里用二维数组可能会超时,所以用一个map…...
2024/4/27 23:56:34
最新文章
- numpy+matplotlib绘制玫瑰线图案
【第10次课]实验十一数据可视化及应用】 声明:著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。 1.简答题 本实验绘制简单图形,要导入numpy库函数和matplotlib.pyplot子库函数: import matplotlib.pyplot as plt impor…...
2024/4/30 16:58:36 - 梯度消失和梯度爆炸的一些处理方法
在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言,在此感激不尽。 权重和梯度的更新公式如下: w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...
2024/3/20 10:50:27 - ssm框架中各层级介绍
1、Spring(业务逻辑层): Spring框架提供了依赖注入(DI)和面向切面编程(AOP)等功能,可以帮助管理Java应用程序中的对象依赖关系和提供横切关注点的支持。 在SSM框架中,S…...
2024/4/30 2:49:54 - 备战蓝桥杯Day37 - 真题 - 特殊日期
一、题目描述 思路: 1、统计2000年到2000000年的日期,肯定是需要遍历 2、闰年的2月是29天,非闰年的2月是28天。我们需要判断这一年是否是闰年。 1、3、5、7、8、10、12月是31天,4、6、9、11月是30天。 3、年份yy是月份mm的倍数…...
2024/4/29 8:09:54 - 【外汇早评】美通胀数据走低,美元调整
原标题:【外汇早评】美通胀数据走低,美元调整昨日美国方面公布了新一期的核心PCE物价指数数据,同比增长1.6%,低于前值和预期值的1.7%,距离美联储的通胀目标2%继续走低,通胀压力较低,且此前美国一季度GDP初值中的消费部分下滑明显,因此市场对美联储后续更可能降息的政策…...
2024/4/29 23:16:47 - 【原油贵金属周评】原油多头拥挤,价格调整
原标题:【原油贵金属周评】原油多头拥挤,价格调整本周国际劳动节,我们喜迎四天假期,但是整个金融市场确实流动性充沛,大事频发,各个商品波动剧烈。美国方面,在本周四凌晨公布5月份的利率决议和新闻发布会,维持联邦基金利率在2.25%-2.50%不变,符合市场预期。同时美联储…...
2024/4/29 6:03:24 - 【外汇周评】靓丽非农不及疲软通胀影响
原标题:【外汇周评】靓丽非农不及疲软通胀影响在刚结束的周五,美国方面公布了新一期的非农就业数据,大幅好于前值和预期,新增就业重新回到20万以上。具体数据: 美国4月非农就业人口变动 26.3万人,预期 19万人,前值 19.6万人。 美国4月失业率 3.6%,预期 3.8%,前值 3…...
2024/4/29 2:29:43 - 【原油贵金属早评】库存继续增加,油价收跌
原标题:【原油贵金属早评】库存继续增加,油价收跌周三清晨公布美国当周API原油库存数据,上周原油库存增加281万桶至4.692亿桶,增幅超过预期的74.4万桶。且有消息人士称,沙特阿美据悉将于6月向亚洲炼油厂额外出售更多原油,印度炼油商预计将每日获得至多20万桶的额外原油供…...
2024/4/29 14:21:50 - 【外汇早评】日本央行会议纪要不改日元强势
原标题:【外汇早评】日本央行会议纪要不改日元强势近两日日元大幅走强与近期市场风险情绪上升,避险资金回流日元有关,也与前一段时间的美日贸易谈判给日本缓冲期,日本方面对汇率问题也避免继续贬值有关。虽然今日早间日本央行公布的利率会议纪要仍然是支持宽松政策,但这符…...
2024/4/27 17:58:04 - 【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响
原标题:【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响近日伊朗局势升温,导致市场担忧影响原油供给,油价试图反弹。此时OPEC表态稳定市场。据消息人士透露,沙特6月石油出口料将低于700万桶/日,沙特已经收到石油消费国提出的6月份扩大出口的“适度要求”,沙特将满…...
2024/4/27 14:22:49 - 【外汇早评】美欲与伊朗重谈协议
原标题:【外汇早评】美欲与伊朗重谈协议美国对伊朗的制裁遭到伊朗的抗议,昨日伊朗方面提出将部分退出伊核协议。而此行为又遭到欧洲方面对伊朗的谴责和警告,伊朗外长昨日回应称,欧洲国家履行它们的义务,伊核协议就能保证存续。据传闻伊朗的导弹已经对准了以色列和美国的航…...
2024/4/28 1:28:33 - 【原油贵金属早评】波动率飙升,市场情绪动荡
原标题:【原油贵金属早评】波动率飙升,市场情绪动荡因中美贸易谈判不安情绪影响,金融市场各资产品种出现明显的波动。随着美国与中方开启第十一轮谈判之际,美国按照既定计划向中国2000亿商品征收25%的关税,市场情绪有所平复,已经开始接受这一事实。虽然波动率-恐慌指数VI…...
2024/4/30 9:43:09 - 【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试
原标题:【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试美国和伊朗的局势继续升温,市场风险情绪上升,避险黄金有向上突破阻力的迹象。原油方面稍显平稳,近期美国和OPEC加大供给及市场需求回落的影响,伊朗局势并未推升油价走强。近期中美贸易谈判摩擦再度升级,美国对中…...
2024/4/27 17:59:30 - 【原油贵金属早评】市场情绪继续恶化,黄金上破
原标题:【原油贵金属早评】市场情绪继续恶化,黄金上破周初中国针对于美国加征关税的进行的反制措施引发市场情绪的大幅波动,人民币汇率出现大幅的贬值动能,金融市场受到非常明显的冲击。尤其是波动率起来之后,对于股市的表现尤其不安。隔夜美国股市出现明显的下行走势,这…...
2024/4/25 18:39:16 - 【外汇早评】美伊僵持,风险情绪继续升温
原标题:【外汇早评】美伊僵持,风险情绪继续升温昨日沙特两艘油轮再次发生爆炸事件,导致波斯湾局势进一步恶化,市场担忧美伊可能会出现摩擦生火,避险品种获得支撑,黄金和日元大幅走强。美指受中美贸易问题影响而在低位震荡。继5月12日,四艘商船在阿联酋领海附近的阿曼湾、…...
2024/4/28 1:34:08 - 【原油贵金属早评】贸易冲突导致需求低迷,油价弱势
原标题:【原油贵金属早评】贸易冲突导致需求低迷,油价弱势近日虽然伊朗局势升温,中东地区几起油船被袭击事件影响,但油价并未走高,而是出于调整结构中。由于市场预期局势失控的可能性较低,而中美贸易问题导致的全球经济衰退风险更大,需求会持续低迷,因此油价调整压力较…...
2024/4/26 19:03:37 - 氧生福地 玩美北湖(上)——为时光守候两千年
原标题:氧生福地 玩美北湖(上)——为时光守候两千年一次说走就走的旅行,只有一张高铁票的距离~ 所以,湖南郴州,我来了~ 从广州南站出发,一个半小时就到达郴州西站了。在动车上,同时改票的南风兄和我居然被分到了一个车厢,所以一路非常愉快地聊了过来。 挺好,最起…...
2024/4/29 20:46:55 - 氧生福地 玩美北湖(中)——永春梯田里的美与鲜
原标题:氧生福地 玩美北湖(中)——永春梯田里的美与鲜一觉醒来,因为大家太爱“美”照,在柳毅山庄去寻找龙女而错过了早餐时间。近十点,向导坏坏还是带着饥肠辘辘的我们去吃郴州最富有盛名的“鱼头粉”。说这是“十二分推荐”,到郴州必吃的美食之一。 哇塞!那个味美香甜…...
2024/4/25 18:39:14 - 氧生福地 玩美北湖(下)——奔跑吧骚年!
原标题:氧生福地 玩美北湖(下)——奔跑吧骚年!让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 啊……啊……啊 两…...
2024/4/26 23:04:58 - 扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!
原标题:扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!扒开伪装医用面膜,翻六倍价格宰客!当行业里的某一品项火爆了,就会有很多商家蹭热度,装逼忽悠,最近火爆朋友圈的医用面膜,被沾上了污点,到底怎么回事呢? “比普通面膜安全、效果好!痘痘、痘印、敏感肌都能用…...
2024/4/27 23:24:42 - 「发现」铁皮石斛仙草之神奇功效用于医用面膜
原标题:「发现」铁皮石斛仙草之神奇功效用于医用面膜丽彦妆铁皮石斛医用面膜|石斛多糖无菌修护补水贴19大优势: 1、铁皮石斛:自唐宋以来,一直被列为皇室贡品,铁皮石斛生于海拔1600米的悬崖峭壁之上,繁殖力差,产量极低,所以古代仅供皇室、贵族享用 2、铁皮石斛自古民间…...
2024/4/28 5:48:52 - 丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者
原标题:丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者【公司简介】 广州华彬企业隶属香港华彬集团有限公司,专注美业21年,其旗下品牌: 「圣茵美」私密荷尔蒙抗衰,产后修复 「圣仪轩」私密荷尔蒙抗衰,产后修复 「花茵莳」私密荷尔蒙抗衰,产后修复 「丽彦妆」专注医学护…...
2024/4/30 9:42:22 - 广州械字号面膜生产厂家OEM/ODM4项须知!
原标题:广州械字号面膜生产厂家OEM/ODM4项须知!广州械字号面膜生产厂家OEM/ODM流程及注意事项解读: 械字号医用面膜,其实在我国并没有严格的定义,通常我们说的医美面膜指的应该是一种「医用敷料」,也就是说,医用面膜其实算作「医疗器械」的一种,又称「医用冷敷贴」。 …...
2024/4/30 9:43:22 - 械字号医用眼膜缓解用眼过度到底有无作用?
原标题:械字号医用眼膜缓解用眼过度到底有无作用?医用眼膜/械字号眼膜/医用冷敷眼贴 凝胶层为亲水高分子材料,含70%以上的水分。体表皮肤温度传导到本产品的凝胶层,热量被凝胶内水分子吸收,通过水分的蒸发带走大量的热量,可迅速地降低体表皮肤局部温度,减轻局部皮肤的灼…...
2024/4/30 9:42:49 - 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...
解析如下:1、长按电脑电源键直至关机,然后再按一次电源健重启电脑,按F8健进入安全模式2、安全模式下进入Windows系统桌面后,按住“winR”打开运行窗口,输入“services.msc”打开服务设置3、在服务界面,选中…...
2022/11/19 21:17:18 - 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。
%读入6幅图像(每一幅图像的大小是564*564) 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 - 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...
win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面,在等待界面中我们需要等待操作结束才能关机,虽然这比较麻烦,但是对系统进行配置和升级…...
2022/11/19 21:17:15 - 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...
有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows,请勿关闭计算机”的提示,要过很久才能进入系统,有的用户甚至几个小时也无法进入,下面就教大家这个问题的解决方法。第一种方法:我们首先在左下角的“开始…...
2022/11/19 21:17:14 - win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...
置信有很多用户都跟小编一样遇到过这样的问题,电脑时发现开机屏幕显现“正在配置Windows Update,请勿关机”(如下图所示),而且还需求等大约5分钟才干进入系统。这是怎样回事呢?一切都是正常操作的,为什么开时机呈现“正…...
2022/11/19 21:17:13 - 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...
Win7系统开机启动时总是出现“配置Windows请勿关机”的提示,没过几秒后电脑自动重启,每次开机都这样无法进入系统,此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一:开机按下F8,在出现的Windows高级启动选…...
2022/11/19 21:17:12 - 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...
有不少windows10系统用户反映说碰到这样一个情况,就是电脑提示正在准备windows请勿关闭计算机,碰到这样的问题该怎么解决呢,现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法:1、2、依次…...
2022/11/19 21:17:11 - 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...
今天和大家分享一下win7系统重装了Win7旗舰版系统后,每次关机的时候桌面上都会显示一个“配置Windows Update的界面,提示请勿关闭计算机”,每次停留好几分钟才能正常关机,导致什么情况引起的呢?出现配置Windows Update…...
2022/11/19 21:17:10 - 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...
只能是等着,别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚,只能是考虑备份数据后重装系统了。解决来方案一:管理员运行cmd:net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...
2022/11/19 21:17:09 - 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?
原标题:电脑提示“配置Windows Update请勿关闭计算机”怎么办?win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢?一般的方…...
2022/11/19 21:17:08 - 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...
关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!关机提示 windows7 正在配…...
2022/11/19 21:17:05 - 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...
钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...
2022/11/19 21:17:05 - 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...
前几天班里有位学生电脑(windows 7系统)出问题了,具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面,长时间没反应,无法进入系统。这个问题原来帮其他同学也解决过,网上搜了不少资料&#x…...
2022/11/19 21:17:04 - 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...
本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法,并在最后教给你1种保护系统安全的好方法,一起来看看!电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中,添加了1个新功能在“磁…...
2022/11/19 21:17:03 - 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...
许多用户在长期不使用电脑的时候,开启电脑发现电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机。。.这要怎么办呢?下面小编就带着大家一起看看吧!如果能够正常进入系统,建议您暂时移…...
2022/11/19 21:17:02 - 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...
配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!配置windows update失败 还原更改 请勿关闭计算机&#x…...
2022/11/19 21:17:01 - 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...
不知道大家有没有遇到过这样的一个问题,就是我们的win7系统在关机的时候,总是喜欢显示“准备配置windows,请勿关机”这样的一个页面,没有什么大碍,但是如果一直等着的话就要两个小时甚至更久都关不了机,非常…...
2022/11/19 21:17:00 - 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...
当电脑出现正在准备配置windows请勿关闭计算机时,一般是您正对windows进行升级,但是这个要是长时间没有反应,我们不能再傻等下去了。可能是电脑出了别的问题了,来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...
2022/11/19 21:16:59 - 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...
我们使用电脑的过程中有时会遇到这种情况,当我们打开电脑之后,发现一直停留在一个界面:“配置Windows Update失败,还原更改请勿关闭计算机”,等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢࿰…...
2022/11/19 21:16:58 - 如何在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