本文主要是介绍C语言—每日选择题—Day70(需要看),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
第一题(注)
1、关于内存管理,以下有误的是( )
A: malloc在分配内存空间大小的时候是以字节为单位
B: 如果原有空间地址后面还有足够的空闲空间用来分配,则在原有空间后直接增加新的空间,使得增加新空间后的空间总大小是:newSize
C: 如果原有空间地址后面没有足够的空闲空间用来分配,那么从堆中另外找一块newsize大小的内存,并把先前内存空间中的数据复制到新的newSize大小的空间中,然后将之前空间释放
D: free函数的作用是释放内存,内存释放是标记删除,会修改当前空间的所属状态,并且会清除空间内容
答案及解析 D
free不会清除空间内容
第二题(注)
2、如下程序输出的结果是什么()
#include <stdio.h>
typedef struct List_t
{struct List_t* next;struct List_t* prev;char data[0];
}list_t;
int main()
{printf("%d",sizeof(list_t));return 0;
}
A: 4byte
B: 8byte
C: 5byte
D: 9byte
答案及解析 B
题目中的char data[0]或写成char data[],即为柔性数组成员;在计算机结构体大小的时候data不占用struct的空间,只是作为一个符号地址存在。因此sizeof的值是两个指针所占字节,即4+4=8字节
第三题
3、以下程序的输出结果是( )
#include<stdio.h>
void fut(int**s,int p[2][3])
{**s=p[1][1];
}
int main()
{int a[2][3]={1,3,5,7,9,11},*p;p=(int*)malloc(sizeof(int));fut(&p,a);printf("%d",*p);return 0;
}
A: 7
B: 9
C: 1
D: 11
答案及解析 B
这个需要注意的是传的参数是p的地址,所以在函数fut内部就可以对p的内容进行修改
第四题(注)
4、以下有关C语言的说法中,错误的是( )
A: 内存泄露一般是指程序申请了一块内存,使用完后,没有及时将这块内存释放,从而导致程序占用大量内存,但又不使用不释放
B: 可以通过malloc(size_t)函数调用申请超过该机器物理内存大小的内存块
C: 无法通过 free(void*) 直接将某块已经使用完的内存直接还给操作系统,free函数只是将动态申请内存的使用权释放
D: 可以通过内存分配函数malloc(size_t)直接申请物理内存
答案及解析 D
malloc申请的是虚拟内存
free 释放的只是将这个内存的使用权释放,而真正释放内存还给操作系统,需要等进程结束
第五题 (注)
5、若要用 fopen 函数打开一个新的二进制文件,该文件既能读也能写,则文件方字符串应是
A: "ab++"
B: "wb+"
C: "rb+"
D: "ab"
答案及解析 B
大家如果对文件操作不熟悉,推荐去学一下操作系统的文件操作,回来再看C语言的,会发现易如反掌!这里等作者将文件操作的博客写出来后,会做解释,大家可以收藏下,到时候来这里找链接
这篇关于C语言—每日选择题—Day70(需要看)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!