去年面试饿了么的时候吧,被问到了个技术问题。

面试官:听说你做过自动化埋点,那么我们聊聊view的曝光监控吧。

我:之前我是把我们广告的曝光监控放在广告的模型层,然后在bindview的时候做一次曝光的,然后内部做了一次曝光防抖动,避免多次曝光。

面试官:你这样就意味着快速滑动的情况下也会计算一次曝光了,如果我需要的是一个停留超过1.5s同时出现超过view的一半作为有效曝光呢。

我:

 

来个背景音乐吧。

 

面试官:回去等通知吧。


闭关一年后

要解决问题,先归纳下都有那些问题.

  1. 控件在频幕上出现的时间超过1.5s
  2. 有效区域出现超过1半

监听View的移入和移出事件

先解决RecyclerView的1.5s这个问题,大家第一个想到的可能都是addOnScrollListener,然后通过layoutmanager计算可见区域,之后计算两次滑动之后的差异区间。但是不好意思,在下不可能这么简单的被你们猜透。

    override fun onAttachedToWindow() {super.onAttachedToWindow()exposeChecker.updateStartTime()}override fun onDetachedFromWindow() {super.onDetachedFromWindow()onExpose()exposeChecker.updateStartTime()}

我看到这两个方法在RecyclerView内部会在View移动出可视区域的时候被触发。但是为什么呢???带着问题分析源代码。

源码分析

如果各位关心过view的绘制流程,那么应该都知道这两个方法。这两个方法会在页面绑定到window的时候被触发,核心源代码在ViewRootimphost.dispatchVisibilityAggregated(viewVisibility == View.VISIBLE);被触发之后,host就是我们的Activity的DecorView。

 mChildHelper = new ChildHelper(new ChildHelper.Callback(){@Overridepublic void addView(View child, int index) {if (VERBOSE_TRACING) {TraceCompat.beginSection("RV addView");}RecyclerView.this.addView(child, index);if (VERBOSE_TRACING) {TraceCompat.endSection();}dispatchChildAttached(child);}@Overridepublic void attachViewToParent(View child, int index,ViewGroup.LayoutParams layoutParams) {final ViewHolder vh = getChildViewHolderInt(child);if (vh != null) {if (!vh.isTmpDetached() && !vh.shouldIgnore()) {throw new IllegalArgumentException("Called attach on a child which is not"+ " detached: " + vh + exceptionLabel());}if (DEBUG) {Log.d(TAG, "reAttach " + vh);}vh.clearTmpDetachFlag();}RecyclerView.this.attachViewToParent(child, index, layoutParams);}
}

ChildHelper是RecyclerView内部负责专门管理所有子View的一个帮助类。其中通过暴露了接口回调的方式让它和RecyclerView可以绑定到一起。其中我们可以看到当child的add,attach都会触发attachViewToParent,重头戏自然在这个地方,而这个核心源在ViewGroup内了,我们继续看。

    protected void removeDetachedView(View child, boolean animate) {if (mTransition != null) {mTransition.removeChild(this, child);}if (child == mFocused) {child.clearFocus();}if (child == mDefaultFocus) {clearDefaultFocus(child);}if (child == mFocusedInCluster) {clearFocusedInCluster(child);}child.clearAccessibilityFocus();cancelTouchTarget(child);cancelHoverTarget(child);if ((animate && child.getAnimation() != null) ||(mTransitioningViews != null && mTransitioningViews.contains(child))) {addDisappearingView(child);} else if (child.mAttachInfo != null) {child.dispatchDetachedFromWindow();}if (child.hasTransientState()) {childHasTransientStateChanged(child, false);}dispatchViewRemoved(child);}protected void attachViewToParent(View child, int index, LayoutParams params) {child.mLayoutParams = params;if (index < 0) {index = mChildrenCount;}addInArray(child, index);child.mParent = this;child.mPrivateFlags = (child.mPrivateFlags & ~PFLAG_DIRTY_MASK& ~PFLAG_DRAWING_CACHE_VALID)| PFLAG_DRAWN | PFLAG_INVALIDATED;this.mPrivateFlags |= PFLAG_INVALIDATED;if (child.hasFocus()) {requestChildFocus(child, child.findFocus());}dispatchVisibilityAggregated(isAttachedToWindow() && getWindowVisibility() == VISIBLE&& isShown());notifySubtreeAccessibilityStateChangedIfNeeded();}@Overrideboolean dispatchVisibilityAggregated(boolean isVisible) {isVisible = super.dispatchVisibilityAggregated(isVisible);final int count = mChildrenCount;final View[] children = mChildren;for (int i = 0; i < count; i++) {// Only dispatch to visible children. Not visible children and their subtrees already// know that they aren't visible and that's not going to change as a result of// whatever triggered this dispatch.if (children[i].getVisibility() == VISIBLE) {children[i].dispatchVisibilityAggregated(isVisible);}}return isVisible;}

其中dispatchVisibilityAggregated就是我们最前面说的ViewRoot所触发的ViewGroup内的方法,会逐层向下view分发View的attach方法。那么也就是当RecyclerView的子控件被添加到RecyclerView上时,就会触发子view的attachToWindow方法。

剩下来的就是View的detch方法是在哪里被触发的呢,这个就是要看recyclerview的另外一个方法了,就是tryGetViewHolderForPositionByDeadline了。

        @NullableViewHolder tryGetViewHolderForPositionByDeadline(int position,boolean dryRun, long deadlineNs) {if (position < 0 || position >= mState.getItemCount()) {throw new IndexOutOfBoundsException("Invalid item position " + position+ "(" + position + "). Item count:" + mState.getItemCount()+ exceptionLabel());}boolean fromScrapOrHiddenOrCache = false;ViewHolder holder = null;// 0) If there is a changed scrap, try to find from thereif (mState.isPreLayout()) {holder = getChangedScrapViewForPosition(position);fromScrapOrHiddenOrCache = holder != null;}// 1) Find by position from scrap/hidden list/cacheif (holder == null) {holder = getScrapOrHiddenOrCachedHolderForPosition(position, dryRun);if (holder != null) {if (!validateViewHolderForOffsetPosition(holder)) {// recycle holder (and unscrap if relevant) since it can't be usedif (!dryRun) {// we would like to recycle this but need to make sure it is not used by// animation logic etc.holder.addFlags(ViewHolder.FLAG_INVALID);if (holder.isScrap()) {removeDetachedView(holder.itemView, false);holder.unScrap();} else if (holder.wasReturnedFromScrap()) {holder.clearReturnedFromScrapFlag();}recycleViewHolderInternal(holder);}holder = null;} else {fromScrapOrHiddenOrCache = true;}}}........return holder;}

当ViewHolder要被回收的时候就会触发RecyclerView的tryGetViewHolderForPositionByDeadline这个方法,然后我们可以观察到当holder.isScrap()的时候会removeDetachedView(holder.itemView, false);而这个正好触发了子项的viewDetch方法。

解决问题1.5s的问题

从上面的代码分析完之后,我们可以在onAttachedToWindow的方法尾部打上第一个曝光开始的节点,在onDetachedFromWindow的方法下面埋下曝光结束的方法,计算他们的差值,如果当值大于1.5s之后,则调用接口。

View有效区域出现超过1半

这个吧,说起来有点丢脸,我google查出来的,其中核心在于 view.getLocalVisibleRect,这个方法会返回当前的view是否出现在window上了。


fun View.isCover(): Boolean {var view = thisval currentViewRect = Rect()val partVisible: Boolean = view.getLocalVisibleRect(currentViewRect)val totalHeightVisible =currentViewRect.bottom - currentViewRect.top >= view.measuredHeightval totalWidthVisible =currentViewRect.right - currentViewRect.left >= view.measuredWidthval totalViewVisible = partVisible && totalHeightVisible && totalWidthVisibleif (!totalViewVisible)return truewhile (view.parent is ViewGroup) {val currentParent = view.parent as ViewGroupif (currentParent.visibility != View.VISIBLE) //if the parent of view is not visible,return truereturn trueval start = view.indexOfViewInParent(currentParent)for (i in start + 1 until currentParent.childCount) {val viewRect = Rect()view.getGlobalVisibleRect(viewRect)val otherView = currentParent.getChildAt(i)val otherViewRect = Rect()otherView.getGlobalVisibleRect(otherViewRect)if (Rect.intersects(viewRect, otherViewRect)) {//if view intersects its older brother(covered),return truereturn true}}view = currentParent}return false
}fun View.indexOfViewInParent(parent: ViewGroup): Int {var index = 0while (index < parent.childCount) {if (parent.getChildAt(index) === this) breakindex++}return index
}

细节

凡事还是不能忽略到页面切换,当页面切换的时候,我们需要重新计算页面的曝光,你说对不对,最简单的方式是什么呢。

不知道各位有没有关心过viewTree里面的onWindowFocusChanged这个方法,其实当页面切换的情况下,就会触发这个方法。

核心原理其实也是ViewRootImp的handleWindowFocusChanged这个方法会向下分发是否脱离window的方法,然后当接受到IWindow.Stub接受到了WMS的信号之后,则会给ViewRootImp发送一个message,然后从ViewRootImp开始向下分发view变化的生命周期。

  override fun onWindowFocusChanged(hasWindowFocus: Boolean) {super.onWindowFocusChanged(hasWindowFocus)if (hasWindowFocus) {exposeChecker.updateStartTime()} else {onExpose()}}

哎哟 你回来 我们聊点别的啊

总结性结论咯,也就是我们只要在ViewHolder的控件最外面包裹一个我们自定义的Layout,然后通过接口回调的方式,我们就能监控到view的有效曝光时间了。

我觉得即使面试失败的情况下,我们也还是需要在其中学习到一些东西的,毕竟机会还是给有准备的人。当然据我现在所知,应该饿了么用的是阿里的那套控件曝光自动化埋点的方案,还是有些不同的。

面试官:老哥那么我们继续探讨下这个问题啊。Scrollview和NestScrollView怎么监控呢。

我:???黑人老哥又特么来了。

分析问题

还是和上篇文章一样,我们先看下要解决哪些问题。

  1. ScrollView NestScrollView 的滑动监控怎么做。
  2. View有没有像RecyclerView一样的attach和detch方法,超过1.5s的曝光时间。
  3. View出现一半。

滑动监控

一般人肯定告诉你,这个你自定义个scrollview,然后在onScrollChanged实现个滑动监听的回调什么的。不好意思,我偏不,带你看看另外一个神奇的方法。

先给大家介绍下ViewTreeObserver里面所包含的一些接口。

内部类接口备注
ViewTreeObserver.OnPreDrawListener当视图树将要被绘制时,会调用的接口
ViewTreeObserver.OnGlobalLayoutListener当视图树的布局发生改变或者View在视图树的可见状态发生改变时会调用的接口
ViewTreeObserver.OnGlobalFocusChangeListener当一个视图树的焦点状态改变时,会调用的接口
ViewTreeObserver.OnScrollChangedListener当视图树的一些组件发生滚动时会调用的接口
ViewTreeObserver.OnTouchModeChangeListener当视图树的触摸模式发生改变时,会调用的接口格

各位老哥有没有发现一些奇怪的东西混在里面,哈哈哈。

惯例分析下源码

理论上来说,所有视图状态之类的都是和ViewRootImp相关的。特别是ViewTreeObserver相关的,所以我们的源码分析也是从ViewRootImp开始的。

class ViewRootImp {// 根视图绘制private boolean draw(boolean fullRedrawNeeded) {Surface surface = mSurface;if (!surface.isValid()) {return false;}if (DEBUG_FPS) {trackFPS();}if (!sFirstDrawComplete) {synchronized (sFirstDrawHandlers) {sFirstDrawComplete = true;final int count = sFirstDrawHandlers.size();for (int i = 0; i< count; i++) {mHandler.post(sFirstDrawHandlers.get(i));}}}scrollToRectOrFocus(null, false);if (mAttachInfo.mViewScrollChanged) {mAttachInfo.mViewScrollChanged = false;// 调用viewtree的滑动监听mAttachInfo.mTreeObserver.dispatchOnScrollChanged();}.....return useAsyncReport;}}

上面的代码可以看出,当mAttachInfo.mViewScrollChanged这个状态位被设置成true的情况下,就会通知viewTree调用滑动监听了。 那么我们的切入点就很简单了,什么时候谁把这个值设置成ture了,是不是就会触发滑动监听了呢。

class View {final static class AttachInfo {/*** Set to true if a view has been scrolled.*/@UnsupportedAppUsageboolean mViewScrollChanged;}/*** This is called in response to an internal scroll in this view (i.e., the* view scrolled its own contents). This is typically as a result of* {@link #scrollBy(int, int)} or {@link #scrollTo(int, int)} having been* called.** @param l Current horizontal scroll origin.* @param t Current vertical scroll origin.* @param oldl Previous horizontal scroll origin.* @param oldt Previous vertical scroll origin.*/protected void onScrollChanged(int l, int t, int oldl, int oldt) {notifySubtreeAccessibilityStateChangedIfNeeded();if (AccessibilityManager.getInstance(mContext).isEnabled()) {postSendViewScrolledAccessibilityEventCallback(l - oldl, t - oldt);}mBackgroundSizeChanged = true;mDefaultFocusHighlightSizeChanged = true;if (mForegroundInfo != null) {mForegroundInfo.mBoundsChanged = true;}final AttachInfo ai = mAttachInfo;if (ai != null) {ai.mViewScrollChanged = true;}if (mListenerInfo != null && mListenerInfo.mOnScrollChangeListener != null) {mListenerInfo.mOnScrollChangeListener.onScrollChange(this, l, t, oldl, oldt);}}}

View.AttachInfo是View的内部类,其注释已经描述了,当view滑动的时候把这个值设置成true。onScrollChanged也是View的protected的方法,而当ScrollView和NestScrollView的滑动状态被改变的时候就会调用这个方法,而这个方法内则就会把状态设置成true。

测试结果

经过在下的测试吧,OnScrollChangedListener在ScrollView和NestScrollView滑动的时候都会触发回调哦。而上述代码分析,则可以说明当两个滑动组件滑动的时候就会触发对应的回调监听。

View 出现一半

这个监控方法还是和上篇文章一样,请各位大佬直接看上篇文章就好了。

1.5s的曝光时长

先回到之前的文章提到onAttachedToWindow onDetachedFromWindow的两个方法,这两个可以用吗?答案肯定是不行的。那么我们应该怎么办呢??

没有枪没有炮,还是自己造吧。

interface ExposeViewAdapter {fun setExposeListener(listener: (Float) -> Unit)fun setExposeListener(listener: OnExposeListener)fun onVisibleChange(isCover: Boolean)
}

首先我们可以先提供一个适配器,提供onVisibleChange这个方法来代替onAttachedToWindow onDetachedFromWindow


class ExposeScrollChangeListener(scrollView: ViewGroup) :ViewTreeObserver.OnScrollChangedListener, ViewTreeObserver.OnGlobalLayoutListener {private val rootView: ViewGroup? = scrollView.getChildAt(0) as ViewGroup?private val views = hashSetOf<View>()private var lastChildCount = 0init {}override fun onScrollChanged() {views.forEach {val exposeView = it as ExposeViewAdapterexposeView.onVisibleChange(it.visibleRect())}}private fun checkViewSize() {rootView?.apply {lastChildCount = childCountgetChildExpose(rootView)}}private fun getChildExpose(view: View?) {view?.let {if (it is ExposeViewAdapter) {views.add(it)}if (view is ViewGroup) {//遍历ViewGroup,是子view加1,是ViewGroup递归调用for (i in 0 until view.childCount) {val child = view.getChildAt(i)if (child is ExposeViewAdapter) {views.add(child)}if (child is ViewGroup) {getChildExpose(child)}}}}}override fun onGlobalLayout() {val timeUsage = System.currentTimeMillis()checkViewSize()Log.i("expose", "timeCoast:${System.currentTimeMillis() - timeUsage}")}}

首先我们需要监控onGlobalLayout这个方法,在这个方法触发的情况下,去扫描当前的ViewTree,去获取实现了ExposeViewAdapter的所有的View。当滑动监听触发的时候调用之前的view是否被遮挡的方法来判断当前的view是不是在视图上出现了,然后调用onVisibleChange来通知视图是否已经从window上移除。

最后

面试官:哎哟不错哟。

 

我:谦虚有理的小菜逼。

面试官:这种方式感觉还是不够智能,如果让你用动态插桩呢。

我:打扰了,二营长,把我的意大利炮抬过来。

面试官:回家继续等通知把。

粉丝技术裙:

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

相关文章

  1. 2020年6月24日打卡

    Leetcode 16. 最接近的三数之和 方法:排序+双指针 题目 给定一个包括 n 个整数的数组 nums 和 一个目标值 target。找出 nums 中的三个整数,使得它们的和与 target 最接近。返回这三个数的和。假定每组输入只存在唯一答案。 来源:力扣(LeetCode) 链接:https://leetcode-c…...

    2024/4/14 20:49:20
  2. c#设计模式——观察者模式

    目录一 UML类图二 例子三 优缺点3.1 优点3.2 缺点四 事件委托实现 一 UML类图二 例子public class Subject{private List<IObserver> observers = new List<IObserver>();public void Add(IObserver observer){observers.Add(observer);}public void Remove(IObser…...

    2024/4/14 20:49:19
  3. LeetCode六月挑战(6.24 )Unique Binary Search Trees LeetCode 96解题方案

    LeetCode六月挑战(6.24 )Unique Binary Search Trees LeetCode 96解题方案 题目描述 Given n, how many structurally unique BST’s (binary search trees) that store values 1 … n? Example: Input: 3 Output: 5 Explanation: Given n = 3, there are a total of 5 uniq…...

    2024/4/25 0:05:07
  4. [LINUX]高速缓冲区的用户态实现

    高速缓冲区的用户态实现:高速缓冲区理论上也是比较好理解的一个数据结构,他的好处是减少对于慢速IO的高频率访问,从单机的内核态来说,慢速和快速主要是内存和磁盘之间的IO瓶颈,对于多机的分布式文件系统来说,主要是磁盘和网络传输之间的IO差异(因为磁盘和内存内核已经有…...

    2024/4/25 0:05:06
  5. python 机器学习(监督学习—线性模型)

    监督学习—线性模型线性模型利用输入特征的线性函数(linear function)进行预测。一、用于回归的线性模型对于回归问题,线性模型预测的一般公式如下:这里 到 表示单个数据点的特征(本例中特征个数为 p+1),w 和 b 是学习模型的参数, 是模型的预测结果。对于单一特征的数…...

    2024/4/25 0:05:05
  6. VC6.0 MFC 时钟运动 调用对话框设置时间

    时钟运动 问题描述: 在VC6.0的MFC中画一个钟表,有时针、分针、秒针,并实现时针、分针、秒针的运动。 最终部分静态效果图如下:(有需要源码的同学可在评论区留言) 操作详细过程(附部分源码) 1、打开VC6.0,点击屏幕左上角“文件(F)”,选择“新建(N)… Ctrl_N”,如下图…...

    2024/4/25 0:05:05
  7. IDEA如何设置自动补全快捷键

    IDEA如何设置自动补全快捷键 点击IDEA左上角的File–>Settings:找到Keymap,如图 在右侧的框中,找到Main menu,如图所示3.选择Basic,双击左键,选择Remove,然后通过Add keyboard Shortcut进行设置快捷键4.通常设置成 Alt+/,最后点击Apply,然后点击OK即可。...

    2024/4/25 0:05:03
  8. 编写函数:笛卡尔坐标系(Append Code)

    Description在数学里,笛卡儿坐标系(Cartesian坐标系),也称直角坐标系,是一种正交坐标系。二维的直角坐标系是由两条相互垂直、0 点重合的数轴构成的。在平面内,任何一点的坐标 是根据数轴上对应的点的坐标设定的。二维的直角坐标系通常由两个互相垂直的坐标轴设定,通常分…...

    2024/4/25 0:05:05
  9. 1375. 灯泡开关 III

    int numTimesAllBlue(vector<int> &light) {vector<int> v(50010, 0);//初始化灯都没有亮int ans = 0, temp = 0, cur = 0;for (auto it:light) {v[it] = 1;temp = max(temp, it);while (v[cur + 1] == 1)cur++;if (cur == temp)ans++;}return ans; }...

    2024/4/25 0:05:01
  10. easyUI数据表格

    前言 之前我做了个选项卡组件,这会儿我想往里面增加点东西,就决定是你了数据表格! 实现 先看看效果图:步骤: 导入依赖:<!-- 写全局样式 --><link rel="stylesheet" type="text/css" href="${pageContext.request.contextPath }/static…...

    2024/4/25 0:05:00
  11. springBoot总结

    **一、**Spring Boot 入门 1、Spring Boot 简介简化Spring应用开发的一个框架; 整个Spring技术栈的一个大整合; J2EE开发的一站式解决方案;2、微服务 2014,martin fowler 微服务:架构风格(服务微化) 一个应用应该是一组小型服务;可以通过HTTP的方式进行互通; 单体应用…...

    2024/4/25 0:05:02
  12. 如果人力紧缺,能否降低要求从而招更多人?

    不能。应该找到更加高效的做事方法,而不是招更多人; 毕竟人数是效率的反面; 俗话说 “人多好办事”、“人多力量大”,但在公司里面并不一定如此。公司里面永远都有做不完的事情,关键在于看清楚应该做什么; 当人数精简,更容易看清核心矛盾,然后在最重要的事情上发力并创…...

    2024/4/25 0:05:00
  13. Uni-app接入腾讯人脸核身

    ​ 人脸核身功能有多种接入方式,其中包含微信H5、微信小程序、APP、独立H5、PC端、API接入6种方式。 ​ 我们的产品是使用uni-app来开发,所以第一时间考虑使用H5方式接入,但是通过与官方技术人员对接后得知,uni-app是有原生插件可以用的,所以可以使用app的方式接入,原生的…...

    2024/4/25 0:04:57
  14. 图像质量评分-综述(BRISQUE、NIMA、RankIQA)

    背景 (一搜一大把,不详细介绍) 图像在获取、压缩、处理、传输、显示等过程中难免会出现一定程度的失真,怎样衡量图像的质量、评定图像是否满足某种特定应用要求,这就需要建立有效的图像质量评价体制。 图像质量评价方法可分为主观评价方法和客观评价方法,主观方法就是凭借…...

    2024/4/28 8:13:42
  15. 用Python比较两个csv文件的ID,将查找到的ID信息提取出来

    需要将ID.csv的蛋白质从name_or.csv中找到,并补充name和organism信息,最后写入了seq_sim_all.csv中 ID.csvname_or.csvseq_sim.all.csv代码如下: import csv f = open(seq_sim_all.csv, w, encoding = utf-8, newline=) csv_writer = csv.writer(f) csv_writer.writerow([Da…...

    2024/4/25 0:04:55
  16. 数组的操作 之一(Append Code)

    Description给出两个不超过N个元素的数组,将它们元素相加之和放入第三个数组中。-----------------------------------------------------------------------------结合“Append Code”中的代码,编写以下函数:原型:int add_array(int arr[], int a[], int m, int b[], int …...

    2024/4/25 0:04:55
  17. 我的Java学习之路(12)-- IO模拟手机号携号转网功能

    IO模拟手机号携号转网功能一、功能说明二、思路三、代码实现1. 首先是用户实体类2. 移动公司类3. 联通公司类4. 最后是程序入口类四、演示效果图 一、功能说明根据国家政策,目前中国移动和中国联通开启了携号转网的活动:移动–>联通 用户需要根据自己输入信息,到移动公司…...

    2024/4/25 0:04:53
  18. 11.Intent细致学习

    概述使用ComponentName属性传递数据b1.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View view) {Intent intent = new Intent();//创建Component对象用来实现页面跳转//其中第一个参数是该包的名字,第二个参数是即将跳转的那个类名Componen…...

    2024/4/28 0:55:31
  19. Python3入门机器学习之3.8实现多元线性回归

    Python3入门机器学习 3.8 实现多元线性回归 1.实现对多元线性回归LinearRegression的封装: class LinearRegression:def __init__(self):"""初始化Linear Regression模型"""self.coef_ = None #系数self.interception_ = None #截距self._th…...

    2024/4/14 20:49:29
  20. linux下调试域格CLM920 NC5 pppd拨号

    Linux下调试域格CLM920 NC5 pppd拨号识别模块 内核添加相关配置 核对驱动加载情况 核对模块注册情况 调用拨号脚本拨号识别模块 域格CLM920 NC5模块VID、PID分别为05c6、9025。确认使用lsusb可以找到模块。内核添加相关配置 域格CLM920 NC5 interface分布如下 interface 0 → D…...

    2024/4/16 17:13:18

最新文章

  1. BTCOIN发布WEB3.0论坛:生态与金融的双重叙事热点驱动自由创新意识

    在数字时代&#xff0c;信息的自由流动和透明度是推动经济发展和社会进步的关键。尤其在加密货币和区块链领域&#xff0c;这一点尤为重要。BTCOIN的最新创举——一个基于WEB3.0理念的信息论坛&#xff0c;不仅标志着信息传递自由化的新篇章&#xff0c;也为数字货币市场的信息…...

    2024/4/28 12:23:10
  2. 梯度消失和梯度爆炸的一些处理方法

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

    2024/3/20 10:50:27
  3. 【stm32】I2C通信协议

    【stm32】I2C通信协议 概念及原理 如果我们想要读写寄存器来控制硬件电路&#xff0c;就至少需要定义两个字节数据 一个字节是我们要读写哪个寄存器&#xff0c;也就是指定寄存器的地址 另一个字节就是这个地址下存储寄存器的内容 写入内容就是控制电路&#xff0c;读出内容就…...

    2024/4/22 20:59:35
  4. node.js常用指令

    1、node&#xff1a;启动 Node.js REPL&#xff08;交互式解释器&#xff09;。 node 2、node [文件名]&#xff1a;执行指定的 JavaScript 文件。 node app.js 3、npm init&#xff1a;初始化一个新的 Node.js 项目&#xff0c;生成 package.json 文件。 此命令会创建一个…...

    2024/4/27 1:07:02
  5. 【外汇早评】美通胀数据走低,美元调整

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

    2024/4/26 18:09:39
  6. 【原油贵金属周评】原油多头拥挤,价格调整

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

    2024/4/28 3:28:32
  7. 【外汇周评】靓丽非农不及疲软通胀影响

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

    2024/4/26 23:05:52
  8. 【原油贵金属早评】库存继续增加,油价收跌

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

    2024/4/27 4:00:35
  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/27 9:01:45
  13. 【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试

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

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

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

    2024/4/25 18:39:16
  15. 【外汇早评】美伊僵持,风险情绪继续升温

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

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

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

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

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

    2024/4/28 1:22:35
  18. 氧生福地 玩美北湖(中)——永春梯田里的美与鲜

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

    2024/4/25 18:39:14
  19. 氧生福地 玩美北湖(下)——奔跑吧骚年!

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

    2024/4/26 23:04:58
  20. 扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!

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

    2024/4/27 23:24:42
  21. 「发现」铁皮石斛仙草之神奇功效用于医用面膜

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

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

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

    2024/4/26 19:46:12
  23. 广州械字号面膜生产厂家OEM/ODM4项须知!

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

    2024/4/27 11:43:08
  24. 械字号医用眼膜缓解用眼过度到底有无作用?

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

    2024/4/27 8:32:30
  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