学会JavaScript函数式编程(第3部分)
摘要: JS函数式编程入门。
- 原文:学会使用函数式编程的程序员(第3部分)
- 作者:前端小智
Fundebug经授权转载,版权归原作者所有。
本系列的其它篇:
- 学会使用函数式编程的程序员(第1部分)
- 学会使用函数式编程的程序员(第2部分)
引用透明 (Referential Transparency)
引用透明是一个富有想象力的优秀术语,它是用来描述纯函数可以被它的表达式安全的替换,通过下例来帮助我们理解。
在代数中,有一个如下的公式:
y = x + 10
复制代码
接着:
x = 3
复制代码
然后带入表达式:
y = 3 + 10
复制代码
注意这个方程仍然是有效的,我们可以利用纯函数做一些相同类型的替换。
下面是一个 JavaScript 的方法,在传入的字符串两边加上单引号:
function quote (str) {retrun "'" + str + "'"
}
复制代码
下面是调用它:
function findError (key) {return "不能找到 " + quote(key)}
复制代码
当查询 key 值失败时,findError 返回一个报错信息。
因为 quote 是纯函数,我们可以简单地将 quote 函数体(这里仅仅只是个表达式)替换掉在findError中的方法调用:
function findError (key) {return "不能找到 " + "'" + str + "'"}
复制代码
这个就是通常所说的**“反向重构”**(它对我而言有更多的意义),可以用来帮程序员或者程序(例如编译器和测试程序)推理代码的过程一个很好的方法。如,这在推导递归函数时尤其有用的。
执行顺序 (Execution Order)
大多数程序都是单线程的,即一次只执行一段代码。即使你有一个多线程程序,大多数线程都被阻塞等待I/O完成,例如文件,网络等等。
这也是当我们编写代码的时候,我们很自然考虑按次序来编写代码:
1. 拿到面包
2. 把2片面包放入烤面包机
3. 选择加热时间
4. 按下开始按钮
5. 等待面包片弹出
6. 取出烤面包
7. 拿黄油
8. 拿黄油刀
9. 制作黄油面包
复制代码
在这个例子中,有两个独立的操作:拿黄油以及 加热面包。它们在 步骤9 时开始变得相互依赖。
我们可以将 步骤7 和 步骤8 与 步骤1 到 步骤6 同时执行,因为它们彼此独立。当我们开始做的时候,事情开始复杂了:
线程一
--------------------------
1. 拿到面包
2. 把2片面包放入烤面包机
3. 选择加热时间
4. 按下开始按钮
5. 等待面包片弹出
6. 取出烤面包 线程二
-------------------------
1. 拿黄油
2. 拿黄油刀
3. 等待线程1完成
4. 取出烤面包
复制代码
果线程1失败,线程2怎么办? 怎么协调这两个线程? 烤面包这一步骤在哪个线程运行:线程1,线程2或者两者?
不考虑这些复杂性,让我们的程序保持单线程会更容易。但是,只要能够提升我们程序的效率,要付出努力来写好多线程程序,这是值得的。
然而,多线程有两个主要问题:
- 多线程程序难于编写、读取、解释、测试和调试。
- 一些语言,例如JavaScript,并不支持多线程,就算有些语言支持多线程,对它的支持也很弱。
但是,如果顺序无关紧要,所有事情都是并行执行的呢?
尽管这听起来有些疯狂,但其实并不像听起来那么混乱。让我们来看一下 Elm 的代码来形象的理解它:
buildMessage message value =letupperMessage =String.toUpper messagequotedValue ="'" ++ value ++ "'"inupperMessage ++ ": " ++ quotedValue
复制代码
这里的 buildMessage 接受参数 message 和 value,然后,生成大写的 message和 带有引号的 value 。
注意到 upperMessage 和 quotedValue 是独立的。我们怎么知道的呢?
在上面的代码示例中,upperMessage 和 quotedValue 两者都是纯的并且没有一个需要依赖其它的输出。
如果它们不纯,我们就永远不知道它们是独立的。在这种情况下,我们必须依赖程序中调用它们的顺序来确定它们的执行顺序。这就是所有命令式语言的工作方式。
第二点必须满足的就是一个函数的输出值不能作为其它函数的输入值。如果存在这种情况,那么我们不得不等待其中一个完成才能执行下一个。
在本例中,upperMessage 和 quotedValue 都是纯的并且没有一个需要依赖其它的输出,因此,这两个函数可以以任何顺序执行。
编译器可以在不需要程序员帮助的情况下做出这个决定。这只有在纯函数式语言中才有可能,因为很难(如果不是不可能的话)确定副作用的后果。
在纯函数语言中,执行的顺序可以由编译器决定。
考虑到 CPU 无法一再的加快速度,这种做法非常有利的。别一方面,生产商也不断增加CPU内核芯片的数量,这意味着代码可以在硬件层面上并行执行。使用纯函数语言,就有希望在不改变任何代码的情况下充分地发挥 CPU 芯片的功能并取得良好成效。
类型注释 (Type Annotations)
在静态类型语言中,类型是内联定义的。以下是 Java 代码:
public static String quote(String str) {return "'" + str + "'";
}
复制代码
注意类型是如何同函数定义内联在一起的。当有泛型时,它变的更糟:
private final Map<Integer, String> getPerson(Map<String, String> people, Integer personId) {// ...
}
复制代码
这里使用粗体标出了使它们使用的类型,但它们仍然会让函数可读性降低,你必须仔细阅读才能找到变量的名称。
对于动态类型语言,这不是问题。在 Javascript 中,可以编写如下代码:
var getPerson = function(people, personId) {// ...
};
复制代码
这样没有任何的的类型信息更易于阅读,唯一的问题就是放弃了类型检测的安全特性。这样能够很简单的传入这些参数,例如,一个 Number 类型的 people 以及一个 Objec t类型的 personId。
动态类型要等到程序执行后才能知道哪里问题,这可能是在发布的几个月后。在 Java 中不会出现这种情况,因为它不能被编译。
但是,假如我们能同时拥有这两者的优异点呢? JavaScript 的语法简单性以及 Java 的安全性。
事实证明我们可以。下面是 Elm 中的一个带有类型注释的函数:
add : Int -> Int -> Int
add x y =x + y
复制代码
请注意类型信息是在单独的代码行上面的,而正是这样的分割使得其有所不同。
现在你可能认为类型注释有错训。 第一次见到它的时候。 大都认为第一个 -> 应该是一个逗号。可以加上隐含的括号,代码就清晰多了:
add : Int -> (Int -> Int)
复制代码
上例 add 是一个函数,它接受类型为 Int 的单个参数,并返回一个函数,该函数接受单个参数 Int类型 并返回一个 Int 类型的结果。
以下是一个带括号类型注释的代码:
doSomething : String -> (Int -> (String -> String))
doSomething prefix value suffix =
prefix ++ (toString value) ++ suffix
复制代码
这里 doSomething 是一个函数,它接受 String 类型的单个参数,然后返回一个函数,该函数接受 Int 类型的单个参数,然后返回一个函数,该函数接受 String 类型的单个参数,并返回一个字符串。
注意为什么每个方法都只接受一个参数呢? 这是因为每个方法在 Elm 里面都是柯里化。
因为括号总是指向右边,它们是不必要的,简写如下:
doSomething : String -> Int -> String -> String
复制代码
当我们将函数作为参数传递时,括号是必要的。如果没有它们,类型注释将是不明确的。例如:
takes2Params : Int -> Int -> String
takes2Params num1 num2 =-- do something
复制代码
非常不同于:
takes1Param : (Int -> Int) -> String
takes1Param f =-- do something
复制代码
takes2Param 函数需要两个参数,一个 Int 和另一个 Int,而takes1Param 函数需要一个参数,这个参数为函数, 这个函数需要接受两个 Int 类型参数。
下面是 map 的类型注释:
map : (a -> b) -> List a -> List b
map f list =// ...
复制代码
这里需要括号,因为 f 的类型是(a -> b),也就是说,函数接受类型 a 的单个参数并返回类型 b 的某个函数。
这里类型 a 是任何类型。当类型为大写形式时,它是显式类型,例如 String。当一个类型是小写时,它可以是任何类型。这里 a 可以是字符串,也可以是 Int。
如果你看到 (a -> a) 那就是说输入类型和输出类型必须是相同的。它们是什么并不重要,但必须匹配。
但在 map 这一示例中,有这样一段 (a -> b)。这意味着它既能返回一个不同的类型,也能返回一个相同的类型。
但是一旦 a 的类型确定了,a 在整段代码中就必须为这个类型。例如,如果 a 是一个 Int,b 是一个 String,那么这段代码就相当于:
(Int -> String) -> List Int -> List String
复制代码
这里所有的 a 都换成了 Int,所有的 b 都换成了 String。
List Int 类型意味着一个值都为 Int 类型的列表, List String 意味着一个值都为 String 类型的列表。如果你已经在 Java 或者其他的语言中使用过泛型,那么这个概念你应该是熟悉的
函数式 JavaScript
JavaScript 拥有很多类函数式的特性但它没有纯性,但是我们可以设法得到一些不变量和纯函数,甚至可以借助一些库。
但这并不是理想的解决方法。如果你不得不使用纯特性,为何不直接考虑函数式语言?
这并不理想,但如果你必须使用它,为什么不从函数式语言中获得一些好处呢?
不可变性(Immutability)
首先要考虑的是不变性。在ES2015或ES6中,有一个新的关键词叫const,这意味着一旦一个变量被设置,它就不能被重置:
const a = 1;
a = 2; // 这将在Chrome、Firefox或 Node中抛出一个类型错误,但在Safari中则不会
复制代码
在这里,a 被定义为一个常量,因此一旦设置就不能更改。这就是为什么 a = 2 抛出异常。
const 的缺陷在于它不够严格,我们来看个例子:
const a = {x: 1,y: 2
};
a.x = 2; // 没有异常
a = {}; // 报错
复制代码
注意到 a.x = 2 没有抛出异常。const 关键字唯一不变的是变量 a, a 所指向的对象是可变的。
那么Javascript中如何获得不变性呢?
不幸的是,我们只能通过一个名为 Immutable.js 的库来实现。这可能会给我们带来更好的不变性,但遗憾的是,这种不变性使我们的代码看起来更像 Java 而不是 Javascript。
柯里化与组合 (curring and composition)
在本系列的前面,我们学习了如何编写柯里化函数,这里有一个更复杂的例子:
const f = a => b => c => d => a + b + c + d
复制代码
我们得手写上述柯里化的过程,如下:
console.log(f(1)(2)(3)(4)); // prints 10
复制代码
括号如此之多,但这已经足够让Lisp程序员哭了。有许多库可以简化这个过程,我最喜欢的是 Ramda。
使用 Ramda 简化如下:
const f = R.curry((a, b, c, d) => a + b + c + d);
console.log(f(1, 2, 3, 4)); // prints 10
console.log(f(1, 2)(3, 4)); // also prints 10
console.log(f(1)(2)(3, 4)); // also prints 10
复制代码
函数的定义并没有好多少,但是我们已经消除了对那些括号的需要。注意,调用 f 时,可以指定任意参数。
重写一下之前的 mult5AfterAdd10 函数:
const add = R.curry((x, y) => x + y);
const mult5 = value => value * 5;
const mult5AfterAdd10 = R.compose(mult5, add(10));
复制代码
事实上 Ramda 提供了很多辅助函数来做些简单常见的运算,比如R.add以及R.multiply。以上代码我们还可以简化:
const mult5AfterAdd10 = R.compose(R.multiply(5), R.add(10));
复制代码
Map, Filter and Reduce
Ramda 也有自己的 map、filter和 reduce 版本。虽然这些函数存在于数组中。这几个函数是在 Array.prototype 对象中的,而在 Ramda 中它们是柯里化的
const isOdd = R.flip(R.modulo)(2);
const onlyOdd = R.filter(isOdd);
const isEven = R.complement(isOdd);
const onlyEven = R.filter(isEven);
const numbers = [1, 2, 3, 4, 5, 6, 7, 8];
console.log(onlyEven(numbers)); // prints [2, 4, 6, 8]
console.log(onlyOdd(numbers)); // prints [1, 3, 5, 7]
复制代码
R.modulo 接受2个参数,被除数和除数。
isOdd 函数表示一个数除 2 的余数。若余数为 0,则返回 false,即不是奇数;若余数为 1,则返回 true,是奇数。用 R.filp 置换一下 R.modulo 函数两个参数顺序,使得 2 作为除数。
isEven 函数是 isOdd 函数的补集。
onlyOdd 函数是由 isOdd 函数进行断言的过滤函数。当它传入最后一个参数,一个数组,它就会被执行。
同理,onlyEven 函数是由 isEven 函数进行断言的过滤函数。
当我们给函数 onlyEven 和 onlyOd 传入 numbers,isEven 和 isOdd 获得了最后的参数,然后执行最终返回我们期望的数字。
Javascript的缺点
所有的库和语言增强都已经得到了Javascript 的发展,但它仍然面临着这样一个事实:它是一种强制性的语言,它试图为所有人提供所有的东西。
大多数前端开发人员都不得不使用 Javascript,因为这旨浏览器也识别的语言。相反,它们使用不同的语言编写,然后编译,或者更准确地说,是把其它语言转换成 Javascript。
CoffeeScript 是这类语言中最早的一批。目前,TypeScript 已经被 Angular2 采用,Babel可以将这类语言编译成 JavaScript,越来越多的开发者在项目中采用这种方式。
但是这些语言都是从 Javascript 开始的,并且只稍微改进了一点。为什么不直接从纯函数语言转换到Javascript呢?
未来期盼
我们不可能知道未来会怎样,但我们可以做一些有根据的猜测。以下是作者的一些看法:
- 能转换成 JavaScript 这类语言会有更加丰富及健壮。
- 已有40多年历史的函数式编程思想将被重新发现,以解决我们当前的软件复杂性问题。
- 目前的硬件,比如廉价的内存,快速的处理器,使得函数式技术普及成为可能。
- PU不会变快,但是内核的数量会持续增加。
- 可变状态将被认为是复杂系统中最大的问题之一。
希望这系列文章能帮助你更好容易更好帮助你理解函数式编程及优势,作者相信函数式编程是未来趋势,大家有时间可以多多了解,接着提升你们的技能,然后未来有更好的出路。
原文:
- medium.com/@cscalfani.…
- medium.com/@cscalfani.…
编辑中可能存在的bug没法实时知道,事后为了解决这些bug,花了大量的时间进行log 调试,这边顺便给大家推荐一个好用的BUG监控工具Fundebug。
你的点赞是我持续分享好东西的动力,欢迎点赞!
一个笨笨的码农,我的世界只能终身学习!
更多内容请关注公众号《大迁世界》!
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
相关文章
- 四月的十大Java故事:Angular v8,Apache NetBeans v11.0,Java 13及更高版本
在Angular v8的路上 Angular 8越来越近:两个新的候选版本已经到来! 这两个版本仅带来很少的变化。 即将推出的两个主要功能Bazel和Ivy发生了什么? 在这里检查我们的线程。 回顾2019年4月的TIOBE指数 根据2019年4月的TIOBE指数,C…...
2024/4/21 14:11:11 - Spring WebFlux
目录响应式编程Spring WebFlux简介WebFlux使用示例响应式编程 响应式编程(reactive programming)是一种异步编程风格,关注数据流、变化传播。 在命令式编程中,abc赋值,此后b、c的值的改变不会影响到a;在响…...
2024/4/21 14:11:10 - VUE响应式数据原理—19.3.28前端日报
给 前端开发博客 加星标,每天进步一点长按二维码即可识别“进入网页”查看哟~1、【前端进阶基础】VUE响应式数据原理 订阅-发布模式解析vue框架的两个抽象核心:虚拟DOM和相应式数据原理 关于虚拟DOM的核心算法,我们上一章已经基本解析过了&am…...
2024/5/4 17:39:06 - 双眼皮怎么贴眼睛变圆
...
2024/4/21 14:11:08 - 大数据舆情情感分析,如何提取情感并使用什么样的工具?
人工智能大数据与深度学习 公众号: weic2c情感分析是学术领域研究多年的课题,用google学术搜索可以找到很多paper,基本的方法上有基于词典规则的方法、语言文法的方法,此外还有分类器以及近几年比较火的深度学习的方法(稍后有详细介绍)。各类paper是有一定的借鉴意义的,不…...
2024/5/4 16:38:05 - 双眼皮怎么画眼妆图片
...
2024/4/21 14:11:06 - ionic3嵌入html页面,ionic3 在微信中配置路由导航 DeepLinker实现指定页面URL
Ionic3使用了近似原生App的页面导航方式,并不支持Angular5的路由。Ionic3的这种路由方式在开发本地App的时候比较方便,但如果要用来开发纯Web页面,或者微信公众号的时候就有点问题了。比如:在首页是一个Tabs页面的情况下,如何控制…...
2024/4/21 14:11:05 - 双眼皮怎么变宽变深
...
2024/4/28 20:53:44 - 双眼皮有几种割法
...
2024/5/5 0:47:43 - 【前端vue——系列2】vue中的data是函数而不是对象与computed的实现原理
系列文章总结 【前端vue——系列1】vue的路由 【前端vue——系列2】vue中的data是函数而不是对象与computed的实现原理 【前端vue——系列3】vue框架的优缺点;vue实现双向绑定 【前端vue——系列4】vuex和angular 【前端vue——系列5】生命周期详讲(vue…...
2024/4/20 15:34:47 - Angular 根据 service 的状态更新 directive
TL;DR 这篇文章讲解了三种根据 service 的状态更新 directive 的做法。分别是 $watch 表达式,事件传递,和 controller 的计算属性。 问题 我有一个 readerService ,其中包含一些状态信息(比如连接状态和电量)。现在我需…...
2024/4/20 15:34:46 - Backbone和Angular的比较
将不同的思想和工具进行对比,是一种更好地理解它们的方式。在本文中,我首先将列举在创建web应用程序时需要重复进行的各项任务,随后为你展现Backbone和Angular将如何帮助你完成这些工作。 我们所尝试解决的问题 作为web开发者来说,…...
2024/5/4 13:57:47 - vue计算属性computed的使用
计算属性computed 描述:在同一个实例化对象中,其中一个属性改变,要求另外一个属性也跟着改变 angular事件监听: $scope.$watch计算属性的使用: computed:{ b:function(){ //默认调用get return 值 } }小例子:<div id&qu…...
2024/4/21 14:11:04 - 双眼皮应该画什么眼线
...
2024/5/4 22:59:50 - 双眼皮一年才恢复好
...
2024/4/26 22:19:42 - 双眼皮一个月了不自然
...
2024/5/4 21:17:39 - angular Ionic CLI组件建立,使用图标,弹窗,按钮,卡片,列表,无尽滚动,刷新
...
2024/5/4 16:15:47 - 双眼皮一个眼尾高
...
2024/5/4 15:53:28 - 双眼皮眼尾吊高了
...
2024/4/21 14:10:58 - 双眼皮眼皮松了怎么办
...
2024/4/21 14:10:57
最新文章
- 代码随想录算法训练营第25天 | 216.组合总和III、17.电话号码的字母组合
代码随想录算法训练营第25天 | 216.组合总和III、17.电话号码的字母组合 自己看到题目的第一想法看完代码随想录之后的想法 链接: 216.组合总和III 链接: 17.电话号码的字母组合 自己看到题目的第一想法 216.组合总和III:递归函数终止条件为搜索得到的数相加为n&…...
2024/5/5 1:30:09 - 梯度消失和梯度爆炸的一些处理方法
在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言,在此感激不尽。 权重和梯度的更新公式如下: w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...
2024/3/20 10:50:27 - Node.js常用快捷键
1.常用的终端命令: (1)del 文件名: 删除文件 (2)ipconfig: 查看IP命令 (3)mkdir 目录名 :在当前目录新建指定目录 (4)rd 目录名:在当前…...
2024/5/2 19:01:35 - 图像处理相关知识 —— 椒盐噪声
椒盐噪声是一种常见的图像噪声类型,它会在图像中随机地添加黑色(椒)和白色(盐)的像素点,使图像的质量降低。这种噪声模拟了在图像传感器中可能遇到的问题,例如损坏的像素或传输过程中的干扰。 椒…...
2024/5/3 19:03:59 - 【QT入门】 QTabWidget各种常见用法详解
往期回顾: 【QT入门】 Qt代码创建布局之分裂器布局详解-CSDN博客 【QT入门】 Qt代码创建布局之setLayout使用-CSDN博客 【QT入门】 Qt代码创建布局之多重布局变换与布局删除技巧-CSDN博客 【QT入门】 QTabWidget各种常见用法详解 一般来说,学一个新的控…...
2024/4/30 19:32:16 - 【外汇早评】美通胀数据走低,美元调整
原标题:【外汇早评】美通胀数据走低,美元调整昨日美国方面公布了新一期的核心PCE物价指数数据,同比增长1.6%,低于前值和预期值的1.7%,距离美联储的通胀目标2%继续走低,通胀压力较低,且此前美国一季度GDP初值中的消费部分下滑明显,因此市场对美联储后续更可能降息的政策…...
2024/5/4 23:54:56 - 【原油贵金属周评】原油多头拥挤,价格调整
原标题:【原油贵金属周评】原油多头拥挤,价格调整本周国际劳动节,我们喜迎四天假期,但是整个金融市场确实流动性充沛,大事频发,各个商品波动剧烈。美国方面,在本周四凌晨公布5月份的利率决议和新闻发布会,维持联邦基金利率在2.25%-2.50%不变,符合市场预期。同时美联储…...
2024/5/4 23:54:56 - 【外汇周评】靓丽非农不及疲软通胀影响
原标题:【外汇周评】靓丽非农不及疲软通胀影响在刚结束的周五,美国方面公布了新一期的非农就业数据,大幅好于前值和预期,新增就业重新回到20万以上。具体数据: 美国4月非农就业人口变动 26.3万人,预期 19万人,前值 19.6万人。 美国4月失业率 3.6%,预期 3.8%,前值 3…...
2024/5/4 23:54:56 - 【原油贵金属早评】库存继续增加,油价收跌
原标题:【原油贵金属早评】库存继续增加,油价收跌周三清晨公布美国当周API原油库存数据,上周原油库存增加281万桶至4.692亿桶,增幅超过预期的74.4万桶。且有消息人士称,沙特阿美据悉将于6月向亚洲炼油厂额外出售更多原油,印度炼油商预计将每日获得至多20万桶的额外原油供…...
2024/5/4 23:55:17 - 【外汇早评】日本央行会议纪要不改日元强势
原标题:【外汇早评】日本央行会议纪要不改日元强势近两日日元大幅走强与近期市场风险情绪上升,避险资金回流日元有关,也与前一段时间的美日贸易谈判给日本缓冲期,日本方面对汇率问题也避免继续贬值有关。虽然今日早间日本央行公布的利率会议纪要仍然是支持宽松政策,但这符…...
2024/5/4 23:54:56 - 【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响
原标题:【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响近日伊朗局势升温,导致市场担忧影响原油供给,油价试图反弹。此时OPEC表态稳定市场。据消息人士透露,沙特6月石油出口料将低于700万桶/日,沙特已经收到石油消费国提出的6月份扩大出口的“适度要求”,沙特将满…...
2024/5/4 23:55:05 - 【外汇早评】美欲与伊朗重谈协议
原标题:【外汇早评】美欲与伊朗重谈协议美国对伊朗的制裁遭到伊朗的抗议,昨日伊朗方面提出将部分退出伊核协议。而此行为又遭到欧洲方面对伊朗的谴责和警告,伊朗外长昨日回应称,欧洲国家履行它们的义务,伊核协议就能保证存续。据传闻伊朗的导弹已经对准了以色列和美国的航…...
2024/5/4 23:54:56 - 【原油贵金属早评】波动率飙升,市场情绪动荡
原标题:【原油贵金属早评】波动率飙升,市场情绪动荡因中美贸易谈判不安情绪影响,金融市场各资产品种出现明显的波动。随着美国与中方开启第十一轮谈判之际,美国按照既定计划向中国2000亿商品征收25%的关税,市场情绪有所平复,已经开始接受这一事实。虽然波动率-恐慌指数VI…...
2024/5/4 23:55:16 - 【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试
原标题:【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试美国和伊朗的局势继续升温,市场风险情绪上升,避险黄金有向上突破阻力的迹象。原油方面稍显平稳,近期美国和OPEC加大供给及市场需求回落的影响,伊朗局势并未推升油价走强。近期中美贸易谈判摩擦再度升级,美国对中…...
2024/5/4 23:54:56 - 【原油贵金属早评】市场情绪继续恶化,黄金上破
原标题:【原油贵金属早评】市场情绪继续恶化,黄金上破周初中国针对于美国加征关税的进行的反制措施引发市场情绪的大幅波动,人民币汇率出现大幅的贬值动能,金融市场受到非常明显的冲击。尤其是波动率起来之后,对于股市的表现尤其不安。隔夜美国股市出现明显的下行走势,这…...
2024/5/4 18:20:48 - 【外汇早评】美伊僵持,风险情绪继续升温
原标题:【外汇早评】美伊僵持,风险情绪继续升温昨日沙特两艘油轮再次发生爆炸事件,导致波斯湾局势进一步恶化,市场担忧美伊可能会出现摩擦生火,避险品种获得支撑,黄金和日元大幅走强。美指受中美贸易问题影响而在低位震荡。继5月12日,四艘商船在阿联酋领海附近的阿曼湾、…...
2024/5/4 23:54:56 - 【原油贵金属早评】贸易冲突导致需求低迷,油价弱势
原标题:【原油贵金属早评】贸易冲突导致需求低迷,油价弱势近日虽然伊朗局势升温,中东地区几起油船被袭击事件影响,但油价并未走高,而是出于调整结构中。由于市场预期局势失控的可能性较低,而中美贸易问题导致的全球经济衰退风险更大,需求会持续低迷,因此油价调整压力较…...
2024/5/4 23:55:17 - 氧生福地 玩美北湖(上)——为时光守候两千年
原标题:氧生福地 玩美北湖(上)——为时光守候两千年一次说走就走的旅行,只有一张高铁票的距离~ 所以,湖南郴州,我来了~ 从广州南站出发,一个半小时就到达郴州西站了。在动车上,同时改票的南风兄和我居然被分到了一个车厢,所以一路非常愉快地聊了过来。 挺好,最起…...
2024/5/4 23:55:06 - 氧生福地 玩美北湖(中)——永春梯田里的美与鲜
原标题:氧生福地 玩美北湖(中)——永春梯田里的美与鲜一觉醒来,因为大家太爱“美”照,在柳毅山庄去寻找龙女而错过了早餐时间。近十点,向导坏坏还是带着饥肠辘辘的我们去吃郴州最富有盛名的“鱼头粉”。说这是“十二分推荐”,到郴州必吃的美食之一。 哇塞!那个味美香甜…...
2024/5/4 23:54:56 - 氧生福地 玩美北湖(下)——奔跑吧骚年!
原标题:氧生福地 玩美北湖(下)——奔跑吧骚年!让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 啊……啊……啊 两…...
2024/5/4 23:55:06 - 扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!
原标题:扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!扒开伪装医用面膜,翻六倍价格宰客!当行业里的某一品项火爆了,就会有很多商家蹭热度,装逼忽悠,最近火爆朋友圈的医用面膜,被沾上了污点,到底怎么回事呢? “比普通面膜安全、效果好!痘痘、痘印、敏感肌都能用…...
2024/5/4 2:59:34 - 「发现」铁皮石斛仙草之神奇功效用于医用面膜
原标题:「发现」铁皮石斛仙草之神奇功效用于医用面膜丽彦妆铁皮石斛医用面膜|石斛多糖无菌修护补水贴19大优势: 1、铁皮石斛:自唐宋以来,一直被列为皇室贡品,铁皮石斛生于海拔1600米的悬崖峭壁之上,繁殖力差,产量极低,所以古代仅供皇室、贵族享用 2、铁皮石斛自古民间…...
2024/5/4 23:55:16 - 丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者
原标题:丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者【公司简介】 广州华彬企业隶属香港华彬集团有限公司,专注美业21年,其旗下品牌: 「圣茵美」私密荷尔蒙抗衰,产后修复 「圣仪轩」私密荷尔蒙抗衰,产后修复 「花茵莳」私密荷尔蒙抗衰,产后修复 「丽彦妆」专注医学护…...
2024/5/4 23:54:58 - 广州械字号面膜生产厂家OEM/ODM4项须知!
原标题:广州械字号面膜生产厂家OEM/ODM4项须知!广州械字号面膜生产厂家OEM/ODM流程及注意事项解读: 械字号医用面膜,其实在我国并没有严格的定义,通常我们说的医美面膜指的应该是一种「医用敷料」,也就是说,医用面膜其实算作「医疗器械」的一种,又称「医用冷敷贴」。 …...
2024/5/4 23:55:01 - 械字号医用眼膜缓解用眼过度到底有无作用?
原标题:械字号医用眼膜缓解用眼过度到底有无作用?医用眼膜/械字号眼膜/医用冷敷眼贴 凝胶层为亲水高分子材料,含70%以上的水分。体表皮肤温度传导到本产品的凝胶层,热量被凝胶内水分子吸收,通过水分的蒸发带走大量的热量,可迅速地降低体表皮肤局部温度,减轻局部皮肤的灼…...
2024/5/4 23:54:56 - 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...
解析如下: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