KotlinPoet作为注解处理器生成代码的手段,相较于EventBus一行一行的write代码,KotlinPoet是采用面向对象的方式生成Kotlin代码,更符合设计人员的设计思路

KotlinPoet高级用法

    • 1 KotlinPoet的基础语法
    • 2 通过KotlinPoet生成简单的路由寻址代码
    • 问题:对于Kotlin中,返回值允许为空的 ? 如果通过KotlinPoet实现
    • 3 手写ARouter框架
    • 3.1 生成路由代码前的处理
    • 3.2 ARouter Path代码生成
    • 3.3 ARouteGroup代码生成
    • 4 问题处理

1 KotlinPoet的基础语法

首先写一段Kotlin代码

class testPoet{companion object {private const val TAG: String = "testPoet"}fun test(str:String){println(str)}
}

如果使用KotlinPoet生成Kotlin代码,按照面向对象的设计思路,首先写函数test,然后写类testPoet,将函数添加到类中,然后导出文件

 override fun process(p0: MutableSet<out TypeElement>?, p1: RoundEnvironment?): Boolean {p1?.let {val elementsSet = it.getElementsAnnotatedWith(LayRouter::class.java)for (element:Element in elementsSet){//1 先写方法  testval testMethod = FunSpec.builder("test").addModifiers(KModifier.PUBLIC).addParameter("str", String::class).returns(UNIT).addStatement("println(str)").build()//2 再写类val companion = TypeSpec.companionObjectBuilder().addProperty(PropertySpec.builder("TAG",String::class,KModifier.PRIVATE,KModifier.CONST).initializer("%S", "testPoet").build()).build()val classBuilder = TypeSpec.classBuilder("testPoet").addModifiers(KModifier.PUBLIC)//添加方法.addFunction(testMethod).addType(companion).build()//3 生成kotlin文件val file = FileSpec.builder("", "TestPoet").addType(classBuilder).build()//导出文件file.writeTo(filer!!)}}return false
}

这里有常用的几个类对象需要解释一下
1 FunSpec:用于生成函数,对应JavaPoet中的MethodSpec
addModifiers:函数的访问修饰符,是private、public、protect …
addParameter:方法中携带的参数,格式为 ”参数名“ ”参数类型“,如果存在多个参数,addParameter可以调用多次
returns:函数的返回值
addStatement:函数体,其中使用**%T** %S可以实现占位,%T 对应JavaPoet的 $T,例如一些类,%S用于字符串的占位

2 TypeSpec:用于生成类,与JavaPoet一致
addModifiers:添加访问修饰符
addFunction addType:在类中添加方法或者属性

3 PropertySpec:用于生成属性
initializer:如果属性需要初始化,格式为 “format 初始化的值” format为占位符

4 FileSpec:用于生成kotlin文件,通过Filer导出
在这里插入图片描述
有几个地方用到了注解,那么就会生成几个Kotlin文件

问题1:如果在一个模块中,多处使用到了注解,按照上述的方式,生成Kotlin文件,会不会有问题?
答案肯定是有的,因为生成的Kotlin文件名都是一致的,这种文件名就会冲突,因此可以通过element来获取注解元素的类名

val className = element.simpleName.toString()

2 通过KotlinPoet生成简单的路由寻址代码

对于每个Activity,想要获取目标Activity的Class,可以通过map,根据path将每个Activity对应的class作为value保存,从path中取出class即可跳转,这种方式存在的局限在于需要手动注册,而且面对大量的Activity,1对1注册是不现实的,那么就可以通过APT的方式实现

 class MainActivityARouter{companion object{fun findTargetClassName(path:String): KClass<MainActivity>? {return if(path == "app/MainActivity") MainActivity::class else null}}
}

这是MainActivity的路由寻址代码,通过输入path验证路径是否一致,如果一致,那么就获取MainActivity的字节码,跳转

这里通过KotlinPoet生成代码,就不再是简单的输入几句话就可以的,像MainActivity,path等都是需要动态获取的,包括泛型的使用,返回值是否可为空的判断

val annotation = element.getAnnotation(LayRouter::class.java)
//方法
val funSpec = FunSpec.builder("findTargetClassName")
val companion = TypeSpec.companionObjectBuilder().addFunction(funSpec.addModifiers(KModifier.PUBLIC).returns(KClass::class.asTypeName().parameterizedBy(element.asType().asTypeName())).addParameter("path", String::class).addStatement("return if(path == %S) %T::class else null",annotation.path,element.asType().asTypeName()).build()).build()
//写类
val classBuilder = TypeSpec.classBuilder(className+"ARouter").addType(companion).build()val fileSpec = FileSpec.builder("", className+"Finding").addType(classBuilder).build()
fileSpec.writeTo(filer!!)

这里只说新的点

1 对于返回值是泛型类型的数据KClass<MainActivity>,其中泛型中的参数,可以通过parameterizedBy表示,有几个参数就选择添加进去几个参数

2 获取注解类的Class,可以通过Element来获取具体的class类型

element.asType().asTypeName()

这里还现存一个问题

**

问题:对于Kotlin中,返回值允许为空的 ? 如果通过KotlinPoet实现

**

3 手写ARouter框架

在真正的组件化工程中,以上的方式实现路由跳转代码冗余严重,而且没必要每个注解类都生成一份代码,要真正体现组件化的体系

在这里插入图片描述

从app的壳工程出发,可以通过路由的方式调起本group的页面,也可以跨模块调起其他group的页面,可以通过一个全局的map来实现

/*** element 每个Activity都是一个元素* model 每个Activity的Class*/
class RouteBean(builder: Builder) {private var element: Element? = nullprivate var model:KClass<*>? = nullprivate var type: RouterType? = nullprivate var path:String = ""private var group:String = "null"init {this.element = builder.elementthis.group = builder.groupthis.path = builder.path}companion object{fun create(model:KClass<*>,type: RouterType,path:String,group:String) : RouteBean{val bean = Builder.addGroup(group).addPath(path).build()bean.setType(type)bean.setModel(model)return bean}}/*** 建造者模式*/object Builder{var element: Element? = nullvar path:String = ""var group:String = ""fun addElement(element: Element):Builder{this.element = elementreturn this}fun addGroup(group:String):Builder{this.group = groupreturn this}fun addPath(path:String):Builder{this.path = pathreturn this}fun build():RouteBean{return RouteBean(this)}}fun setType(type: RouterType){this.type = type}fun setModel(model:KClass<*>){this.model = model}fun getType():RouterType{return type!!}fun getModel():KClass<*>{return model!!}fun getGroup():String{return group}fun getPath():String{return path}fun getElement():Element{return element!!}
}enum class RouterType{ACTIVITY,FRAGMENT
}

先从组的维度,每个组下面都有对应的path,key就是app、video、mine等等,拿到了group对应的path,也是一个map;key就是app/MainActivity … value是每个注解类的信息,包括对应的Class

ARouter$$path$$app
ARouter$$path$$video
ARouter$$path$$mineARouter$$group$$app
ARouter$$group$$video
ARouter$$group$$mine

先写基础的一个样板,然后使用KotlinPoet生成代码

    //<"app","List<RouteBean>">//<"video","List<RouteBean>">//<"mine","List<RouteBean>">private val pathMap = mutableMapOf<String,MutableList<RouteBean>>()//封装group的mapprivate val groupMap = mutableMapOf<String,String>()

3.1 生成路由代码前的处理

 override fun process(p0: MutableSet<out TypeElement>?, p1: RoundEnvironment?): Boolean {p1?.let {val elementsSet = it.getElementsAnnotatedWith(LayRouter::class.java)for (element: Element in elementsSet) {val className = element.simpleName.toString()val annotation = element.getAnnotation(LayRouter::class.java)//创建RootBeanval routeBean = RouteBean.Builder.addElement(element).addGroup(annotation.group).addPath(annotation.path).build()//判断是Activity上的注解还是Fragment上的val activityMirror = elementTool!!.getTypeElement(ACTIVITY_PACKAGE).asType()if(typeTool!!.isSubtype(element.asType(),activityMirror)){routeBean.setType(RouterType.ACTIVITY)}else{//抛出异常throw Exception("@LayRouter注解只能在Activity或者Fragment上使用")}//根据group分组var pathChild:MutableList<RouteBean>? = pathMap[routeBean.getGroup()]if(pathChild.isNullOrEmpty()){pathChild = mutableListOf()//如果是空的pathChild.add(routeBean)//添加到map中pathMap[routeBean.getGroup()] = pathChild}else{//如果不为空pathCild.add(routeBean)}}//循环查找完成message!!.printMessage(Diagnostic.Kind.NOTE,"查看map $pathMap")createPathFile()createGroupFile()}return true}

在生成代码之前,先需要统计每个组内有多少路由线,才能在getARoutePath函数体内,将所有的路由线路添加到map中,因此对每个模块的全部注解类,需要添加到一个pathMap中,主要是为了循环添加代码语句准备的

{app=[com.study.compiler_api.RouteBean@3a5c7c9d, com.study.compiler_api.RouteBean@3891f826]}

3.2 ARouter Path代码生成

 class ARouter$$path$$app : IARoutPath{override fun getARoutePath(): MutableMap<String, RouteBean> {val pathMap = mutableMapOf<String,RouteBean>()pathMap.put("app/MainActivity",RouteBean.create(model,type,path,group))return pathMap}
}

使用kotlinPoet生成代码

private fun createPathFile() {//从pathMap中,获取pathval builder = FunSpec.builder("getARoutePath").addModifiers(KModifier.OVERRIDE)//返回值.returns(MutableMap::class.asTypeName().parameterizedBy(String::class.asTypeName(),RouteBean::class.asTypeName())).addStatement("val %N = mutableMapOf<%T,%T>()",pathMap_Variable,String::class,RouteBean::class)//map添加需要放循环里pathMap.forEach { (_, mutableList) ->//判断模块传过来的参数mutableList.forEach { routeBean ->builder.addStatement("%N.put(%S,%T.create(%T::class,%T.%L,%S,%S))",pathMap_Variable,routeBean.getPath(),RouteBean::class,routeBean.getElement().asType().asTypeName(),RouterType::class,routeBean.getType(),routeBean.getPath(),routeBean.getGroup())}}builder.addStatement("return %N",pathMap_Variable)val className = "ARouter_path_$option"//创建文件val fileBuilder = FileSpec.builder("", className).addType(TypeSpec.classBuilder(className).addFunction(builder.build()).addSuperinterface(ClassName("com.study.compiler_api","IARoutPath")).build()).build()fileBuilder.writeTo(filer!!)//往groupMap里添加if(!groupMap.containsKey(option)){groupMap[option] = className}message!!.printMessage(Diagnostic.Kind.NOTE,"groupMap $groupMap")}

只说新的知识点
1 占位符 %N,变量的占位符,对应JavaPoet中的$N
占位符 %L,字面量,像一些枚举、常量等可以使用

2 addSuperinterface :实现某个类或者接口,参数ClassName(“包名”,“实现的类或者接口”)

因为需要将所有的路由注册到map中,因此就用到了一开始在element循环中使用到的pathMap,其中封装了List<RoouteBean>,可以把所有的路由信息取出来

public class ARouter_path_app : IARoutPath {public override fun getARoutePath(): Map<String, RouteBean> {val pathMap = mutableMapOf<String,RouteBean>()pathMap.put("app/MainActivity",RouteBean.create(MainActivity::class,RouterType.ACTIVITY,"app/MainActivity","app"))pathMap.put("app/SecondActivity",RouteBean.create(SecondActivity::class,RouterType.ACTIVITY,"app/SecondActivity","app"))return pathMap}
}

在导出某个组的全部孩子路由地址之后,将group名称和代表该组的路由类名称保存起来

3.3 ARouteGroup代码生成

class ARouteGroupApp : IARoutGroup {override fun getARouteGroup(): Map<String, IARoutPath> {val groupMap = mutableMapOf<String, IARoutPath>()groupMap["app"] = ARouter_path_app()return groupMap}
}

koltinPoet生成代码

 private fun createGroupFile() {val builder = FunSpec.builder("getARouteGroup").addModifiers(KModifier.OVERRIDE).returns(Map::class.asTypeName().parameterizedBy(String::class.asTypeName(),IARoutPath::class.asTypeName())).addStatement("val %N = mutableMapOf<%T,%T>()",groupMap_Variable,String::class,IARoutPath::class)groupMap.forEach { (key, value) ->builder.addStatement("groupMap[%S] = %T()",key,ClassName("",value))}builder.addStatement("return %N",groupMap_Variable)val classBuilder = TypeSpec.classBuilder("ARouteGroup$option").addFunction(builder.build()).addSuperinterface(ClassName("com.study.compiler_api","IARoutGroup")).build()val file = FileSpec.builder("", "ARouteGroup$option").addType(classBuilder).build()file.writeTo(filer!!)}

这里有一点,就是通过类名(字符串),找到在包中对应的类,就是通过ClassName,第一个参数是包名,要查找的类所在的包名,value就是类名称

ClassName("",value)

4 问题处理

如果按照这种方式来生成apt代码,会有一个问题,尝试重新打开文件失败!!

Caused by: javax.annotation.processing.FilerException: Attempt to reopen a file for path 

原因就是,process方法会被执行2次,那么在写apt代码的时候,就会被执行2次,第一次生成的Kotlin代码后,相同的文件名,再次执行process方法的时候会报错

网上有问答是把process返回为true,不工作了就能够避免,但是尝试之后并没有效果

解决方案:

process(Set<? extends TypeElement> set, RoundEnvironment roundEnvironment)

process函数两个参数,set只有1次情况下不为空,其他情况下为空,因此在不为空的情况下可以进行注解处理,如果为空,那么就直接返回false即可,这才是问题的关键!!

//处理注解override fun process(p0: MutableSet<out TypeElement>?, p1: RoundEnvironment?): Boolean {if(p0!!.isEmpty()){return false}
查看全文
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

相关文章

  1. GAMES101第三讲Transformation笔记

    变换一、2D变换&#xff08;2D Transformation&#xff09;二、齐次坐标&#xff08;Homogeneous coordinates&#xff09;三、逆变换&#xff08;Inverse Transform&#xff09;四、组合变换&#xff08;Compose Transform&#xff09;五、3D变换&#xff08;3D Transformatio…...

    2024/4/13 21:23:33
  2. system verilog学习记录2--类和随机约束

    system verilog学习记录2–类和随机约束 类 类的特点&#xff1a;封装&#xff0c;继承&#xff0c;多态。对象创建的初始化顺序,(有super.new()) 1). 子类实例在初始化的时候要先调用父类的new()&#xff1b; 2). 父类new()完成后&#xff0c;子类成员变量初始化&#xff1b;…...

    2024/4/13 21:23:38
  3. Java基础(03)

    4.JAVA基础 4.1注释、标识符、关键字 注释 平时我们编写代码时&#xff0c;在代码量比较少的时候&#xff0c;我们还可以看懂自己写的&#xff0c;但是当项目结构一旦复杂的时候&#xff0c;我们就需要用到注释 注释并不会被执行&#xff0c;是写给程序员看的 书写注释时一…...

    2024/4/20 12:24:26
  4. Codeforces Round#768(Div.2) D. Range and Partition

    题意 给定一个数组&#xff0c;将这个数组分为k块&#xff0c;每一块要求在区间[x,y]内的数都要多于在区间外的数。求一个[x,y]使得y-x值最小&#xff0c;并输出k个区间的左右端点。 题解 我们先分析一下题意&#xff0c;找到我们需要解决的问题&#xff0c;以及问题中相互牵…...

    2024/4/20 15:30:45
  5. 关于领域驱动以及面向对象的实例思考

    序言 领域驱动设计是当下主流的设计思想&#xff0c;在微服务的设计中尤为重要。其思想更多的继承了面向对象的思想&#xff0c;是对其在分布式的框架下的拓展与强化&#xff0c;更加适合现代企业的分工合作&#xff0c;以及版本的更新迭代。 在讲解我对与领域驱动设计的思考时…...

    2024/4/13 21:23:13
  6. python 用 zipfile 库解压压缩包时遇到的 bug

    代码如下&#xff1a; import zipfilezip_file zipfile.ZipFile("demo.zip") zip_file.extractall(pwd"123".encode())错误栈&#xff1a; Traceback (most recent call last):File "C:/Users/th1nker/PycharmProjects/douban-robot/zip-test/test…...

    2024/4/15 15:03:21
  7. Koltin44,零基础学习android开发

    val (_, _, goodsId1, count1) infos[i] if (goodsId1 goodsId) { count count1 break } } return count } /** 根据类别查找 */ fun queryCacheSelectedInfoByTypeId(typeId: Int): Int { var count 0 for (i in 0…infos.size - 1) { val (_, typeId1, _, …...

    2024/4/13 21:23:13
  8. mac 提交代码 git 提交换行符问题

    更改 autocrlf false safecrlf false...

    2024/4/13 21:23:33
  9. 方舟编译器的构建(笔记)

    幕布&#xff1a; 文档链接: https://www.mubucm.com/doc/1z3htgqATZ6 密码: eueu 文章目录1. 方舟编译器构建体系&#xff08;逐层向下&#xff09;1. 构建流程 &#xff1a;2. 构建工具介绍&#xff1a;1. Makefile2. gn3. Ninja1. Ninja的特点&#xff1a;2. 方舟编译器源码…...

    2024/4/13 21:23:13
  10. git下载与安装

    git下载地址 点击转到git官网 git安装...

    2024/4/19 9:24:53
  11. SpringBoot篇—整合Mybatis以及使用druid数据源

    整合步骤 导入mybatis官方starter编写mapper接口&#xff08;标注Mapper注解&#xff09;编写sql映射文件并且绑定mapper接口在application.yml文件中指定Mapper配置文件的位置&#xff0c;以及指定全局配置文件的信息&#xff08;建议&#xff1a;将要配置在该文件中的内容写在…...

    2024/4/13 21:23:13
  12. ffmpeg----avfifo.h

    1、结构体 typedef struct AVFifoBuffer {uint8_t *buffer;uint8_t *rptr, *wptr, *end;uint32_t rndx, wndx; } AVFifoBuffer; 2、申请fifo /* *分配单个size大小的fifo&#xff0c;其内部调用av_fifo_alloc_array(size, 1)&#xff0c;失败返回NULL */ AVFifoBuffer *av_f…...

    2024/4/5 3:30:46
  13. 数学考试 思维+前缀和

    数学考试 题目链接&#xff1a;数学考试 题目大意&#xff1a;给定长为n的数组和k&#xff0c;从数组中任意选择不相交的长度为k的两段&#xff0c;求其和的最大值。 解题思路&#xff1a;预处理出从[k1,n]区间内的值最大的长度为k的子串的值&#xff0c;再顺序遍历数组将以当…...

    2024/4/13 21:23:03
  14. CPUGPU

    常用函数 #设置设备 devicetorch.device(cuda:0 if torch.cuda.is_available() else cpu)#判断是否有cuda可用 if_cudatorch.cuda.is_available()#统计gpu个数 gpu_counttorch.cuda.device_count()#将模型设置为多个gpu并行模式 modeltorch.nn.DataParallel(net) optimoptim.SG…...

    2024/4/5 3:30:44
  15. shoppe项目12----订单系统续

    目录订单提交&#xff08;普通版&#xff09;订单提价&#xff08;事务版&#xff09;订单提交&#xff08;普通版&#xff09; 订单提价&#xff08;事务版&#xff09;...

    2024/4/13 21:23:23
  16. shoppe项目11----订单系统

    目录订单提交流程前端分析订单模型类后端流程订单提交流程 前端分析 订单模型类 后端流程...

    2024/4/16 1:20:27
  17. 力扣第十四天

    文章目录session Ⅰ Algorithmproblem Ⅰmy solution 1problem Ⅱmy solution ⅠTime Limit Exceededmy solution Ⅱ Top down DPmy solution Ⅲ Bottom up DPproblem Ⅲmy solution Ⅰ with DP-arraymy solution Ⅱwithout DP-arrayproblem Ⅳmy solution Bottom up DPsession…...

    2024/4/20 1:32:25
  18. 884. 两句话中的不常见单词

    文章目录模拟法&#xff1a;双HashMap两个字符串合并成一个&#xff0c;找只出现过一次句子 是一串由空格分隔的单词。每个 单词 仅由小写字母组成。 如果某个单词在其中一个句子中恰好出现一次&#xff0c;在另一个句子中却 没有出现 &#xff0c;那么这个单词就是 不常见的 …...

    2024/4/13 21:23:08
  19. PyTorch | Autograd

    一、requires_grad requires_grad是tensor类的一个属性&#xff0c;默认是false。可以在初始化时用requires_grad参数来确定&#xff0c;也可以通过tensor.requires_grad_(bool)函数来改变既有tensor是否需要自动求导。 xtorch.ones(3,2) print(x.requires_grad) ytorch.ones…...

    2024/4/13 21:23:03
  20. vue获得当路由

    当前页面 获得完整url window.location.href 获得路由 this.$route.path 路由路径参数 this.$route.params...

    2024/4/19 23:24:43

最新文章

  1. 【SQL代理中转注入】对DVWA登录界面username字段实施注入

    一、实验过程 步骤0&#xff1a;注释掉相关username防护&#xff0c;截图如下&#xff1a; 以DVWA为攻击目标&#xff0c;将login.php中第21、22行注释掉 步骤1&#xff1a;源码分析&#xff0c;截图如下&#xff1a; 如此可知&#xff0c;首先需要通过token验证&#xff0c;然…...

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

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

    2024/3/20 10:50:27
  3. Docker Desktop+WSL2安装到自定义路径

    现在大多数软件实在太“流氓”了&#xff0c;在安装过程中&#xff0c;根本不让你选择安装路径&#xff0c;默认安装到$HOME下&#xff08;windows C盘&#xff09;&#xff0c;随着软件的使用增多&#xff0c;可能磁盘空间不够&#xff0c;这个时候就想着&#xff0c;看看某些…...

    2024/4/24 13:10:08
  4. 谷粒商城实战(008 缓存)

    Java项目《谷粒商城》架构师级Java项目实战&#xff0c;对标阿里P6-P7&#xff0c;全网最强 总时长 104:45:00 共408P 此文章包含第151p-第p157的内容 简介 数据库承担落盘&#xff08;持久化&#xff09;工作 拿map做缓存 这种是本地缓存&#xff0c;会有一些问题 分布…...

    2024/4/23 6:23:00
  5. 【外汇早评】美通胀数据走低,美元调整

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

    2024/4/23 20:58:27
  6. 【原油贵金属周评】原油多头拥挤,价格调整

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

    2024/4/23 13:30:22
  7. 【外汇周评】靓丽非农不及疲软通胀影响

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

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

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

    2024/4/24 18:16:28
  9. 【外汇早评】日本央行会议纪要不改日元强势

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

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

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

    2024/4/19 11:57:53
  11. 【外汇早评】美欲与伊朗重谈协议

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

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

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

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

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

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

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

    2024/4/23 22:01:21
  15. 【外汇早评】美伊僵持,风险情绪继续升温

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

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

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

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

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

    2024/4/25 4:19:21
  18. 氧生福地 玩美北湖(中)——永春梯田里的美与鲜

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

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

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

    2024/4/19 11:59:44
  20. 扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!

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

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

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

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

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

    2024/4/23 13:28:14
  23. 广州械字号面膜生产厂家OEM/ODM4项须知!

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

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

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

    2024/4/23 13:27:19
  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