c++ 基本使用
1 枚举
enum ShapeType
{
circle,
square,
rectangle
}; int main() { ShapeType shape = circle; switch(shape)
{
case circle:
cout<<"ShapeType.circle"<<endl;
break;
case square:
cout<<"ShapeType.square"<<endl;
break;
case rectangle:
cout<<"ShapeType.rectangle"<<endl;
break;
default:
cout<<"Unknown!"<<endl;
} return ;
}; 输出:
ShapeType.circle
2. const_cast, static_cast
const int i = ; /*
error C2440: 'const_cast' : cannot convert from 'const int' to 'int'
Conversion is a valid standard conversion, which can be performed implicitly or by use of static_cast, C-style cast or function-style cast
转换是一个合法的标准转换,可以通过隐式执行,或使用static_cast、C风格的转换、函数式转换进行
*/ //int j = const_cast<int>(i); /* 从 const int --> int, 下面4中都可以,唯独const_cast常量转换方式不行,只是因为它是一个合法的标准转换,用简单的方式已能处理还用不到高级的const_cast常量转换 */
int j = i; //隐式转换
int h = static_cast<int>(i); //static_cast静态转换
int k = (int)i; //C风格转换
int t = int(i); //函数式转换 /*
const int * --> int * 使用const_cast常量转换
*/
int* s = const_cast<int *>(&i); /*
error C2440: 'static_cast' : cannot convert from 'const int *' to 'int *'
Conversion loses qualifiers
*/
int* w = static_cast<int *>(&i); //long* l = const_cast<long *>(&i); // error C2440: 'const_cast' : cannot convert from 'const int *' to 'long *'
const_cast的用法:
返回该常量对应的变量 = const_cast<该常量所属的类型>(常量)
const int * --> int * 使用 const_cast
const int i = ; /* error C2440: 'initializing' : cannot convert from 'const int *' to 'int *' */
//int* p = &i; int* p = const_cast<int *>(&i);
const int --> int 是一个合法的标准转换,const int直接就可以隐含转换到int, eg. int i = 5;
3 union联合体
union Packed
{
char i;
short j;
int k;
long l;
float f;
double d; //该union的大小为double,8个字节
}; //分号是必须的,用于结束该union的定义 int main() { cout<<"sizeof(Packed) = "<<sizeof(Packed)<<endl; /*
* 联合体,用同一个变量,处理不同的数据类型
*/
Packed p; p.i = 'C';
cout<<p.i<<endl; p.d = 3.14159;
cout<<p.d<<endl; //此时联合体变量p保存的是d成员的值 return ;
};
4 数组
int a[10];
创建了10个存储单元连续的int型变量,但每一个变量都没有单独的标识符。相反,它们都集结在名字a下
int a[]; //数组名a的类型信息为int *
const int *p = a; //指针变量p的类型信息为int const * cout<<"a typeinfo: "<<typeid(a).name()<<endl; //int *
cout<<"p typeinfo: "<<typeid(p).name()<<endl; //int const * cout<<"sizeof(int) = "<<sizeof(int)<<endl; cout<<"a = "<<(long) a<<endl; //数组名的值 for (int i=; i<; i++)
cout<<"&a["<<i<<"] = "<<(long) &a[i]<<endl;
int型量占用4个字节,数组a占用的内存单元从176到212+4,共40个字节
数组名a的值,是第一元素a[0]的地址, a的值 与 &a[0] 相等
想给一个函数传递数组
1)声明一个数组作为函数参数
2)声明一个指向数组元素的指针
void func1(int a[], int size)
{
for (int i=; i<size; i++)
a[i] = i*i -i;
} void func2(int* a, int size)
{
for (int i=; i<size; i++)
a[i] = i*i +i;
} void print(int a[], string name, int size)
{
for (int i=; i<size; i++)
cout << name << "[" << i << "] = " << a[i] <<endl;
cout<<"--------------------------"<<endl;
} int main() { int a[]; //数组未初始化,输出的是一些无意义的值 -- 把数组a作为参数传给print函数,通过指针直接在同一块内容单元上操作,修改有效
print(a, "a", ); //初始化数组,并输出
func1(a, );
print(a, "a", ); //修改数组元素的值,并输出
func2(a, );
print(a, "a", ); return ;
};
命令行参数字符指针数组
命令行中每一个用空格分隔的字符串都被转换为一个单独的命令行参数
int main(int argc, char* argv[])
{ cout<<"argc = "<<argc<<endl; //命令行参数的个数 for (int i=; i<argc; i++)
cout<< "argv[" << i << "] = " << argv[i] <<endl; return ;
};
字符指针数组,即指向字符型的指针的数组,数组中的每个元素都是指向字符型的指针
5 函数指针
void func(int x)
{
cout<<"func("<< x <<") called ... "<<endl;
} int main(int argc, char* argv[])
{ void (*fp)(int); //定义函数指针fp, 该函数有1个int参数,无返回值
fp = func;
(*fp)(); //func(2) called ... void (*fp2)(int) = func; //定义函数指针fp, 并把函数func的地址赋给它
(*fp2)(); //func(3) called ... return ;
};
随机推荐
- listView中的button控件获取索引
1.在listitem中初始化button的时候,给该button添加一个setTag方法,将此时的索引值传进去,然后在button的onclick事件中调用view的getTag方法,即可将list ...
- 为什么不用原生的Spring Cloud Config
引言 近几年传统应用架构已经逐渐朝着微服务架构演进.那么随着业务的发展,微服务越来越庞大,此时服务配置的管理变得会复杂起来.为了方便服务配置文件统一管理,实时更新,配置中心应运而生.其实,所谓配置中心 ...
- BZOJ 3057圣主的考验题解
老师居然考这么毒瘤的题目!!!!! 很容易想到dp,f[i][j]表示有i个节点,左子树的最深深度为j的方案数 枚举左子树有多少节点然后转移,复杂度为n^3 T飞~ 我们考虑到有深度为h的树的节点有多 ...
- maven与sbt修改国内镜像
一.idea中的maven 1.打开IntelliJ IDEA->Settings ->Build, Execution, Deployment -> Build Tools > ...
- MUI - sortable在mui.js前端框架不兼容的解决方案
关于sortable看这 兼容的解决方案看这 http://www.cnblogs.com/phillyx/ 示例代码已更到github
- BKDRHash算法的初步了解
字符串hash最高效的算法, 搜了一下, 原理是: 字符串的字符集只有128个字符,所以把一个字符串当成128或更高进制的数字来看,当然是唯一的 这里unsigned不需要考虑溢出的问题, 不过 ...
- ubuntu 代理配置
1.安装Python 2.安装shadowsocks客户端 sudo pip install shadowsocks 3.配置shadowsocks客户端配置 vim /etc/shadowsocks ...
- 【JZOJ4845】【NOIP2016提高A组集训第5场11.2】寻找
题目描述 "我有个愿望,我希望穿越一切找到你." 这是个二维平面世界,平面上有n个特殊的果实,我从(0,0)点出发,希望得到尽量多的果实,但是出于某种特殊的原因,我的运动方式只有三 ...
- 找顺数【数位dp】
输出1到n中含有6的数的个数. 样例输入 100 样例输出 19 找规律感觉好难想(好像是什么100以内有19个,200以内有19*2个,600以内115个,700以内214个...,1000以内有2 ...
- spring调试
spring-beans DefaultListableBeanFactory preInstantiateSingletons:650 RequestMappingHandlerMapping Ab ...