C++ traits与模板递归

  • C++中的traits技巧
    • 获取迭代器所指对象类型的方法
    • STL中的iterator_traits
    • type traits
      • STL性能: 通过判断选择更高效的算法
        • POD类型
      • C++标准库中丰富的type traits
      • 闭包之binder1st实现
  • 模板迭代与递归
      • 递归模板模式(CRTP)
        • 编译期多态
        • 编译期递归计算
      • 变长模板的迭代与递归
        • 可变参数hash函数

C++中的traits技巧

	traits,又被叫做特性萃取技术,用于提取“被传进的对象”对应的信息,让同一个接口实现对应的功能。在STL中,算法和容器是分离的,两者通过迭代器链接。算法需要知道所处理对象的一些信息,萃取器相当于在接口和实现之间加一层封装,来隐藏一些细节并协助调用合适的方法。 如何获取迭代器所指对象的信息,如类型。

获取迭代器所指对象类型的方法

1)函数模板的参数推导机制
template <class I, class T>
void func_impl(I iter, T t) {T tmp; // 迭代器所指物的类型新建的对象...
}template <class I>
inline
void func(I iter) {func_impl(iter, *iter); 
}
	通过func_impl的封装,利用函数模板推导,在func_impl中得到了迭代器所指对象同类型的对象。缺陷:如果需要获取迭代器指向对象除value_type外的其他信息,如difference_type、pointer、reference、iterator_category等。这种方法便不一定适用。并且这种推导的只是参数,无法推导函数的返回值类型。2)函数模板推导 + typedef声明内嵌型别
template <class T>
struct MyIter {typedef T value_type;T * ptr;MyIter(T * p = 0) : ptr (p) {};T& operator* () const { return *ptr;}
};template <class I>
typename I::value_type 
get (I ite) {return *ite;
}MyIter<int> iter( new int(10) );
auto ret = get( iter );
	这种方法不支持原生指针。如,为get传入一个原生指针int*时,I::value_type无法得到int,因为原生指针中无法typedef它的value_type。这时可以利用模板的偏特化特性。3)函数模板推导 + typedef声明内嵌型别 + 函数模板偏特化
template <class I>
typename I::value_type
get (I ite) {...
}template <class I>
I get(I* ite) {...
}template <class I>
I get(const I* ite) {...
}
	利用get函数模板偏特化,对指针和const指针版本做特化。这种方法可行却不够优雅。此时的解决方法可以是引入一个类模板中间层,iterator_traits,不改变get的形式,而将偏特化和typedef声明放于类模板中完成。

STL中的iterator_traits

	iterator模式便提供了这样一种方法:使之能够依序寻访某个聚合物所含的各个元素,而又无需暴露该聚合物的内部表达形式。c++中各个容器的iterator扮演着将数据容器与算法结合起来的重要角色。给算法提供一个访问容器元素的工具,即iterator,将范型算法用于某个容器。使用traits技法,一方面解决了统一了原生指针和自定义iterator被算法使用时的差异,t提供一个统一而简洁的接口,另一方面为为算法提供了关于元素的更丰富的信息,使算法可以选择更高效的实现方式。
#include <iostream>template <class T>
struct iterator_traits {typedef typename T::value_type value_type;
};template <class T>
struct iterator_traits<T*> {typedef T value_type;
};template <class T>
struct iterator_traits<const T*> {typedef T value_type;
};template <class I>
typename iterator_traits<I>::value_type
get (I ite) {...
}
	STL中的iterator_traits定义了以下几种型别:
template<class _Tp>
struct iterator_traits<_Tp*>
{typedef ptrdiff_t difference_type;typedef typename _Tp::value_type value_type;typedef typename _Tp::pointer pointer;typedef typename _Tp::reference reference;typedef typename _Tp::iterator_category iterator_category;
};

type traits

	type_traits是C++11提供的模板元基础库。type_traits可实现在编译期计算、判断、转换、查询等等功能。type_traits提供了编译期的true和false。

STL性能: 通过判断选择更高效的算法

		对于vector这种大块分配内存,然后大块析构的容器,如果容器里面是POD的话,那么只要等它的生命周期结束就行了,如果是非POD的话,那么就要判断是否拥有non trivial的析构函数。这个判断便需要依靠type_traits的偏特化特性进行判断,选择相应的行为(函数):

POD类型

C++11 POD类型


#include <iostream>namespace my_type_trait{/** 2两个空白类,没有任何成员,不会带来额外负担,却能通过类型代表真假,可以用于函数特化参数 */struct __true_type { };struct __false_type { };template <class _Tp>struct __type_traits {typedef __true_type this_dummy_member_must_be_first;// 不要移除这个成员 // 它通知能自动特化__type_traits的编译器, 现在这个__type_traits template是特化的 // 这是为了确保万一编译器使用了__type_traits而与此处无任何关联的模板时 // 一切也能顺利运作 typedef _false_type has_trivial_default_constructor;//默认构造函数是否有意义?  typedef _false_type has_trivial_copy_constructor;//拷贝构造函数是否有意义?  typedef _false_type has_trivial_assgignment_constructor;//拷贝赋值操作是否有意义?  typedef _false_type has_trivial_destructor;//析构函数是否有意义?  typedef _false_type is_POD_type;//是否为Plain Old Data?  };
}
	对__type_traits类模板,class A可以偏特化出__type_traits<A>,并对has_trivial_destructor进行重新的typedef,改变has_trivial_destructor为_false_type类型或者__true_type类型。对于一个算法模板函数,接收一个__true_type或者__false_type类型的参数,重载出针对_false_type类型和__true_type类型的不同版本。于是,对算法传入class A类型的对象时,便可以根据__type_traits<A>::has_trivial_destructor的类型,选择到相应版本的算法函数。
template <class T>
void doSth(T& t, my_type_trait::__true_type) {std::cout << "true" << std::endl;
}template <class T>
void doSth(T& t, my_type_trait::__false_type) {std::cout << "false" << std::endl;
}template <typename T>
void doSth(T& t) {typedef typename my_type_trait::__type_traits<T>::is_POD_type is_POD_type; doSth(t, is_POD_type());
} class A {
public:
};class B {
};namespace my_type_trait{template <>struct __type_traits<A> {typedef __true_type is_POD_type;};template <>struct __type_traits<B> {typedef __false_type is_POD_type;};
}int main(void) {A a;B b;doSth(a);   // truedoSth(b);   // falsereturn 0;
} 

C++标准库中丰富的type traits

Standard library header <type_traits>

#include <iostream>
#include <type_traits>
using namespace std;int main()
{// 判断int和const int类型std::cout << "int: " << std::is_const<int>::value << std::endl;std::cout << "const int:" << std::is_const<const int>::value << std::endl;// 判断类型是否相同std::cout << std::is_same<int, int>::value << "\n";std::cout << std::is_same<int, unsigned int>::value << "\n";// 添加/移除conststd::cout << std::is_same<const int, add_const<int>::type>::value << std::endl;std::cout << std::is_same<int, remove_const<const int>::type>::value << std::endl;// 添加引用std::cout << std::is_same<int&, add_lvalue_reference<int>::type>::value << std::endl;std::cout << std::is_same<int&&, add_rvalue_reference<int>::type>::value << std::endl;// 取公共类型typedef std::common_type<unsigned char, short, int>::type NumericType;std::cout << std::is_same<int, NumericType>::value << std::endl;// 对于普通类型移除引用、const和volatiletypedef std::decay<int>::type Normal;    // inttypedef std::decay<int&>::type Ref;    // inttypedef std::decay<int&&>::type RefRef;    // inttypedef std::decay<const int&>::type const;    // inttypedef std::decay<int[2]>::type Array;    // int*typedef std::decay<int(int)>::type FunPtr;    // int(*)(int) 函数指针typedef int(&fn_ref)(int);typedef int(*fn_ptr)(int);// 用来获取可调用对象的返回类型typedef std::result_of<fn_ref(int)>::type int_f;    // inttypedef std::reuslt_of<fn_ptr(int)>::type int_s;    // intreturn 0;
}

闭包之binder1st实现

提取并保存一个类型的信息叫做type traits,提取并保存一个函数参数或返回值同理可叫做参数traits或者返回值traits。利用traits手法,可以轻易实现一个仿函数类,binder1st,用于绑定一个仿函数的第一个参数,形成闭包。虽然C++11中对闭包有更好的编译层面的支持——lambda表达式,也不妨碍对简单的binder1st的学习,加深对traits技法的理解。

binder1st的使用:template<class _Arg1,class _Arg2,class _Result>struct binary_function{	// base class for binary functionstypedef _Arg1 first_argument_type;typedef _Arg2 second_argument_type;typedef _Result result_type;};#include <iostream>
#include <functional>template<typename T>
class MLess : public std::binary_function<T, T, bool>
{
public:bool operator() (const T& a, const T& b) const{return a < b;}
};int main(int argc, char** argv)
{auto lessObj = std::bind1st(MLess<int>(), 5);std::cout << lessObj(6) << std::endl;system("pause");return 0;
}binder1st的实现:template<class _Fn2>class binder1st: public unary_function<typename _Fn2::second_argument_type,typename _Fn2::result_type>{	// functor adapter _Func(stored, right)
public:typedef unary_function<typename _Fn2::second_argument_type,typename _Fn2::result_type> _Base;typedef typename _Base::argument_type argument_type;typedef typename _Base::result_type result_type;binder1st(const _Fn2& _Func,const typename _Fn2::first_argument_type& _Left): op(_Func), value(_Left){	// construct from functor and left operand}result_type operator()(const argument_type& _Right) const{	// apply functor to operandsreturn (op(value, _Right));}result_type operator()(argument_type& _Right) const{	// apply functor to operandsreturn (op(value, _Right));}protected:_Fn2 op;	// the functor to applytypename _Fn2::first_argument_type value;	// the left operand};// TEMPLATE FUNCTION bind1st
template<class _Fn2,class _Ty> inlinebinder1st<_Fn2> bind1st(const _Fn2& _Func, const _Ty& _Left){	// return a binder1st functor adaptertypename _Fn2::first_argument_type _Val(_Left);return (binder1st<_Fn2>(_Func, _Val));}

模板迭代与递归

递归模板模式(CRTP)

编译期多态

	使用派生类作为模板参数特化基类:使用派生类覆盖基类成员函数实现静态绑定,可实现编译时多态。使用父类调用直接子类函数,实现多态:1)静态函数成员多态:在父类模板的静态方法中使用模板参数(即子类)的同名静态方法;2)非静态函数成员:通过this指针进行静态转换,在父类模板方法中调用子类同名方法。
#include<iostream>
#include<stddef.h>
using namespace std;
template<class Derived>
struct Base  
{  void Interface()  {  cout <<"come from Interface"<<endl;      // 转换为子类指针,编译期将绑定至子类方法  static_cast<Derived*>(this)->Implementation(); }  static void StaticInterface()  {  // 编译期将绑定至子类方法  cout <<"come from StaticInterface"<<endl;Derived::StaticImplementation();  }  void Implementation(){cout <<"Base Implementation"<<endl;return;}static void StaticImplementation(){cout << "Base StaticImplementation"<<endl;return;}
};  // The Curiously Recurring Template Pattern (CRTP)  
struct Derived1 : Base<Derived1>  
{  static void StaticImplementation();  
};  struct Derived2 : Base<Derived2>  
{  void Implementation();  
};  

编译期递归计算

	利用模板递归的特性,模板特例化为递归终止条件,在编译期计算出递归结果。优点:1)编译时就把数据计算出来了,对于运行时的大数据递归计算效率大大提高了缺点:1)编译时间的损失2)代码可读性有些损失3)调试困难4)不能计算变量的值,也就是对于运行时确定的数据是不能通过模板递归出来的5)不能进行异常处理,也就是模板参数传入一个错误的数字后可能导致崩溃
计算斐波那契数列:template< int n >
struct Factorial{const static int value = Factorial< n-1 >::value * n;
};template<>
struct Factorial< 0 >{const static int value = 1;
};计算幂:template< int m, int n >
struct POWER{static const size_t data=POWER< m,  n-1 >::data * m;
};template< int m >
struct POWER< m, 0 >{static const size_t data = 1;
};计算阶乘:template < unsigned int N >
struct FactR{ enum { Val = N * FactR::Val }; 
};template <> 
struct FactR < 1 >
{enum {Val = 1};

变长模板的迭代与递归

	通过变长模板,对传入的个数变化的模板参数依次解包,实例化出不同参数的模板对参数进行处理,应对不定数量的参数的情况。
#include <iostream>
#include <vector>
#include <functional>
using namespace std;template<class... Args>
void fun (Args... args) {function<bool (int)> check = [] (int t) {if (t == 3) {cout << "find 3" << endl;} else {cout << t << " is not 3" << endl;}return t != 3;};vector<function<bool ()>> fun = { bind (check, args)... };for (auto f : fun) {if (!f ()) break;}
}int main (int argc, char* argv []) {fun (1,2,5,7,9,3,5,6);return 0;
}
	以上程序对输入的任意长度的参数,按照顺序寻找数值等于3的数。对输入的n个参数,为每个参数实例化出一个仿函数,存储在vector中,依次调用,寻找数值3。

可变参数hash函数

//计算种子数值
template<typename T>
inline void hash_combine(size_t& seed, const T& val)
{seed ^= std::hash<T>()(val) + 0x9e3779b9 + (seed << 6) + (seed >> 2);
}//递归调用出口
template<typename T>
inline void hash_val(size_t& seed, const T& val)
{hash_combine(seed, val);
}template<typename T, typename... Types>
inline void hash_val(size_t& seed, const T& val, const Types&... args)
{//重新计算种子值hash_combine(seed, val);//递归调用hash_val(seed, args...);
}template<typename... Types>
inline size_t hash_val(const Types&... args)
{size_t seed = 0;hash_val(seed, args...);return seed;
}
查看全文
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

相关文章

  1. 应急响应模型

    应急响应阶段 预备->识别->遏制->消除->恢复->反思 各阶段内容 预备:监控、加固、制定流程、检验 识别:识别攻击者操作、识别恶意主机流量、识别业务变化…… 遏制:短平快控制风险,准备长期响应:封禁 消除:删除恶意软件、重置系统、重置服务 恢复:IR提供…...

    2024/4/17 12:58:11
  2. Linux线程私有数据

    Linux线程私有数据__thread关键字线程特定数据TSD进程中的key结构数组线程中的pthread结构数组申请TSD的原理流程TSD的RAII技法封装单线程C程序有两类基本数据:局部数据和全局数据。对于多线程C程序,添加了第三类数据:线程私有数据。线程私有数据与全局数据非常相似,区别在…...

    2024/4/19 8:24:59
  3. Leetcode 5428.重新排列数组(Shuffle the Array)

    Leetcode 5428.重新排列数组 1 题目描述(Leetcode题目链接)给你一个数组 nums ,数组中有 2n 个元素,按 [x1,x2,…,xn,y1,y2,…,yn] 的格式排列。 请你将数组按 [x1,y1,x2,y2,…,xn,yn] 格式重新排列,返回重排后的数组。 输入:nums = [2,5,1,3,4,7], n = 3 输出:[2,3,5,4…...

    2024/4/15 4:53:42
  4. gitlab建立分支,并上传新项目

    创建一个空分支,上传一个新的项目工程 实测可用 思路 建立分支,git里切换到目标分支,将原有项目删除,粘贴新项目,上传分支。 1.建立分支 在仓库里建立分支,起个名字。 也可以在终端建立分支,由于本人并没有尝试过终端建立分支就不写了。2.clone项目 在终端输入:git clo…...

    2024/4/20 14:19:20
  5. P4071 排列计数 解题报告(错排问题、组合数、逆元打表)

    题目链接:https://www.luogu.com.cn/problem/P4071 先是组合数部分,比较容易想到从n个中挑出m个对位的,剩下的我们都要让他们不对位。这时候,我们就想到了错排问题。 错排问题的定义是:考虑一个有n个元素的排列,若一个排列中的所有元素都不在他们原来的位置上,那么这种情…...

    2024/4/19 15:11:19
  6. 分析技术指标的背离特征有哪些问题要注意?

    我们都知道,投资者在判断市场趋势时,不仅要结合当前基本面,还要利用技术指标对价格走向进行技术分析,寻找适宜的进出场时机。在这过程中,投资者发现多种技术指标都会出现背离的情况。那么,在分析技术指标的背离特征时,投资者有哪些问题要注意呢?详情如下所述。 首先,各…...

    2024/4/15 4:53:38
  7. 【环境搭建】onnxruntime

    1,下载 sudo apt-get update sudo apt-get install make cmake git clone https://github.com/microsoft/onnxruntime.git cd onnxruntime bash ./build.sh --skip_tests --use_cuda --config RelWithDebInfo --build_shared_lib --parallel --cuda_home=/usr/local/cuda-10…...

    2024/4/24 11:52:37
  8. Status code :200 OK (from disk cache)

    直接上图在写前端访问后端接口时候发现,可以访问,但是没有数据,显示请求代码code 为来自磁盘,所以我们需要清理一下磁盘。 ![在这里插入图片描述](https://img-blog.csdnimg.cn/20200608182523345.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,…...

    2024/4/24 11:52:36
  9. 义乌个体户结滙政策

    一、注册义乌个体工商户所需资料: 1)有效身fen份证扫描件,或者手机拍照正反面 2)个体户的经营范围:工艺品/服装/办公用品/饰品/玩具/日用百货/机械配件/电子产品/汽车配件/灯具,可任选三个,经营范围不影响结滙。 3)个体户名称:由工商局预先核准通知书,随机核名取名,…...

    2024/4/24 11:52:34
  10. 地址空间与内存分配

    地址空间与内存分配内存地址Linux内存模型brk与sbrkmalloc分配前初始化内存块的结构获取内存块内存对齐从空闲block获取拓展新blockfree碎片处理合法性检查释放内存空间STL内存管理gnu中的八种内存分配器__gnu_cxx::new_allocator__gnu_cxx::__pool_alloc__gnu_cxx::__mt_alloc…...

    2024/5/8 11:29:06
  11. jQuery动态生成页面元素.append,.html,html元素变成字符串

    我在想在第二个div元素中添加一个返回按钮,却变成了一个字符串 $(".c-container")[2].append("<a>返回</a>")改进后代码 $(".c-container").eq(2).append("<a>返回</a>")...

    2024/4/24 11:52:34
  12. DuplicateKeyException

    这里写自定义目录标题Error updating database. Cause: com.mysql.jdbc.exceptions.jdbc4.MySQLIntegrityConstraintViolationException: Duplicate entry 13890739042 for key inside_user_tel重复键异常: “inside_user_tel”的重复条目“13890739042” #org.springframe…...

    2024/4/24 11:52:30
  13. 第四章 Schema与数据类型优化

    良好的逻辑设计和物理设计是高性能的基石,应该根据系统将要执行的查询语句来设计 schema,这往往需要权衡各种因素。 例如,反范式的设计可以加快某些类型的查询,但同 时可能使另一些类型的査询变慢。 比如添加计数表和汇总表是一种很好的优化査询的方式, 但这些表的维护成本…...

    2024/4/24 11:52:29
  14. react笔记(二)

    常用语法基础 列表渲染 类似vue中的v-for,react中也有类似的列表渲染方法。首先我们知道,在jsx中标签即是变量,因此我们可以创建一个标签数组。可以借助map等函数,实现值到标签的映射。 giftMsg=["123","345","567"]; const giftMsgs = gift…...

    2024/4/24 11:52:31
  15. 检测服务器开放端口

    1.使用nmap检测开放端口,可检测远程服务器[root@localhost ~]# nmap localhostStarting Nmap 6.40 ( http://nmap.org ) at 2020-06-09 01:40 CST Nmap scan report for localhost (127.0.0.1) Host is up (0.000023s latency). Other addresses for localhost (not scanned):…...

    2024/4/24 11:52:28
  16. 一篇文章理解线性代数中的标量、向量、矩阵和张量

    经过之前的一些积累,终于有勇气开始进军机器学习了!说实话,机器学习 这个概念是我入行的最纯粹的原因,包括大学选专业、学习 Python 语言…这些有时间仔细梳理下经历再写,总之这个系列的文章就是我自学 机器学习 的笔记,各位看看就好,希望能为一些想入门但无从下手的小伙…...

    2024/4/24 11:52:26
  17. SpringBoot(1.1.12)旧版本 + jdk 1.6

    因客户需求需要在jdk6上搭建springboot项目 支持1.6的SpringBoot项目的版本需要早于1.2,我这次选用的是 旧版本链接传送门 接下来创建项目于是尝试创建一个maven 项目创建好之后引入pom 如下 <?xml version="1.0" encoding="UTF-8"?> <project…...

    2024/4/24 11:52:28
  18. Python之数据库操作

    Python 标准数据库接口为 Python DB-API,Python DB-API为开发人员提供了数据库应用编程接口。 Python DB-API使用流程: 引入 API 模块 获取与数据库的连接 执行SQL语句和存储过程 关闭数据库连接 文章目录MySQLdb创建数据库及表创建数据库:创建数据库表:修改数据库…...

    2024/4/24 11:52:24
  19. 红黑树的理解

    红黑树的理解原文链接...

    2024/4/15 4:53:54
  20. LeetCode 105. 从前序与中序遍历序列构造二叉树(各种遍历二叉树的性质,递归建树)

    这道题算是二叉树里面的基础题、经典问题了。 解决这道题,需要知道二叉树的递归定义。二叉树的前序遍历、中序遍历的性质,并用这个性质建树。 注:必须要有中序遍历。 编号的数字不能重复。/*** Definition for a binary tree node.* struct TreeNode {* int val;* T…...

    2024/4/15 4:53:54

最新文章

  1. 探索大语言模型在信息提取中的应用与前景

    随着人工智能技术的快速发展&#xff0c;大语言模型&#xff08;LLMs&#xff09;在自然语言处理&#xff08;NLP&#xff09;领域取得了显著的进展。特别是在信息提取&#xff08;IE&#xff09;任务中&#xff0c;LLMs展现出了前所未有的潜力和优势。信息提取是从非结构化文本…...

    2024/5/8 11:46:05
  2. 梯度消失和梯度爆炸的一些处理方法

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

    2024/5/7 10:36:02
  3. ROS2高效学习第十章 -- ros2 高级组件之大型项目中的 launch 其二

    ros2 高级组件之大型项目中的 launch 1 前言和资料2 正文2.1 启动 turtlesim&#xff0c;生成一个 turtle &#xff0c;设置背景色2.2 使用 event handler 重写上节的样例2.3 turtle_tf_mimic_rviz_launch 样例 3 总结 1 前言和资料 早在ROS2高效学习第四章 – ros2 topic 编程…...

    2024/5/7 4:57:36
  4. Docker Desktop+WSL2安装到自定义路径

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

    2024/5/8 5:04:44
  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