简单的C语言小题目隐藏的知识(一)
2016-07-07 17:18
309 查看
有时候,一些简单的选择,填空能够弥补我们对C理论知识上的空缺,使我们在实际编程时可以运用一些技巧大大提高编译以及运行的效率。希望我在做题时遇到的知识空白也能够帮到大家。
1.下面哪种C/C++
分配内存的方法会将分配的空间初始化为0:
A.malloc()
B.calloc()
C.realloc()
D.new[ ]
解析:
1) malloc函数:
void *malloc(unsigned int size)
在内存的动态分配区域中分配一个长度为size的连续空间,如果分配成功,则返回所分配内存空间的首地址,否则返回NULL,申请的内存不会进行初始化。
2)calloc函数:
void *calloc(unsigned int num, unsigned int size)
按照所给的数据个数和数据类型所占字节数,分配一个
num * size 连续的空间。
calloc申请内存空间后,会自动初始化内存空间为
0,但是malloc不会进行初始化,其内存空间存储的是一些随机数据。
3)realloc函数:
void *realloc(void *ptr, unsigned int size)
动态分配一个长度为size的内存空间,并把内存空间的首地址赋值给ptr,把ptr内存空间调整为size。
申请的内存空间不会进行初始化。
4)new是动态分配内存的运算符,自动计算需要分配的空间,在分配类类型的内存空间时,同时调用类的构造函数,对内存空间进行初始化,即完成类的初始化工作。动态分配内置类型是否自动初始化取决于变量定义的位置,在函数体外定义的变量都初始化为0,在函数体内定义的内置类型变量都不进行初始化。
2.下面程序的输出结果为多少(32位机器上)?
void Func(char str_arg[2])
{
int m = sizeof(str_arg);
int n = strlen(str_arg);
printf("%d\n", m);
printf("%d\n", n);
}
int main(void)
{
char str[] = "Hello";
Func(str);
}
A.5 5
B.5 4
C.4 5
D.4 4
解析:
数组作为函数参数时,会自动退化为指针
①对于voidFunc(charstr_arg[2])
这一句不要被那个2误导了
下面这些写法都可以的。
voidFunc(charstr_arg[])
voidFunc(charstr_arg[1])
voidFunc(charstr_arg[2])
voidFunc(charstr_arg[3])
voidFunc(charstr_arg[4])
...
voidFunc(charstr_arg[200])
...
也可以写成
voidFunc(char *str_arg)
之所以能这样写,是因为Func的参数是一个地址
②对于sizeof的参数,是一个指针,因为这是32位系统,
32 = 8*4,需要4字节存储指针。
如果是64位系统 64 = 8*8,需要8字节
③对于strlen,就是字符串的长度,"Hello"长度是5
1.下面哪种C/C++
分配内存的方法会将分配的空间初始化为0:
A.malloc()
B.calloc()
C.realloc()
D.new[ ]
解析:
1) malloc函数:
void *malloc(unsigned int size)
在内存的动态分配区域中分配一个长度为size的连续空间,如果分配成功,则返回所分配内存空间的首地址,否则返回NULL,申请的内存不会进行初始化。
2)calloc函数:
void *calloc(unsigned int num, unsigned int size)
按照所给的数据个数和数据类型所占字节数,分配一个
num * size 连续的空间。
calloc申请内存空间后,会自动初始化内存空间为
0,但是malloc不会进行初始化,其内存空间存储的是一些随机数据。
3)realloc函数:
void *realloc(void *ptr, unsigned int size)
动态分配一个长度为size的内存空间,并把内存空间的首地址赋值给ptr,把ptr内存空间调整为size。
申请的内存空间不会进行初始化。
4)new是动态分配内存的运算符,自动计算需要分配的空间,在分配类类型的内存空间时,同时调用类的构造函数,对内存空间进行初始化,即完成类的初始化工作。动态分配内置类型是否自动初始化取决于变量定义的位置,在函数体外定义的变量都初始化为0,在函数体内定义的内置类型变量都不进行初始化。
2.下面程序的输出结果为多少(32位机器上)?
void Func(char str_arg[2])
{
int m = sizeof(str_arg);
int n = strlen(str_arg);
printf("%d\n", m);
printf("%d\n", n);
}
int main(void)
{
char str[] = "Hello";
Func(str);
}
A.5 5
B.5 4
C.4 5
D.4 4
解析:
数组作为函数参数时,会自动退化为指针
①对于voidFunc(charstr_arg[2])
这一句不要被那个2误导了
下面这些写法都可以的。
voidFunc(charstr_arg[])
voidFunc(charstr_arg[1])
voidFunc(charstr_arg[2])
voidFunc(charstr_arg[3])
voidFunc(charstr_arg[4])
...
voidFunc(charstr_arg[200])
...
也可以写成
voidFunc(char *str_arg)
之所以能这样写,是因为Func的参数是一个地址
②对于sizeof的参数,是一个指针,因为这是32位系统,
32 = 8*4,需要4字节存储指针。
如果是64位系统 64 = 8*8,需要8字节
③对于strlen,就是字符串的长度,"Hello"长度是5
相关文章推荐
- VC++6.0调试
- 循环双端队列示例C++_通话列表的保存
- C++ 几个不常用的关键字
- C++设计模式-Composite组合模式
- [note] C语言控制终端,缘何使用“\033[m”
- C++基础8【难】 回顾:数组指针,函数指针,函数指针做函数参数 C语言多态
- java 层调用Jni(Ndk) 持久化c c++ 对象
- POJ1001(C++处理大数)
- 设计模式(14)-Flyweight Pattern
- C++类构造函数,拷贝构造函数,赋值函数,析构函数几点注意
- c++——const
- 开始学习算法导论
- 数组引用:C++ 数组做参数 深入分析
- C++继承与派生
- 【c++程序】指针数组与数组指针
- c++——static关键字
- MFC使用ADO链接ACCESS的环境部署与注意事项
- C++经典面试问题20-40
- C++ 关于声明,定义,类的定义,头文件作用,内、外链接
- MFC学习笔记2_消息映射