当前位置: 首页 > news >正文

做国外订单用哪个网站semen是什么意思

做国外订单用哪个网站,semen是什么意思,公司建设网站公司,建设网站主要有哪些技术C模板函数 函数模板简单的函数模板模板类型推导返回输入的类型,模板返回的类型由输入的决定返回类型的模板参数返回值使用auto,编译器自动推导 默认模板实参模板参数重载函数模板 constexpr关键字 函数模板 简单的函数模板 typename 可以使用class代替…

C++模板函数

  • 函数模板
    • 简单的函数模板
    • 模板类型推导
      • 返回输入的类型,模板返回的类型由输入的决定
      • 返回类型的模板参数
      • 返回值使用auto,编译器自动推导
    • 默认模板实参
    • 模板参数
    • 重载函数模板
  • constexpr关键字

函数模板

简单的函数模板

typename 可以使用class代替,但是不可以是使用struct代替。
template <typename T>
T mmax(T a, T b)
{return b < a ? a : b;
}

模板类型推导

返回输入的类型,模板返回的类型由输入的决定


template <typename T>
T mmax(T a, T b)
{return b < a ? a : b;
}

T是由输入的参数类型推导出来的,输入int T就是int型的。

如果a 和 b一个是int一个是double就需要定义两个typename。

template <typename T1, typename T2>
T1 mmax(T1 a, T2 b)
{return b < a ? a : b;
}

返回类型的模板参数

当模板参数和调用参数之间没有关联的时候,且模板参数不确定的时候,必须在调用时显式指定模板实参。

添加三个模板类型,调用的时候必须指定模板的返回类型
template <typename TR, typename T1, typename T2>
TR mmax(T1 a, T2 b)
{return b < a ? a : b;
}std::cout << mmax<int>(10.3,6)<< endl;

返回值使用auto,编译器自动推导

从C++14开始,可以通过不声明任何返回类型来实现。

template <typename T1, typename T2>
auto mmax(T1 a, T2 b) -> typename std::decay<decltype(b < a ? a : b)>::type
{return b < a ? a : b;
}

这里使用了类型特征 std::decay<>,其返回结果类型为成员typestd::decay<>在标准库<type_traits> 中定义。由于其成员type是一个类型,因此必须用typename修饰这个表达式才能访问它。

从C++11,C++标准库提供了一种指定选择“更一般的类型”的方法。std::common_type<>::type 萃取作为模板实参传递的两个或多个不同类型的“公共类型”。

C++11写法
template <typename T1, typename T2>
typename std::common_type<T1, T2>::type mmax(T1 a, T2 b)
{return b < a ? a : b;
}
C++ 14 写法
template <typename T1, typename T2>
std::common_type_t<T1, T2> mmax(T1 a, T2 b)
{return b < a ? a : b;
}

std::common_type<> 也是在标准库<type_traits> 中。
它可以萃取一个具有作为结果类型的type 成员的结构体。
其核心用法:

typename std::common_type<T1, T2>::type

从C++14 开始,可以通过在特征名称后面附加_t 并省略typename::type

std::common_type_t<T1, T2>

在内部它根据运算符?:的语法规则或具体的类型的特化来选择类型。

默认模板实参

使用三目运算符?: 不过必须在a和b参数调用之前使用。

template <typename T1, typename T2, typename TR = std::decay_t<decltype(true ? T1() : T2())>>
TR mmax(T1 a, T2 b)
{return b < a ? a : b;
}

使用std::common_type<> 类型特征来指定返回类型的默认值:

template <typename T1, typename T2, typename TR = std::common_type_t<T1, T2>>
TR mmax(T1 a, T2 b)
{return b < a ? a : b;
}

需要注意的是,std::common_type<> 会进行退化,因此返回类型不可能变成引用类型。

模板参数

template<typename T, int N>
void Print(T a)
{std::vector<T> num;for(int i = 0; i < N; ++i){num.push_back(i + a);}for(auto& value : num){std::cout << static_cast<T>(value) << std::endl;}
}

重载函数模板

int mmax(int a, int b)
{return b < a? a : b;
}template<typename T>
T mmax(T a, T b)
{return b < a? a : b;
}std::cout << mmax(10.3,6.1)<< endl; //使用的模板函数

一个模板函数可以和一个普通函数同名且可以用相同类型实例化的函数模板共存。在所有其他因素都相同的情况下,重载解析过程优先选择非模板函数。

std::cout << mmax('a', 6) << endl;

由于模板参数推导不允许自动类型转换,而普通函数可以,因此此函数使用的是非模板函数。

template <typename T1, typename T2>
auto mmax(T1 a, T1 b)
{return b < a ? a : b;
}template <typename TR, typename T1, typename T2>
TR mmax(T1 a, T1 b)
{return b < a ? a : b;
}

auto a = mmax<double, int>(10.3, 6);使用第一个模板
auto b = mmax<long, double>(10.3, 6); 使用第二个模板
auto c = mmax<int>(10.3, 6); 错误: 两个模板都能匹配

两个模板都能匹配通常会造成重载解析过程中无从选择,并产生歧义。因此在重载函数模板时,应该确保对于任何调用,其中只有一个与之匹配。

constexpr关键字

从C++11开始,可以使用关键字constexpr来启用在编译器使用代码计算某些数值的功能。

constexpr int Sum(int a, int b)
{return a + b;
}
int Iarray[Sum(10,3)];

使用这个关键字修饰函数就可以自定义数组大小,如果不用这个关键字修饰代码编译会出错的。

http://www.ds6.com.cn/news/21297.html

相关文章:

  • 宝鸡小外贸网站建设电商怎么做
  • 做网站还有钱赚吗西安百度推广电话
  • dw企业网站设计网络营销都具有哪些功能
  • 网站文章分类微信seo是什么意思
  • 淘宝联盟 网站建设 内容少恶意点击软件
  • 宁波市住房和城乡建设厅网站百度图片搜索引擎入口
  • 做化工哪个网站好商城网站建设
  • 自己做网站做外贸可以吗排名优化网站建设
  • 广州市政府门户网站的网址是百度教育网站
  • wordpress修改默认头像英文网站seo发展前景
  • wordpress msnseo项目培训
  • 女装市场网站建设费用评估网站设计论文
  • 重庆建设工程造价协会seo网站优化流程
  • 专业北京网站建设全国防疫大数据平台
  • 链接缩短网址深圳网站优化
  • 帝国做网站的步骤软文写作的三个要素
  • 一加手机官网网站网络推广员岗位职责
  • 网站如何设定关键词百度推广如何办理
  • 做图素材网站seo整站优化什么价格
  • 微商城网站建设流程方案互联网推广好做吗
  • 推荐一个做照片书的网站磁力链最好用的搜索引擎
  • wordpress变数据库seo网站推广
  • 做磁力网站少儿编程
  • 拐角型布局网站seo外包公司怎么样
  • 可以做超链接或锚文本的网站有哪些seo查询是什么意思
  • 国内用什么做网站今日热搜榜排行榜
  • 做旅游网站需要引进哪些技术人才广州搜索排名优化
  • 做门户网站的好处中文域名的网站
  • 用vs做网站后台开发可以吗营销和销售的区别
  • 学编程可以建设网站吗百度经验手机版