他写在博客上不负责任,有人踩在上面,原因一点点失去了它。
其实纯常见问题。特别糟糕,由于鲍文看起来很大的优势就是想更直接看到的东西。
好了。返回整个标题。
1.你脑海中的运算符有哪些。按优先级排个序?
这个问题明显没有标准答案,可是最主要的还是要有吧。
比方+ ,- ,* ,/ ,%, 前++/--,后++/--,=,<, >, << ,>>,(),&,^,|,~以及逗号","域名符"::",&&,||等等等等。
其优先级麻,这个可能会略微麻烦一点,可是自己简单试验肯定能够做出来的。
所谓的优先级顺序能够看博文最后的表。
2 .malloc/free 和 new/delete的差别?(我没有跑题?。)
从功能上两者都是申请/释放动态的数组可是,malloc/free是stdlib的函数。须要加头文件stdlib。而new/delete是运算符。
1、malloc/free是C/C++中的方法(函数),new/delete是C++中的操作符。
2、malloc/free使用的内存空间为堆区,new/delete是free store区。
3、free须要推断非空,非空才干释放。可是delete是不须要的
4、另外在使用new/delete是调用构造函数/析构函数,而malloc/free不过对内存分配,也因此不能满足非内部数据。
3.让你来写一个重载函数++i,i++,你怎么写?
这个是基本功
/***********************************************************
> OS : Linux 3.11.10-301.fc20.x86_64 Fedora20
> Author : yaolong
> Mail : dengyaolong@yeah.net
> Time : 2014年07月17日 星期四 09时02分44秒
**********************************************************/
#include<iostream>
#include<cstdio>
#include<string>
#include<cstring>
using namespace std;
class A{
public:
int x;
A(int x=0){
this->x=x;
}
A operator ++(int ){ //i++,先返回复制品。再搞原对象
A tmp=*this ;
this->x++;
return tmp;
}
A operator ++(){//++i,直接改动对象
this->x++;
return *this;
}
};
int main(){
A a1(3);
A a2=a1++;
cout<<a2.x<<endl;; //3
cout<<a1.x<<endl; //4
A a3=++a2;
cout<<a3.x<<endl; //4
cout<<a2.x<<endl; //4
}
4.来看个程序
#include<iostream>
using namespace std; int main(){
int x=3;
cout<<x+x%2==1<<endl;
return 0;
}
这个程序是不能正常执行的。编译错误,依据优先级看来是% , + 。 <<, ==
所以整个式子解释应该是
x%2 -> 1
x+ 1 -> 4
1<<endl 出错了
以下假如式子变成这样,
cout<<(x+x%2==1<<2)<<endl;
这样整个式子的解释是这种
由于()优先级最高(在这个式子中),所以先解释()内的
x%2 -> 1
x+1 ->4
1<<2 -> 4
4 ==4 得到1
之后到运算符<<
而<<是从左到右的,故cout<<1 之后再输出转行
输出的为
1
当我们这样写
int y=x+x%2==1<<2;
cout<<y<<endl;
这时候就没有错,为什么?由于=号的优先级非常低,仅仅有逗号比其更低了,就仅仅有一个
我们不是常常这么做吗?
int x=3,y;
5.再来看一个?跟你想的又一样不一样?
#include<iostream>
using namespace std;
int main(){
int x=3;
cout<<((x+x%2)==1)<<endl;
cout<<(x+(x%2==1))<<endl; return 0;
}
这个用上面的分析,非常easy就知道了
第一个先运行最里层括号
(x+x%2)
而%比+优先,所以就是
x%2 ->1
x+1 -> 4
之后外层括号
4==1 -> 0(false)
第一个输出为0
第二个很easy知道
x%2->1
1==1 -> 1(true)
x+1 -> 4
第二个输出4
6.来个难一点的,感觉一下逗号和括号的恶心?
#include<iostream>
using namespace std; void fun0(int x,int y ,int z){
cout<<x<<" "<<y<<" "<<z<<endl;
int a=2,b=3,c=7;
x=a*b,c;
y=(a*b+z,z=c);
cout<<x<<" "<<y<<" "<<z<<endl;
}
void fun1(int x,int y,int z){
cout<<x<<" "<<y<<" "<<z<<endl;
int a=2,b=3,c=7;
y=(x=a+b+z),(z=b+c);
cout<<x<<" "<<y<<" "<<z<<endl;
}
void fun2(int x,int y,int z){
cout<<x<<" "<<y<<" "<<z<<endl;
int a=2,b=3,c=7;
y=((x=a+b+z),(z=b+c));
cout<<x<<" "<<y<<" "<<z<<endl;
}
int main(){
int x,y,z;
fun0(x,y,z);
fun1(x,y,z);
fun2(x,y,z);
}
这个题目是相对过分的,由于手写根本写不出正确答案,不同编译器输出结果页不一样。
看fun0(x,y,z)
由于x,y,z没有初始值,所以每一个函数的第一个输出x,y,z都是编译器默认的。
int a=2,b=3,c=7;
x=a*b,c;
y=(a*b+z,z=c);
这个,先声明了a=2,b=3,c=7
x=a*b,c
由于逗号比=优先级低,前面说过,=号是倒数第二低,逗号是倒数第一。x=6,c没有不论什么改变
y=(a*b+z,z=c)
先执行括号的东西
(a*b+z,z=c)
,号是从左到右执行,假设感兴趣的朋友能够试验一下(p=a*b+c,z=c),把p数出来就知道了
所以先运行表达式
a*b+z。得到2*3 +z(z是一个乱七八糟的数,我的GCC编译出来的是32767)。
再运行z=c,而(表达式1,表达式2。表达式……)最后返回的是最后一个表达式
所以y=z=c,y=7,z=7
第一个fun0在我这里输出为
0 0 32767
6 7 7
对于fun1,2也是通=,的优先级来推断
很easy就能够判断出来其结果
最后总的输出为
0 0 32767
32773
6 7 7
0 0 32767
32772 32772 10
0 0 32767
32772 10 10
以下再附带一个fun3,用于測试上述到的逗号的从左到右运行
void fun3(int x,int y ,int z){
cout<<x<<" "<<y<<" "<<z<<endl;
int a=2,b=3,c=7,p;
x=a*b,c;
y=(p=a*b+z,z=c);
cout<<p<<endl;
cout<<x<<" "<<y<<" "<<z<<endl; }
7.我们用%来做余运算,%仅仅能应用于正整数对吗?
这个问题自己測试就能够拉,是能够对非0的整数进行操作,可是不能对浮点型等操作。
8.域运算符::我们经常常使用到,请问::能够重载吗?
不能够的,运算符有一些是不能重载的。比方本题的::和.等等。在文章最后会有提到可否重载。
9.运算符重载作为非成员函数重载时必须定义为友元函数?
不是的,当操作的成员为公开的时候不一定要定义友元函数。
10. 运算符必须是符号吗?(即仅仅能是+,-,*,/,::之类的吗?)
不是的。文章一開始就提到了。new/delete是运算符。还有sizeof,和强制转换操作符等。
图片来自百度百科。
版权声明:本文博主原创文章,博客,未经同意不得转载。