看到Observable和RxJS就感觉很亲切,因为之前做Android开发的时候接触过RxJava。Observable和RxJS的相关知识最好的文档还是官方文档 https://www.angular.cn/guide/observables 强烈推荐大家看官方文档。

一、可观察对象(Observable)

       可观察对象(Observable)在Angular 中使用非常广泛。可观察对象支持在应用中的发布者和订阅者之间传递消息。 在需要进行事件处理、异步编程和处理多个值的时候,可观察对象相对其它技术有着显著的优点。

       可观察对象的使用本质可以认为是一个观察者模式。简单的流程就是一个观察者(Observer)通过subscribe()方法订阅一个可观察对象(Observable)。订阅之后观察者(Obsever)对可观察者(Observable)发射的数据或数据序列就能作出响应(next函数发射数据)。涉及到三个东西:观察者(Observer)、可观察者(Observable)、订阅(subscribe)。

我们先给出一个简单的实例,然后再分开来讲观察者(Observer)、可观察者(Observable)、订阅(subscribe)。

import {Component} from '@angular/core';
import {of} from 'rxjs';// 创建一个可观察者对象-Observable,发射三个数据123
const myObservable = of(1, 2, 3);// 创建一个观察者对象-Observer(处理next、error、complete回调)
const myObserver = {next: x => console.log('Observer got a next value: ' + x),error: err => console.error('Observer got an error: ' + err),complete: () => console.log('Observer got a complete notification'),
};// 通过Observable的subscribe函数,观察者去订阅可观察者的消息
myObservable.subscribe(myObserver);@Component({selector: 'app-root',templateUrl: './app.component.html',styleUrls: ['./app.component.css']
})
export class AppComponent {
}

1.1、Observer(观察者)

       Observer(观察者)用于接收Observable(可观察者)对象通知的处理器(说白了就是就是接收Observable发送过来的消息)。Observer(观察者)需要实现Observer接口。
观察者对象定义了一些回调函数来处理可观察对象可能会发来的三种通知(Observer接口里面的方法)。

通知类型(方法)说明
next必要。用来处理每个发送过来的值。在开始执行后可能执行零次或多次
error可选。用来处理错误通知。错误会中断这个可观察对象实例的执行过程
complete可选。用来处理执行完毕(complete)的通知。当执行完毕后,这些值就会继续传给下一个处理器

       当然了观察者对象可以定义这三种处理器(next、error、complete)的任意组合。如果你不为某种通知类型提供处理器,这个观察者就会忽略相应类型的通知。

       举个例子比如我们只想处理next()方法对应的通知那么观察值就可以这么写了:

// 创建一个观察者对象-Observer(只处理next回调)
const myObserver = {next: x => console.log('Observer got a next value: ' + x),
};

1.2、Observable(可观察者)

       使用Observable构造函数可以创建任何类型的可观察流。 当执行可观察对象的subscribe()方法时,这个构造函数就会把它接收到的参数作为订阅函数来运行。 订阅函数需要接收一个Observer对象,并把值发布给观察者对象的next()方法。其实很好理解,比如有如下的代码,sequenceSubscriber方法是Observable构造函数的参数。当调用subscribe()方法订阅的时候就会执行sequenceSubscriber方法里面的动作发射数据。

import {Component} from '@angular/core';
import {Observable, of} from 'rxjs';// 可观察者构造函数的参数
function sequenceSubscriber(observer) {// 发射三个值observer.next(1);observer.next(2);observer.next(3);observer.complete();return {unsubscribe() {}};
}// 通过构造函数来创建一个可观察者
const sequence = new Observable(sequenceSubscriber);// 订阅
sequence.subscribe({next(num) {console.log(num);},complete() {console.log('Finished sequence');}
});@Component({selector: 'app-root',templateUrl: './app.component.html',styleUrls: ['./app.component.css']
})
export class AppComponent {
}

1.3、 Subscribing(订阅)

       光有观察者和可观察者是不够的,还需要通过订阅把他两串联起来才能运作起来。只有当有人订阅Observable的实例时,它才会开始发布值。 订阅就是去调用Observable对象的subscribe()方法,并把一个Observer对象传给它,用来接收通知。subscribe()方法的调用会返回一个Subscription对象,该对象具有一个unsubscribe()方法。当调用该方法时,你就会停止接收通知。

1.4、多播

       默认情况下可观察对象会为每一个观察者创建一次新的、独立的执行。 订阅了多少次就会有多少个独立的流(next监听器会重复调用)。

       多播:多播用来让可观察对象在一次执行中同时广播给多个订阅者。借助支持多播的可观察对象,你不必注册多个监听器,而是复用第一个(next)监听器,并且把值发送给各个订阅者。我们通过一个简单的实例来看多播的代码应该怎么写,会把所有的观察者放在一个数组里面,然后复用第一个观察者的监听器。

多播代码

import {Component} from '@angular/core';
import {Observable} from 'rxjs';function multicastSequenceSubscriber() {// 需要发射的数据const seq = [1, 2, 3];// 观察者数组,多播那肯定会有多个观察者const observers = [];let timeoutId;// 在调用Observable对应subscriber()方法的时候,会传入进来observer观察者对象return (observer) => {// observers观察者对象加入数组observers.push(observer);// 第一次有观察者订阅过来的时候if (observers.length === 1) {timeoutId = doSequence({next(val) {// 遍历每个观察者,调用观察者的next()方法observers.forEach(obs => obs.next(val));},complete() {// 遍历每个观察者,调用观察者的complete()方法,调用slice(0)又冲第一个元素开始遍历。// 因为前面已经调用过observers.forEach了已经移动到最后一个元素去了observers.slice(0).forEach(obs => obs.complete());}}, seq, 0);}return {unsubscribe() {// 如果调用了取消订阅,则从数组里面删除observers.splice(observers.indexOf(observer), 1);// 如果是最后一个,则清除 timer outif (observers.length === 0) {clearTimeout(timeoutId);}}};};
}// 每秒发射一个数据
function doSequence(observer, arr, idx) {return setTimeout(() => {observer.next(arr[idx]);if (idx === arr.length - 1) {observer.complete();} else {// 继续执行doSequence(observer, arr, ++idx);}}, 1000);
}// 创建一个多播的被观察者
const multicastSequence = new Observable(multicastSequenceSubscriber());// 第一个观察者订阅
multicastSequence.subscribe({next(num) {console.log('1st subscribe: ' + num);},complete() {console.log('1st sequence finished.');}
});// 1.5s之后,第二个观察者订阅
setTimeout(() => {multicastSequence.subscribe({next(num) {console.log('2nd subscribe: ' + num);},complete() {console.log('2nd sequence finished.');}});
}, 1500);@Component({selector: 'app-root',templateUrl: './app.component.html',styleUrls: ['./app.component.css']
})
export class AppComponent {
}

二、RxJS

2.1、RxJS简单介绍

       RxJS(响应式扩展的JavaScript 版)是一个使用可观察对象进行响应式编程的库。它让组合异步代码和基于回调的代码变得更简单。RxJS文档链接 https://rxjs-dev.firebaseapp.com/ 。

RxJS是一个库,一个工具,让我们写异步的代码非常的简单。

       RxJS的学习关键在操作符的学习,RxJS提供了各种各样的操作符。操作符用的对很多事情能事半功倍。操作符的类型有:创建操作符、组合操作符、过滤操作符、转换操作符、多播操作符等等。

RxJS常用操作符

类别操作
创建from、fromPromise、fromEvent、of等
组合combineLatest、concat、merge、startWith、withLatestFrom、zip等
过滤debounceTime , distinctUntilChanged , filter , take , takeUntil等
转换bufferTime , concatMap , map , mergeMap , scan , switchMap等
工具tap等
多播share等

如果想深入的学习RxJS可以多去了解里面的操作符。我只能说操作符非常的强大。

2.2、管道pipe

       有的时候我们可能想把多个操作符连接起来就需要借助管道pipe()函数来实现。pipe() 函数以你要组合的这些函数作为参数,并且返回一个新的函数,当执行这个新函数时,就会顺序执行那些被组合进去的函数。我们用一个简单的实例来来看看pipe管道怎么使用,通过管道把filter操作符和map操作符链接起来。

要是在RxJava里面要把多个操作符链接起来,非常的简单直接…链式编程就可以实现。但是RxJS里面不支持这种操作,只能通过管道把多个操作符链接起来。

import {Component} from '@angular/core';
import {of} from 'rxjs';
import {filter, map} from 'rxjs/operators';// 通过RxJS的of创建操作符创建一个Observable对象,并且通过管道把filter操作符和map操作符链接起来
const squareOdd = of(1, 2, 3, 4, 5).pipe(// 只需要奇数filter(n => n % 2 !== 0),// 值平方map(n => n * n));// 订阅
squareOdd.subscribe(x => console.log(x));@Component({selector: 'app-root',templateUrl: './app.component.html',styleUrls: ['./app.component.css']
})
export class AppComponent {
}

2.3、RxJS错误处理

       RxJS除了可以在订阅时提供error()处理器外,RxJS 还提供了catchError操作符来处理一些不是致命的错误。什么意思,我们知道一旦走到error()方法去了之后整个数据流就直接断了,比如我们顺序发送100个数据,第一个数据发送的时候就发生了错误后面的99个数据都没办法再发送了。RxJS里面的catchError操作符可以避免这种情况,他让你有一个修复的机会,我们可以在catchError里面做一些特殊的处理,当第一个数据发送的时候的错误,我们可以通过某种方式让数据可以继续发送。 比如如下的实例,第一个数据发射的时候产生了错误,我们接着从2开始发送数据。

RxJS里面的catchError 操作符让我们对一些错误可以做一些修复。

import {Component} from '@angular/core';
import {range} from 'rxjs';
import {catchError, map} from 'rxjs/operators';const apiData = range(1, 100).pipe(map(value => {if (value === 1) {// 第一个数据就发生错误了throw new Error('Value expected!');}return value;}),// 当有错误返回的时候,我们又从2开始发送catchError(err => range(2, 99))
);apiData.subscribe({next(x) {console.log('data: ', x);},error(err) {console.log('errors already caught... will not run');}
});@Component({selector: 'app-root',templateUrl: './app.component.html',styleUrls: ['./app.component.css']
})
export class AppComponent {
}

三、Angular里面的可观察对象

       Angular通常使用可观察对象作为处理各种常用异步操作的接口。

3.1、事件发送器 EventEmitter

       EventEmitter类我们在前一篇文章(组件交互)有提过,当子组件想向父组件发送消息的时候我们就用到了EventEmitter。EventEmitter用来从组件的 @Output() 属性中发布一些值。EventEmitter扩展了Observable,并添加了一个 emit()方法,这样它就可以发送任意值了。当你调用emit() 时,就会把所发送的值传给订阅上来的观察者的next()方法。

子组件代码

import {Component, EventEmitter, Output} from '@angular/core';@Component({selector: 'app-data-child',template: `<button (click)="vote(true)">点击</button>`
})
export class DataChildComponent {// @Output定义一个准备回调父组件的事件EventEmitter也是可以传递参数的@Output() voted = new EventEmitter<boolean>();vote(agreed: boolean) {// 把事件往上抛出去,可以带参数this.voted.emit(agreed);}
}

父组件代码

import {Component} from '@angular/core';@Component({selector: 'app-data-parent',styleUrls: ['./data-parent.component.css'],template: `<p>点击 {{clickCount}} 次</p><app-data-child (voted)="onVoted($event)"></app-data-child>`
})
export class DataParentComponent {clickCount = 0;/*** 子组件抛上来的事件*/onVoted(agreed: boolean) {this.clickCount++;}
}

       上面代码中我们在子组件里面通过@Output() voted = new EventEmitter();定义了一个EventEmitter类型的输出变量voted。并且父组件里面绑定到了这个输出变量(其实就是订阅的关系)。我们可以理解下他们是怎么工作的。当子组件里面的按钮被点击之后,调用了EventEmitter的emit()函数。这个时候EventEmitter会去检测有那些观察值订阅了这个EventEmitter。然后调用这些订阅者的next()函数从而调用父组件模板里面写的函数。

3.2、HTTP

       Angular的HttpClient从HTTP 方法调用中返回了可观察对象。例如,http.get(‘url’)、http.post(‘url’)返回的对象就是可观察对象。我们还是用一个非常简单的实例来说明。组件里面有一个按钮,点击这个按钮的时候通过htt.get(url)获取url上对应的数据。

service对应代码

import {Injectable} from '@angular/core';
import {HttpClient} from '@angular/common/http';@Injectable()
export class NetworkProtocolsService {constructor(private http: HttpClient) {}/*** 获取配置信息-返回Observable*/getConfig() {return this.http.get('assets/config.json');}
}

组件对应代码

import {Component} from '@angular/core';
import {NetworkProtocolsService} from '../network-protocols.service';@Component({selector: 'app-data-parent',styleUrls: ['./data-parent.component.css'],template: `<button (click)="onButtonClick()">点击获取配置信息</button><p>配置信息:{{message}}</p>`,providers: [NetworkProtocolsService]
})
export class DataParentComponent {message = '';constructor(private protocolsService: NetworkProtocolsService) {}// 点击按钮获取配置信息,简单的把配置信息显示出来onButtonClick() {this.protocolsService.getConfig().subscribe(data => this.message = data.toString(),err => console.error('network get error: ' + err));}
}

3.3、AsyncPipe(异步管道)

       AsyncPipe(异步管道)订阅一个 Observable或Promise对象(这里我们只讲Observable),并返回它发出的最新值。 当通过next()方法发出新值时,订阅的异步管道就知道数据发送变化了,然后标识组件需执行变化检测。 当组件被销毁时,异步管道自动取消订阅,以避免潜在的内存泄漏。

       如下实例,time是一个Observable,并且并且每一秒都发射一个新的值。

import {Component} from '@angular/core';
import {Observable} from 'rxjs';@Component({selector: 'app-data-parent',styleUrls: ['./data-parent.component.css'],template: `<div><code>observable|async</code>:Time: {{ time | async }}</div>`
})
export class DataParentComponent {time = new Observable(observer => {setInterval(() => observer.next(new Date().toString()), 1000);});
}

3.4、路由器(router)

       Router.events路由器的事件都是以可观察对象的形式提供的。而且路由器的事件有以下七种。如下所示:

路由器事件说明
NavigationStart会在导航开始时触发
RoutesRecognized会在路由器解析完 URL,并识别出了相应的路由时触发
RouteConfigLoadStart会在 Router 对一个路由配置进行惰性加载之前触发
RouteConfigLoadEnd会在路由被惰性加载之后触发
NavigationEnd会在导航成功结束之后触发
NavigationCancel会在导航被取消之后触发。 这可能是因为在导航期间某个路由守卫返回了 false
NavigationError会在导航由于意料之外的错误而失败时触发

       因为路由器事件是以Observable的形式提供的,我们也可以使用RxJS里面的filter()操作符来找到感兴趣的事件,并且订阅它们。如下代码我们只关心NavigationStart事件。

import {Component, OnInit} from '@angular/core';
import {Observable} from 'rxjs';
import {NavigationStart, Router} from '@angular/router';
import {filter} from 'rxjs/operators';@Component({selector: 'app-data-parent',styleUrls: ['./data-parent.component.css'],template: ``
})
export class DataParentComponent implements OnInit {navStart: Observable<NavigationStart>;constructor(private router: Router) {// 我们只是关心NavigationStart事件this.navStart = router.events.pipe(filter(evt => evt instanceof NavigationStart)) as Observable<NavigationStart>;}ngOnInit(): void {this.navStart.subscribe(evt => console.log('Navigation Started!'));}
}

3.5、响应式表单 (reactive forms)

       响应式表单具有一些属性,它们使用可观察对象来监听表单控件的值。FormControl的valueChanges属性和statusChanges属性包含了会发出变更事件的可观察对象。订阅可观察的表单控件属性是在组件类中触发应用逻辑的途径之一。

       用一个简单的实例来说明,当input里面的值变化的时候,我们能获取input的值的变化。

import {Component, OnInit} from '@angular/core';
import {FormControl, FormGroup} from '@angular/forms';@Component({selector: 'app-data-parent',styleUrls: ['./data-parent.component.css'],template: `<h2>Hero Detail</h2><h3><i>FormControl in a FormGroup</i></h3><form [formGroup]="heroForm" novalidate><div class="form-group"><label class="center-block">Name:<input class="form-control" formControlName="name"></label></div></form>`
})
export class DataParentComponent implements OnInit {heroForm = new FormGroup({name: new FormControl()});ngOnInit() {const nameControl = this.heroForm.get('name');// 当表单里面数据变化的时候,可以收到通知。nameControl.valueChanges就是一个ObservablenameControl.valueChanges.forEach((value: string) => console.log(value));}}

       以上就是对Angular2以上Observable和RxJS的简答介绍。最后还是想告诉大家最好的文档还是官方文档 https://www.angular.cn/guide/observables

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

相关文章

  1. angular2用户输入的一些事件

    按钮事件&#xff1a; html: <button (click)"oncllick()">点我啊{{click1}}</button> component: click1:string; oncllick(){console.log("进来了")this.click1"123"; }键盘事件&#xff1a; html:<input (keyup)"o…...

    2024/4/21 2:31:46
  2. angular2 配置HTTP协议- 配置路由

    背景介绍&#xff1a;今天把登录页面的HTTP请求和路由配置了一下&#xff0c;然后通过请求到的数据进行路由跳转&#xff1b;首先配置反向代理&#xff0c;之前用原生的时候是通过nginx来进行反向代理解决跨域的问题&#xff0c;但是使用ng后&#xff0c;需要在浏览器输入locah…...

    2024/4/21 2:31:45
  3. angular中的this指向问题

    this是指向当前$scope的。 例如在ng-click的使用中&#xff0c;this是指向当前的$scope而并不是dom元素的。 我们可以使用this的一些方法和属性 我们打印一下this就会发现&#xff0c;this中包含了我们$scope中的所有元素&#xff0c;还有自己的原型方法&#xff0c;这不同于jq…...

    2024/4/21 2:31:44
  4. angular2 数组去重方法

    const newArr Array.from(new Set(this.userDataSource)); this.userDataSource newArr;...

    2024/4/21 2:31:43
  5. Angular2 Http

    原文链接&#xff1a;http://www.cnblogs.com/SLchuck/p/5930740.html 1. 使用Http 绝大部分应用程序都会和后台服务打交道&#xff0c;Http是浏览器和服务器之间通讯的主要协议&#xff0c;通过Http调用来访问远程服务器上相应的 Web API。 HttpModule 并不是 Angular 的核心模…...

    2024/4/21 2:31:42
  6. Angular2 开发规范

    目录 把所有应用程序的源代码都放到名叫 app 的目录里。所有内容都遵循每个文件单个特性的原则。每个组件、服务和管道都在自己的文件里。所有第三方程序包都被保存到其它目录里而不在 app 目录里&#xff0c;我们不会修改它们&#xff0c;所以不希望它们弄乱我们的应用程序。使…...

    2024/4/20 20:23:05
  7. angular2系统学习 - 路由与导航(2)

    angular2系统学习 - 路由与导航(2) 1.模块注册路由 NgModule注册路由分根模块(AppModule)与子模块注册路由,只有根模块AppModule才能使用forRoot()方法。 - 主模块 RouterModule.forRoot()方法 - 子模块 RouterModule.forChild()方法2.命令导航路由替代点击Link导航 需要执行…...

    2024/5/8 12:25:32
  8. angular基础

    1、引入angular.js <script src"http://cdn.static.runoob.com/libs/angular.js/1.4.6/angular.min.js"></script> 2、表达式 使用双引号表达的并且能进行简单的逻辑运算的JavaScript表达式 <div ng-app ng-initname"mapbar_front">…...

    2024/4/27 1:51:53
  9. angular6 中angular.json中参数详解

    其实我觉得配置项这个东西应该是很简单的,毕竟是配置项,参数拿过来抄一下就行了.又不是写什么样式写什么逻辑的 但是吧,居然还真的在网上找不到什么能看的东西,尤其是我现在升级到angular6, 就真的找不到什么能看的东西了,于是乎,这个看着感觉随便抄抄的内容让我不得不自己研究…...

    2024/4/20 20:23:01
  10. Angular动态表单使用

    使用动态表单目的就是不用去手动编写太多的HTML代码&#xff0c;设置好之后就由数据的多少以及类型来动态生成表单&#xff0c;提高效率。在Angular的官网中介绍动态表单时&#xff0c;夹杂了一些业务方面的东西&#xff0c;增加了不熟悉的人学习的难度&#xff0c;这里直接就是…...

    2024/4/21 2:31:41
  11. angular2 在input上使用管道(过滤器)

    1.例牌&#xff0c;上需求 需求&#xff1a;用angular2进行开发Web App,登录时&#xff0c;用户填写的小写字母直接转换成大写字母显示&#xff1a; abc>ABC; 各位客官看到可能想打我&#xff0c;ng2不是有个uppercase管道吗&#xff1f;直接用就好了&#xff0c;还跑来这…...

    2024/4/20 17:14:29
  12. 190323Angular的核心概念有哪些?

    Angular的核心概念有哪些? 其实说实话&#xff0c;对于使用了Angular这么久的我来说&#xff0c;14年2月开始到现在吧。差不多将近5年了。通常来讲&#xff0c;用一个技术5年&#xff0c;不说成为一个特别牛逼的大神吧&#xff0c;最起码问下原理应该二话不说&#xff0c;噼里…...

    2024/4/24 15:55:45
  13. 【Angular4】如何使用observer-subscribe

    一、订阅 Angular4里面有一个非常重要的方法&#xff0c;叫订阅(subscribe&#xff09;&#xff1b;首先看一个例子&#xff1a; getStudyTime(userId){this.trainService.findStudyTime(userId).subscribe(result>{this.trainListresult;})}这里&#xff0c;我们定义了一个…...

    2024/4/30 14:22:07
  14. angular项目打包_Angular真有React开发人员讲得那么差劲?

    全文共2892字&#xff0c;预计学习时长8分钟图源&#xff1a;technoloader说真的&#xff0c;Angular真的不似React开发人员说得那么差劲&#xff0c;只是我们常常服从于脑海中已有的偏见。对于门外汉来说&#xff0c;Angular看起来既庞大又复杂。但很多人没有意识到的是&#…...

    2024/4/28 10:24:02
  15. 【Angular】深入总结angular核心,都是干货

    为什么写这篇文章&#xff1a; 使用angular开发也有快2年的时间&#xff0c;突然有一天有人问我&#xff0c;你能不能给我简单讲一下angular框架&#xff1f;虽然每天都在使用&#xff0c;却不知如何表述&#xff0c;故决定写这样一篇文章。 一句话知识点&#xff1a; Angul…...

    2024/4/23 20:09:34
  16. angular5 环境变量配置

    好久没有来了&#xff0c;今天风和日丽&#xff0c;就来分享个小知识&#xff0c;不扯淡&#xff0c;直接进入主题&#xff1a; 需求&#xff1a;使用angular实现前后分离开发&#xff0c;必然遇到环境问题&#xff0c;比如&#xff1a; 在本地开发你需要请求的地址是&#x…...

    2024/5/6 13:58:39
  17. 我为什么没有弃用 AngularJS,还在观望 Angular呢?

    背景 WEB前端的技术&#xff0c;用一个词来形容&#xff0c;可谓——“乱象丛生”&#xff01;哪怕是在前端行业深耕了十几年的老司机&#xff0c;也是一脸的懵逼&#xff0c; 到底学什么是好&#xff1f; 暂不说 Angular、 React 、Vue&#xff0c;这三个学哪个是好&#xff0…...

    2024/4/23 3:47:02
  18. angular 自定义更新_用angular创建一个自定义库

    angular 自定义更新Hey guys, I’m here today to talk about custom libraries. I hope that by the end of this article you will know how to create your own custom library. &#x1f60a;大家好&#xff0c;我今天在这里谈论自定义库。 我希望到本文结尾&#xff0c;您…...

    2024/4/21 2:31:33
  19. [Angular学习笔记]Angular事件处理

    事件 当用户点击链接&#xff0c;按下按钮&#xff0c;输入文字时&#xff0c;这些动作都会触发DOM事件&#xff0c;本篇博客解释如何使用Angular 事件绑定语法把这些事件绑定到事件处理器。 事件绑定 Angular提供了事件绑定机制&#xff0c;可以响应任何DOM事件&#xff0c…...

    2024/4/21 2:31:32
  20. angular拦截请求和响应

    angular拦截请求和响应 拦截器的概念想必大家都不陌生&#xff0c;不过这里还是要提一句&#xff08;凑一点字数&#xff09;&#xff1a; 拦截器就是在我们的请求 发送之前 或 请求返回之后被我们处理之前&#xff0c;先截住。当然截住之后我们可以对其做一些操作&#xff0…...

    2024/4/21 2:31:31

最新文章

  1. 【YOLOv8改进[Backbone]】使用SCINet改进YOLOv8在黑暗环境的目标检测效果

    目录 一 SCINet 1 本文方法 ① 权重共享的照明学习 ② 自校准模块 ③ 无监督训练损失 二 使用SCINet助力YOLOv8在黑暗环境的目标检测效果 1 整体修改 2 配置文件 3 训练 其他 一 SCINet 官方论文地址&#xff1a;https://arxiv.org/pdf/2204.10137 官方代码地址&…...

    2024/5/8 14:08:31
  2. 梯度消失和梯度爆炸的一些处理方法

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

    2024/5/7 10:36:02
  3. 在 Visual Studio Code (VSCode) 中隐藏以 . 开头的文件

    打开VSCode。 按下Ctrl ,快捷键打开设置。您也可以点击屏幕左下角的齿轮图标&#xff0c;然后选择“Settings”。 在设置搜索框中&#xff0c;键入files.exclude。 在找到的Files: Exclude项中&#xff0c;点击Add Pattern按钮来添加一个新的模式&#xff0c;或者直接在搜索…...

    2024/5/5 2:03:53
  4. 算法——匹配算法

    匹配算法有很多种&#xff0c;常见的包括暴力匹配算法、KMP算法、Boyer-Moore算法、Rabin-Karp算法、正则表达式匹配算法等。每种算法都有其适用的场景和特点&#xff0c;可以根据具体需求选择合适的算法来进行匹配操作。 1.匈牙利匹配 匈牙利匹配&#xff0c;也称为二分图最…...

    2024/5/7 3:52:06
  5. 【外汇早评】美通胀数据走低,美元调整

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

    2024/5/8 6:01:22
  6. 【原油贵金属周评】原油多头拥挤,价格调整

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

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

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

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

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

    2024/5/7 14:25:14
  9. 【外汇早评】日本央行会议纪要不改日元强势

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

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

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

    2024/5/4 23:55:05
  11. 【外汇早评】美欲与伊朗重谈协议

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

    2024/5/4 23:54:56
  12. 【原油贵金属早评】波动率飙升,市场情绪动荡

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

    2024/5/7 11:36:39
  13. 【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试

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

    2024/5/4 23:54:56
  14. 【原油贵金属早评】市场情绪继续恶化,黄金上破

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

    2024/5/6 1:40:42
  15. 【外汇早评】美伊僵持,风险情绪继续升温

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

    2024/5/4 23:54:56
  16. 【原油贵金属早评】贸易冲突导致需求低迷,油价弱势

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

    2024/5/4 23:55:17
  17. 氧生福地 玩美北湖(上)——为时光守候两千年

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

    2024/5/7 9:26:26
  18. 氧生福地 玩美北湖(中)——永春梯田里的美与鲜

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

    2024/5/4 23:54:56
  19. 氧生福地 玩美北湖(下)——奔跑吧骚年!

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

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

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

    2024/5/5 8:13:33
  21. 「发现」铁皮石斛仙草之神奇功效用于医用面膜

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

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

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

    2024/5/4 23:54:58
  23. 广州械字号面膜生产厂家OEM/ODM4项须知!

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

    2024/5/6 21:42:42
  24. 械字号医用眼膜缓解用眼过度到底有无作用?

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

    2024/5/4 23:54:56
  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