牛客网错题知识点整理C/C++(一)
一. 知识点以及错题
1.考察运算符的结合方向
int main(void){
int a = 3;
printf("%d\n", (a += a -= a*a));
}
答案为-12
a = (a + (a - a*a))
a = (a + (3 - 9))
a = -6 + (-6) = -12
2.运算符的优先级
一般为算数运算符>关系运算符>逻辑运算符>条件运算符>
- 由高到低:算<—关<—逻<—条<—赋
3.下面四个类,在32位机器上,sizeof(A), sizeof(B),sizeof( C),sizeof(D)的值分别为什么?
class A{
};
class B{
char ch;
int x;
};
class C{
public:
void Print(void){}
};
class D
{
public:
virtual void Print(void){}
};
答案为:1,8,1,4
类A占用1个字节的占位空间,类B在32位机器对齐字节数为4,char为1,int为4,
所以补齐到8个字节,函数C的返回值为void类型,也占一个字节,virtual修饰符加上后占用4个字节
4. 用C语言实现的算法可以没有输出但必须要有输入?
这句话的阐述是错误的,正确的应该是一个算法有0个或多个输入 有一个或多个输出
5.如下题
这里需要考虑到运算符的优先级,左移的优先级要高于异或,所以y先左移两位变为11000,在于x异或变为00011011
6.如下图![在这里插入图片描述](https://i-blog.csdnimg.cn/blog_migrate/6e16eaa988bd4d7c534c3b4125b62ffe.png#pic_center)
根据大佬的解答,似乎明白了什么;主函数中调用了sayHello(b),调用了类中的默认拷贝函数,使得两者的对象完全相同,在制作p返回时,调用了析构函数释放了p,但是在程序结束后又再一次调用了析构函数,所以会导致程序崩溃
- 以下是大佬原话
这里的错误原因是编译器在生成default copy construction的时候使用的bitwise copy语义,也就是只是简单的浅拷贝。 上面被注释掉的程序就是编译器自动添加的部分。 从而导致在sayHello中向参数x传递值时,调用了bitwise copy的拷贝构造函数,使得x对象和b对象中的值完全一致,包括p指针的值,在x离开作用域(也就是sayHello函数结束),x发生析构,调用delete 销毁了指针p,同时在main函数结束的时候,析构b时又会调用一次delete删除指针p。
7.若有定义语句:char s[3][10],(*k)[3],*p;则以下赋值语句错误的是()
1.p=s;
2.p=k;
3.p=s[0];
4.k=s;
首先来看选项1,由于p是指向char类型的指针,而s是指向char数组的指针,所以是错的;
选项2,由于p是指向char类型的指针,而k是指向char数组的指针,所以也是错的;
选项3,同理,这里的s[0]表示第一个元素的首地址,是为指向char类型的,所以正确
选项4,都是指向char数组的指针,没问题,但是s指向的是长度为10的数组指针,可以理解为char (*p)[10],但是k却是一个指向长度为3的数组指针,所以也是错的;
8.若变量已正确赋值,下列哪些表达式不符合C的语法?
a=a+7
a=7+b+c,a++
int(12.3%4)
a=a+7=c+b
首先分析第一个,一看就是正确的,再看第二个也正确,多选题果断CD
在看第三个,无法对double类型的数字取余,所以错误
最后一个,可以写成 a = a + (7 = c+b);这里的7位常量不能被修改