1、引用内部函数绑定机制
#include<iostream>
#include<functional>u s ingnamespac est d;usingnamespacestd: :placeholders;
//仿函数创建一个函数指针 引用一个结构体内部或者一个类内部的共有函数structMyStruct
{voidadd(inta)
{cout<<a<<endl ;
}voidadd2(inta, intb)
{cout<<a + b<<endl;
}voidadd3(inta, intb, intc)
{cout<<a + b + c<<endl;
}
} ;voidmain()
{
MyStructstruct1;
//auto自动变量地址 函数指针 bind绑定
//第一个参数引用内部函数绑定一个实体对象
//这里后面的_1等为占位用autofunc = bind(&MyStruct: :add, &struct1, _1) ;autofunc2 = b ind(&MyStruct: :add2, &struct1, _1, _2) ;autofunc3 = b ind(&MyStruct: :add3, &struct1, _1, _2, _3) ;f unc(100) ;f unc 2(10, 20) ;f unc 3(10, 20, 30) ;cin. get() ;
}voidmain1()
{
//如果想通过另外一种方式获得结构体中的函数还可以通过下面的方式
MyStructstruct1;
//创建函数指针类结构体数据私有代码共享
//函数通过调用调用需要传递对象名进行区分void(MyStruct: :*p) (inta) =&MyStruct: :add;cin. get() ;
}
补充Cocos2dx中关于std: :function和bind的用法案例
2.通过R”()”的方式实现转义字符
#include<iostream>
#include<string>
#include<stdlib.h>voidmain()
{std: :stringpath = R"( "C:\Program Files\Tencent\QQ\QQProtect\Bin\QQProtect. exe")";//通过R"()" 括号之间去掉转义字符system(path.c_str() ) ;system("pause") ;
}
3.引用包装器通过std: :ref(count) 的方式调用。
#include<iostream>template<classT>voidcom(Targ) //模板函数 引用无效 引用包装器
{std: :cout<<"com ="<<&arg<<"\n";arg++;
}voidmain()
{intcount = 10;int&rcount = count;com(count) ;std: :cout<<count<<std: :endl;
//std: :ref(变量) 函数模板,引用包装器
//com(std: :ref(count)) ;c om(rcount) ;std: :cout<<"main="<<&rcount<<"\n";std: :cout<<count<<std: :endl;std: :cin.get() ;
}
使用引用包装器的方式
#include<iostream>template<classT>voidcom(Targ)//模板函数 引用无效引用包装器
{std: :cout<<"com ="<<&arg<<"\n";arg++;
}voidmain()
{intcount = 10;int&rcount = count;com(count) ;std: :cout<<count<<std: :endl;
//std: :ref(变量) 函数模板,引用包装器com(std: :ref(count) ) ;//这种方式代表引用包装器
//com(rcount) ;std: :cout<<"main="<<&rcount<<"\n";std: :cout<<count<<std: :endl;std: :cin.get() ;
}
4.C++别名
#include<iostream>namespacespace{ //隔离模板避免冲突template<classT>usingprt = T*;//模板的简写定义一个模板的指针}intadd(inta, intb)
{returna + b;
}
//typedef是C语言中定义别名的关键字typedef int(*ADD) (inta, intb) ;
//C++中的别名是通过using关键字实现的usingFUNC = int(*) (inta, intb) ;usingco = std: :ios_base: :fmtflags;
voidmain()
{
ADDp = add;std: :cout<<p(1, 2) <<std: :endl;
FUNC func = add;std: :cout<<func(1, 2) <<std: :endl;
//space: :ptr<int>pint(new int(15)) ;
//std: :cout<< *pint << " " << pint <<std: :endl;std: :cin.get() ;
}
5.模板元
#include<iostream>
//主要思想
//
//利用模板特化机制实现编译期条件选择结构利用递归模板实现编译期循环结构模板元程序则由编译器在编译期解释执行。
//
//优劣及适用情况
//
//通过将计算从运行期转移至编译期在结果程序启动之前做尽可能多的工作最终获得速度更快的程序。也就是说模板元编程的优势在于
//
//1.以编译耗时为代价换来卓越的运行期性能一般用于为性能要求严格的数值计算换取更高的性能 。通常来说一个有意义的程序的运行次数或服役时间总是远远超过编译次数或编译时间 。//
//2.提供编译期类型计算通常这才是模板元编程大放异彩的地方。
//
//模板元编程技术并非都是优点
//
//1.代码可读性差 以类模板的方式描述算法也许有点抽象。
//
//2.调试困难元程序执行于编译期没有用于单步跟踪元程序执行的调试器用于设置断点、察看数据等 。程序员可做的只能是等待编译过程失败然后人工破译编译器倾泻到屏幕上的错误信息。//
//3.编译时间长通常带有模板元程序的程序生成的代码尺寸要比普通程序的大
//
//4.可移植性较差对于模板元编程使用的高级模板特性不同的编译器的支持度不同。
//模板元把运行时消耗的时间在编译期间优化template<intN>structdata
{enum {res = data<N - 1>: :res + dat a<N - 2>: :re s } ;} ;
//当为1的情况template<>structdata<1>
{e num {r e s = 1} ;
} ;template<>structdata<2>
{e num { r e s = 1 } ;
} ;intgetdata(intn)
{if (n == 1 | | n == 2)
{return 1;
}else
{returngetdata(n - 1) + getdata(n - 2) ;
}
}voidmain()
{constintmyint = 40;i ntnum = data<my int>: :res;//<>内部不可以有变量std: :cout<<num<<std: :endl ;std: :cout<<getdata(40) <<std: :endl ;std: :cin.get() ;
}
运行结果相同但是后者明显速度要慢于前者。
6.宏
#include<stdio.h>
#include<assert.h>
#include<iostream>u s ingnamespac est d;
#def ineN 10voidmain()
{i ntnum = 100;c out<<num<<endl;
//本文件所在的文件路径cout<<__FILE__<<endl;
//下一行代码在文件中的行位置cout<<__LINE__<<endl;
//日期c out<<__DATE__<<end l;
//日期cout<<__TIME__<<endl;
//当前函数名称cout<< __FUNCTION__ <<endl;cin. get() ;
}
7.断言调试注意static_assert这个是C++11的语法在QT中运行需要加上CONFIG+=C++11
这时候没有输入东西
8.C++中的多线程
#inc lude<thread>
#include<iostream>
#inc lude<windows.h>
#include<vector>u s ingnamespac est d;usingnamespacestd: :thi s_thread;voidmsg()
{
MessageBoxA(0, "12345", "678910",0) ;
}voidmsgA(intnum)
{std: :cout<<get_id() <<" num = "<<num<<std: :endl;
}voidmain()
{
// thread: :hardware_concurrency线程auton = thread: :hardware_concurrency() ;//获得当前cpu核心数我的是4核的std: :cout<<n<<std: :endl;
//获取当前线程编号std: :cout<<"thread = "<<get_id() <<std: :endl;threadthread1 (ms g) ; //创建多线程threadthread2(ms g) ;thread1. join() ;//开始执行
RAKsmart怎么样?RAKsmart发布了2021年中促销,促销时间,7月1日~7月31日!,具体促销优惠整理如下:1)美国西海岸的圣何塞、洛杉矶独立物理服务器低至$30/月(续费不涨价)!2)中国香港大带宽物理机,新品热卖!!!,$269.23 美元/月,3)站群服务器、香港站群、日本站群、美国站群,低至177美元/月,4)美国圣何塞,洛杉矶10G口服务器,不限流量,惊爆价:$999.00,...
易探云服务器怎么样?易探云是国内一家云计算服务商家,致力香港云服务器、美国云服务器、国内外服务器租用及托管等互联网业务,目前主要地区为运作香港BGP、香港CN2、广东、北京、深圳等地区。目前,易探云推出的国内云服务器优惠活动,国内云服务器2核2G5M云服务器低至330元/年起;成都4核8G/200G硬盘/15M带宽,仅1888元/3年起!易探云便宜vps服务器配置推荐:易探云vps云主机,入门型云...
WordPress专业外贸企业网站搭建模版,特色专业外贸企业风格 + 自适应网站开发设计 通用流行的外贸企业网站模块 + 更好的SEO搜索优化和收录 自定义多模块的产品展示功能 + 高效实用的后台自定义模块设置!采用标准的HTML5+CSS3语言开发,兼容当下的各种主流浏览器: IE 6+(以及类似360、遨游等基于IE内核的)、Firefox、Google Chrome、Safari、Opera...