前言

我在学习generator ,yield ,co,thunkify的时候,有许多费解的地方,经过了许多的实践,也慢慢学会用,慢慢的理解,前一阵子有个其他项目的同事过来我们项目组学习node,发现他问的问题和我学习node的时候,遇到的困难都一样,所以产生写篇blog记录下co,thunkify的运用和原理,和园子里的神仙们交流交流,不对之处,还请指正,谢谢。

我在node的编写中,认真敲着敲着代码,然后回过头来发现,代码变成像这样子了,

var fs = require('fs'); 
//TODO:读取3个文件,然后... fs.readFile(
'file1.txt','utf-8', function(err,data1){ fs.readFile('file1.txt','utf-8', function(err,data2){ fs.readFile('file1.txt','utf-8', function(err,data3){ ...})}) })

或者在前端的代码中也有,

$.get("/b.txt", function(r1){$.get("/b.txt", function(r2){$.get("/b.txt", function(r3){$("div").html(r1+r2+r3);});});
});

这样子的代码的维护和代码量成倍数上涨,江湖人称回调金字塔,或邪恶金字塔,或者你可能说fs模块和jq,都可以提供同步的方式去调用接口,fs.readFileSync, 设置 async:true,通过同步的执行代码,但是javascript作为一种异步编程的语言,若使用同步的等待进行执行代码,那麽也将失去javascript原有的魅力。所以智慧无穷的人们通过一些新的技术或者新的运用去发挥js的异步编程的特性。

  • 事件监听的方法,node原生有EventEmitter对象,通过on,emit的方式把业务行为进行解耦,而社区有eventproxy等一些成熟的包支持。
  • promise对象,在jq1.5版本中始露尖角,运用在ajax调用中,后得到developer的广泛认可,在es6中纳入规范,当今的大多浏览器内置了这个对象,nodez中有q,bluebird等包。
  • 协程,微线程,es6中的generator,其实协程并不是在es6中的新概念,在Lua中已经普遍的使用,其实说白了也是一种函数调用的方式,只不过会保留执行前后的上下文,node有co,thunkify等支持流程控制。
  • 其他像async包,为流程控制而衍生的串行,并行,瀑布流,等概念,在早期的时候也被许多人运用(我们公司项目的前几个大版本的代码就是Async,coffeeScript写的,看得晕坨坨)

等等。

这些方法都可以去避免 回调金字塔的问题,在开发的成本上参差不齐。

而我再对generator函数做流程控制的时候,用的co,thunkify,用return callback(err,res);进行然后上一级调用的函数表示费解,而且不止co中有return callback(err,res); 在async 包也有,所以想弄清楚co中,究竟是怎么样去做流程控制的。

什么是thunk?

co,thunkify 的普通调用方式:

Demo1:

 1 co(function*(){
 2     //打印的顺序为 timeout!alen ,1,yield 会开启一个协程并开始等待返回
 3     yield thunkify(genFun)("timeout! alen");
 4     console.log("over!")
 5 }).catch(function(e){
 6     console.log(e.stack);
 7 })
 8 
 9 function genFun (param,callback){
10     co(function*(){
11         setTimeout(function () {
12             console.log(param);
13             return callback(null,1);
14         }, 4000);
15     }).catch(function(e){
16         console.log(e.stack);
17     })
18 }
19 // 运行结果:
20 //timeout! alen
21 // 1

 

 

 这里开始运行时,注意:

  • 所有的yield 的东西必须包含在co的匿名generator函数里面,在co后面返回的是一个prmise,需要catch Error,不然回调函数里面的错误无法捕捉,为什么无法捕捉呢?因为我们的函数不是我们自己去调用的,是由node的底层去调用的,比如读取一个文件 fs.readFile("a.txt",fun(err,res)),为什么底层知道读取完a.txt,需要把错误放到err,而结果放到res中?回到函数在外部我们捕捉不到,node底层的实现是用多线程去定时的轮询,判断内核中是否有已经完成的i/o调用,若是有,则执行回调函数,(node,异步IO模型实现原理,详情请看《深入浅出NodeJS》第三章异步I/O),所以执行回调函数的环境决定了我们回调函数的第一个参数必须是错误,然后传回给调用者。   

 

  • thunkify 的作用是把所有的函数封装成thunk函数,那麽什么是thunk函数呢?以下是维基百科的一段引用:

In computer programming, a thunk is a subroutine that is created, often automatically, to assist a call to another subroutine. Thunks are primarily used to represent an additional calculation that a subroutine needs to execute, or to call a routine that does not support the usual calling mechanism. They have a variety of other applications to compiler code generation and in modular programming.

     在计算机编程中,thunk 就是一个自动被创建去帮助调用另一个子进程的子进程。Thunk 主要是被用于表示一个子进程需要执行的额外计算,或者调用一个不支持普通调用机制的子进程。Thunk 在代码编译生成和模块化编程中有这广泛的运用。

     这段话说的有点晕,thunk最初产生是被用解决函数的 传值调用和传名调用,而用于js,其实就是把多个参数thunk化成只接受一个参数的函数.

  

thunkify 做了什么?

Demo2:

 1 //demo1:
 2 var thunkify = function(fn) {
 3 
 4     //thunkify 就是直接返回一个函数,在这个函数里面收集arguments这个类数组对象的参数,保存起来
 5     return function() {
 6         var args = new Array(arguments.length);
 7         var ctx = this;
 8 
 9         for (var i = 0; i < args.length; ++i) {
10             args[i] = arguments[i];
11         }
12 
13         /**
14          * 这里返回的函数是给co用的,把上一级收集的参数数组args的末尾加上一个function函数返回的回调函数,
15          * 这个也是为什么 return callback(null,res); 可以返回到上一级调用的函数,因为每个yield 后的结果都会转成promise
16          * ,在function thunkToPromise(fn)函数封装done
17          */
18         //TODO: 返回一个只有一个done的函数,其他的参数通过args变量用apply调用传入。
19         return function(done) {
20             var called;
21 
22             args.push(function() {
23                 if (called) return;
24                 called = true;
25                 done.apply(null, arguments);
26             });
27 
28             try {
29                 fn.apply(ctx, args);
30             } catch (err) {
31                 done(err);
32             }
33         }
34     };
35 }

 

 

  所有将多个函数封装成只接受一个参数函数(详情请看 Thunk的含义),所以使用thunkify 封装函数的时候,

    yield thunkify(genFun)("timeout! alen")

  返回的是一个function(done){}, 可以看到

  • thunkify(genFun) 这里返回一个函数,保存这里的上下文,这个返回的函数做的工作就是收集参数并封装在args中.
  • 等到再次调用的时候,thunkify(genFun)("timeout! alen"),这里也还是返回一个函数,会在args参数的最后加上一个function,这个函数结合在co这个done是co中传入做错误收集的.
  • 这里called 变量就是做的防止回调函数被调用两次。
  • 上面保存的this很!有!用!,在默认的情况下我们包的引入的是这样的 var thunkify  = require("thunkify"); 调用的时候也是 thunkify(genFun)("timeout! alen"),若是没有指定this,如果也没有启用严格模式 use strict,所以我们普通的调用环境是global,但是有时候我们必须改变thunkify的this指向的应用,特别实在我们用到原型链的时候,比如:

    demo3:

     1 var co = require("co")
     2 var thunkify = require("thunkify")
     3 
     4 // 一个构造
     5 function Person(age){
     6     this.age = age;
     7 }
     8 // 一个获取通过名字获取姓名的方法
     9 Person.prototype.getAgeName = function(name,callback){
    10     var _this = this;
    11     co(function*(){
    12         setTimeout(function(){
    13             return callback(null,name+":"+_this.age);
    14         },2000);
    15     }).catch(function(e){
    16         console.log(e.stack);
    17         throw new Error(e.stack);
    18     })
    19 }
    20 
    21 // 开始调用
    22 co(function*(){
    23     var p = new Person(13);
    24     // 分别是两种不同的调用方法
    25     // var res = yield thunkify(p.getAgeName)("xiaoming");   # 1
    26      var res = yield thunkify(p.getAgeName).call(p,"xiaoming");  # 2
    27     console.log(res)
    28 }).catch(function(e){
    29     console.log(e.stack)
    30 })
    31 
    32 // 结果:
    33 // #1:undefined  
    34 // #2:xiaoming:13

    正是需要用call去改变thunkify返回的函数里的上下文,所以才需要在里面保存this的调用环境。

     

  • 具体请看git-demo[有co,thunkify详细注解]

为什么return callback(err,res) 返回?

  return callback(err,res); 可以做到返回,而且最初接触thunkify,co的时候,发现,callback 这个变量根本就是我们直接声明的! 注意是声明,不是定义,因为我们仅仅是为了不让js解析器在语法检查的时候不抛出callback undefined 的错误,然后我们就自己在函数的参数,在实际的调用的是我们根本就没有传=.=,废话少说上图,

  

  是的,的确只是为了避免callback undefined 抛错而什么声明的,但是,它却是有赋值,在thunkfify中,下面:

  

  args.push(function{}) 这个push的元素就是我们的callback,在这里真正赋值。但是这个done参数,又是怎么工作的呢?

  co函数:

 1 /**
 2  * Execute the generator function or a generator
 3  * and return a promise.
 4  *
 5  * @param {Function} fn
 6  * @return {Promise}
 7  * @api public
 8  */
 9 
10 /**
11  * 执行 generator 函数 或者 一个 generator 同时返回一个promise
12  */
13 
14 function co(gen) {
15     var ctx = this;
16     var args = slice.call(arguments, 1);
17 
18     // we wrap everything in a promise to avoid promise chaining,
19     // which leads to memory leak errors.
20     // see https://github.com/tj/co/issues/180
21     return new Promise(function(resolve, reject) {
22         if (typeof gen === 'function') gen = gen.apply(ctx, args);
23         if (!gen || typeof gen.next !== 'function') return resolve(gen);
24 
25         onFulfilled();
26 
27         /**
28          * @param {Mixed} res
29          * @return {Promise}
30          * @api private
31          */
32         function onFulfilled(res) {
33             var ret;
34             try {
35                 ret = gen.next(res);
36             } catch (e) {
37                 return reject(e);
38             }
39             next(ret);
40         }
41 
42         /**
43          * @param {Error} err
44          * @return {Promise}
45          * @api private
46          */
47 
48         function onRejected(err) {
49             var ret;
50             try {
51                 ret = gen.throw(err);
52             } catch (e) {
53                 return reject(e);
54             }
55             next(ret);
56         }
57 
58         /**
59          * Get the next value in the generator,
60          * return a promise.
61          *
62          * @param {Object} ret
63          * @return {Promise}
64          * @api private
65          */
66         /* 把在generator 中next()的值传进去,然后返回一个promise*/
67         function next(ret) {
68             if (ret.done) return resolve(ret.value);
69             var value = toPromise.call(ctx, ret.value);
70             if (value && isPromise(value)) return value.then(onFulfilled, onRejected);
71             return onRejected(new TypeError('You may only yield a function, promise, generator, array, or object, '
72                 + 'but the following object was passed: "' + String(ret.value) + '"'));
73         }
74 
75     });
76 }

 

  co,做了什么事情?

  • co接受一个generator function ,然后收集arguments参数,然后直接 return new promise()!!!  也就是co和co之间是非阻塞的。所以
    1 co(function*(){
    2     // TODO:1 
    3 });
    4 co(function*(){
    5     // TODO:2
    6 })

    上述代码 1,2两处,不能保证一定是1先于比2完成。(估计也没人这么写=。=)

  • gen = gen.apply(ctx, args); 开始调用我们传入的co中的generator 函数,
  •  onFulfilled() ,函数中,gen.next(res),执行到下一个yield 然后等待子程序返回,这时他返回的是一个function 正是thunkfiy最底层的那个

  

  所以第一次调用onFulfilled(),ret = gen.next(res);返回ret.value 是一个function ,而这个function 正是接受一个done为参数的函数。

  然后去到next(ret),

  next函数:

1 /* 把在generator 中next()的值传进去,然后返回一个promise*/
2         function next(ret) {
3             if (ret.done) return resolve(ret.value); 
4             var value = toPromise.call(ctx, ret.value);
5             if (value && isPromise(value)) return value.then(onFulfilled, onRejected);
6             return onRejected(new TypeError('You may only yield a function, promise, generator, array, or object, '
7                 + 'but the following object was passed: "' + String(ret.value) + '"'));
8         }

 

  在这里,会依次判断是否已经完成,done==true, 否则,res.done =false,ret.value = function(done){},

  那麽将ret.value 转成一个promise,而this指向ctx,调用co的上下文,而在value也是一个Promise 之后,然后then(onFulfilled, onRejected),唯有这次value响应了,value的状态不在是pendding了,那麽才执行gen.next(res)的回调,所以

  •   每个yield 返回的promise 唯有onFulfilled了之后,才会再次开始gen.next(),因为gen.next()在上一个yield 返回的promise的onFulfilled回调之中。

  toPromise函数:

 1  /* 把一个被yield 过的值 转成promise */
 2 function toPromise(obj) {
 3     if (!obj) return obj;
 4     if (isPromise(obj)) return obj;
 5     if (isGeneratorFunction(obj) || isGenerator(obj)) return co.call(this, obj);
 6     if ('function' == typeof obj) return thunkToPromise.call(this, obj);
 7     if (Array.isArray(obj)) return arrayToPromise.call(this, obj);
 8     if (isObject(obj)) return objectToPromise.call(this, obj);
 9     return obj;
10 }

 

   在这里,obj是一个function,所以会 return thunkToPromise.call(this, obj); 转成promise,并且吧obj 传进去,这个obj正是我们有一个done为参数的函数,

  thunkToPromise函数:  

 1  /* 把thunk函数转成promise */
 2 function thunkToPromise(fn) {
 3     var ctx = this;
 4     return new Promise(function (resolve, reject) {
 5         fn.call(ctx, function (err, res) {
 6             if (err) return reject(err);
 7             if (arguments.length > 2) res = slice.call(arguments, 1);
 8             resolve(res);
 9         });
10     });
11 }

   到这里,终于看到了done被赋值什么了,是个function(resolve, reject),这里直接返回一个Promise,这个Promise 做了什么?fn被调用,上下文是co调用的环境,done参数是一个回调函数,第一个参数是err,那麽这个和我们上面只是声明却没有定义的有什么关系?

  我们申明的callback,在我们thunkify的是时候,就已经赋值了,

  A,B,C 三张图,总结一下

  • A是我们在调用thunkify话的函数具有多少个参数,而最后一个callback是在thunkify 里面在自动帮我们补上,也就是B上的args.push(function)。
  • C呢,做的事情就是,传递一个done函数给我们thunkify()返回的函数,然后执行他。在这里执行callback的时候done.apply(null,arguments),这个时候会把我们平时return callbakc(err,res),这两个err,res,传进入arguments,去执行done ,而这个done函数,会去判断这个函数是否超过2个参数,如果超过两个参数,那麽就把err参数除外的函数封装成一个数组返回。
  • 因为在generator 中 return 关键字会直接导致 return 以下的yield 失效,即是

  

  结果:

 

  

  所以,看到如果函数有return 那么,这个generator 函数会直接返回{done:true,value=XX}这也是为什么return callback(err,res); 就直接返回上一级函数了。yield thunkify() 唯有遇到return,generator中的所有yield都完成了, 或在本执行函数的过程中遇到reject,才会返回。

  

总结

  • co是通过传入一个generator函数,这个generator函数中,每个yield thunkify 返回的都是一个promise, 每次gen.next();的运行依赖上一个yield 返回的promise是否 onFulfilled ,若没有执行则throw Error()终止。
  • 每个yield thunkify 的返回,都是通过 return ,throw Error,或者所有的yield 都已经onFulfilled了,所以才返回;
  • thunkify中可以通过call,apply来改变this,进行保存原型链中的对象的调用上下文。

 

转载于:https://www.cnblogs.com/Alencong/p/5869378.html

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

相关文章

  1. nodemailer 使用时碰到的问题

    nodemailer包加入后出现如下问题:fangdeMacBook-Air:ah fxc$ node ./server.js/Users/fxc/work-on-node/ah/node_modules/nodemailer/lib/mailer/index.js:31 compile: [(...args) => this._convertDataImages(...args)], ^^^SyntaxError…...

    2024/4/15 3:54:46
  2. ReactNativeiOS(一)安装

    开始用到React Native for iOS,特此笔记。如能帮助到您,我会很开心。OS X - 当前仅支持 OS X推荐使用 Homebrew 的方式来安装 nvm,watchman和 flow。MacdeiMac:~ mac$ ruby -vruby 2.0.0p645 (2015-04-13 revision 50299) [universal.x86_64-darwin15]MacdeiMac:~ mac$ pwd/…...

    2024/4/24 13:32:17
  3. Nodejs中控制异步的几种方法【陆续更新……】

    Promise是异步代码实现控制流的一种方式。这一方式可以让你的代码干净、可读并且健壮。 Q 和 Bluebird 都是在实现 Promise A+ 标准的基础上提供了一些封装和帮助方法1.异步回调原生写法serverClient.get("http://localhost:3001/test/test.php?page=1&page_count=1&…...

    2024/4/24 13:32:16
  4. NodeJs回调操作Promise化

    mongoose是一个NodeJs下MongoDB的ORM库。使用这个库,您从DB到表(collection)都不用创建了。只需要在项目中定义好Model。下面就是用上一篇的代码来演示如何把mongoose的数据库操作里的回调地狱(callback hell)轻松化解掉。上一篇Petshop的代码在这里。打开Promise的开关mo…...

    2024/4/24 13:32:15
  5. 异步循环和双层嵌套循环(性能优化nodejs从2.8m到28s)

    两步优化: 定位问题:该接口使用多次sql查询,并采用了async,另外在数据的处理中使用了map,forEach嵌套。 方案: 1/使用了bluebird来提升异步并发能力,替代原来的async请求。 2/数据处理确实无法通过优化数据结构减少嵌套,这里采用了for循环来替代map,forEach,虽然降低了…...

    2024/4/24 13:32:14
  6. async/await - 8.在for循环中正确的使用await

    async/await - 8.在for循环中正确的使用awaitconst fetch = require(node-fetch) const bluebird = require(bluebird)async function getZhihuColumn(id) {await bluebird.delay(1000)const url = `https://zhuanlan.zhihu.com/api/columns/${id}`const response = await fet…...

    2024/4/24 13:32:13
  7. 我的NodeJS一年之旅总结

    这是《为什么我从Python转换到Node.js》这篇文章的后续。《为什么我从Python转换到Node.js》写于一年多前,主要是说因为我对Python感到失望于是打算尝试Node。一年的内部CLI工具,客户项目和更新公司产品的历练,正是我所学到的东西。不仅是Node,JavaScript也很不错。易于学习…...

    2024/4/24 13:32:14
  8. hexo 错误汇总

    文章目录发布文章遇到:发布文章的时候出现错误:代码推送到github,hexo g -d 半天推送不上去记录一次hexo+coding hexo s本都没问题,hexo g -d 样式并未改变的问题。hexo 问题记录:hexo server的时候报Template render error : (unknown path) [Line 7, Column 23hexo发布…...

    2024/4/24 13:32:15
  9. node_redis 中文文档及node_redis 注释笔记(中文版)

    node_redis 中文文档及node_redis 注释笔记(中文版)https://github.com/NodeRedis/node_redisredis - a node.js redis client这是node.js的一个完整且功能丰富的Redis客户端。它支持所有的Redis命令,并专注于高性能。Install with:npm install redisUsage Examplevar redis =…...

    2024/4/24 13:32:11
  10. node权限控制模块node_acl的应用

    前言一个应用必不可少的部分:登录认证(jaredhanson/passport)、权限控制(OptimalBits/node_acl) 由于node_acl中文资料较少,本文给出一个完整的简单示例,便于初学者理解和学习 最后有动态的效果图给出,更直观的展示node_acl的使用效果知识点示例中的路由并未采用如:app.pu…...

    2024/4/24 13:32:09
  11. nodejs 中模块使用的介绍

    模块的分类 核心模块: 如 http 文件模块: 如 var util = require(‘./util.js’) 第三方模块: 如 var promise=require(‘bluebird’)模块的使用流程 创建模块: teacher.js 导出模块: exports.add = function(){} 加载模块: var teacher = require(‘./teacher.js’…...

    2024/4/24 13:32:09
  12. Node生成图片

    问题描述最进公司在做的小程序,但是小程序分享只能是图片,不能自定义样式 但是我们还有个需求,就是分享出去的 必须要让人直观的看出求职者的 基本信息,功夫不负有心人,最后给解决了!直接上代码const fs = require("fs"); const images = require("images…...

    2024/4/24 13:32:07
  13. NodeJs之数据库异常处理

    数据库异常NodeJs版本:4.4.4数据库链接错误 使用nodejs处理异常最麻烦不过,这里我抛开nodejs提供的domain和一些第三方库专门处理的东西。操作数据库是我们常用的功能。通过回调,我们这里会有很多err出没。 如下: var pool = require(../db.js); var runtimeLog = require(.…...

    2024/4/24 13:32:09
  14. NPM安装问题

    今天安装NPM一直出错,报错日志如下0 info it worked if it ends with ok 1 verbose cli [ D:\\Program\\nodejs\\node.exe, 1 verbose cli D:\\Program\\nodejs\\node_modules\\npm\\bin\\npm-cli.js, 1 verbose cli install, 1 verbose cli -g, 1 verbose cli vue-cl…...

    2024/4/15 3:54:57
  15. Express.js 相关资料

    Express.js 中文入门指引手册 Express 4.x API 中文手册Windows 7 下 Node.js 连接 Oraclenodejs+express+ejs+mongoose实例10 个最佳的 Node.js 的 MVC 框架koa koa+ES6, http://koa.bootcss.com/ https://github.com/koajs/examples coHapibluebird nodeclubCNodeJS ionic…...

    2024/4/19 16:21:41
  16. nodejs代码封装基础

    以加法为例 --return类型 return.js文件: var obj = {}; obj.sum = function(a, b){var sum = a+b;return sum; } module.exports = obj; --callback类型 callback.js文件: var obj = {}; obj.sum = function(a, b ,callback){var sum = a+b;callback(null,sum) } module.expor…...

    2024/4/15 3:54:52
  17. Angular CLI的那些“坑”

    在进行angular-cli项目迁移的时候,特别是项目比较复杂的时候,很容易掉坑。下面我就自己的实践经验总结一下自己在进行CLI迁移的时候掉过的一些坑 1.Module build failed: Error: Angular Compiler was detected but it was an instance of the wrong class. This likely mean…...

    2024/4/15 3:54:52
  18. Hexo遇到的坑

    hexo新建文章的时候一直报错: ERROR Process failed: _posts/个人博客.md TypeError: Cannot read property utcOffset of null完整代码: D:\我的博客\Blog>hexo g INFO Start processing ERROR Process failed: _posts/个人博客.md TypeError: Cannot read property utc…...

    2024/4/15 3:54:50
  19. nodejs的部署的问题

    因为我们要管理很多依赖,最后我们选择使用autod来管理,autod:一个自动分析项目所有的文件,获取所有的项目依赖和它们的版本的工具。autod 同时可以根据我们传递的一些选项和参数,来直接更新 package.json 文件:通过这个工具,我们可以很轻松的跟踪到所有依赖的最新版本,…...

    2024/4/20 17:38:00
  20. node中异步处理Promise封装调用

    --所需模块安装模块 npm install bluebird logger需求:在node中异步调用多个api返回数据处理封装papi模块 /*** api请求封装*/ var request = require(request); var Promise = require(bluebird); var config = require(../config); //配置文件 var logger = require(./lo…...

    2024/4/15 3:54:56

最新文章

  1. 【亲测对比】大厂云服务器2-64G对比表 不卡顿 幻兽帕鲁 我的世界 雾锁王国 饥荒联机版 英灵神殿通用

    更新日期&#xff1a;4月26日&#xff08;京东云采购季持续进行&#xff09; 本文纯原创&#xff0c;侵权必究 《最新对比表》已更新在文章头部—腾讯云文档&#xff0c;文章具有时效性&#xff0c;请以腾讯文档为准&#xff01; 【腾讯文档实时更新】2024年-幻兽帕鲁服务器专…...

    2024/4/27 4:20:06
  2. 梯度消失和梯度爆炸的一些处理方法

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

    2024/3/20 10:50:27
  3. redis之主从复制、哨兵模式

    一 redis群集有三种模式 主从复制&#xff1a; 主从复制是高可用Redis的基础&#xff0c;哨兵和集群都是在主从复制基础上实现高可用的。 主从复制主要实现了数据的多机备份&#xff0c;以及对于读操作的负载均衡和简单的故障恢复。 缺陷&#xff1a; 故障恢复无法自动化&…...

    2024/4/26 19:46:10
  4. 大学教材《C语言程序设计》(浙大版)课后习题解析 | 第一、二章

    概述 本文主要提供《C语言程序设计》(浙大版) 第一、二章课后习题解析&#xff0c;以方便同学们完成题目后作为参考对照。后续将写出三、四章节课后习题解析&#xff0c;如想了解更多&#xff0c;请持续关注该专栏。 专栏直达链接&#xff1a;《C语言程序设计》(浙大版)_孟俊宇…...

    2024/4/26 14:42:37
  5. 【外汇早评】美通胀数据走低,美元调整

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

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

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

    2024/4/26 20:12:18
  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/25 18:39:22
  10. 【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响

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

    2024/4/25 18:39:22
  11. 【外汇早评】美欲与伊朗重谈协议

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

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

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

    2024/4/25 16:48:44
  13. 【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试

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

    2024/4/26 16:00:35
  14. 【原油贵金属早评】市场情绪继续恶化,黄金上破

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    2024/4/25 18:39:00
  22. 丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者

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

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

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

    2024/4/25 18:38:58
  24. 械字号医用眼膜缓解用眼过度到底有无作用?

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

    2024/4/25 18:38:57
  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