Questions
CPT111W PRINSIP PENGATURCARAAN (PRINCIPLES OF PROGRAMMING)
Single choice
What does the following code print?#include <iostream> using namespace std; int* allocateMemory() { int *ptr = new int; *ptr = 10; return ptr; } int main() { int *p = allocateMemory(); cout << *p << endl; delete p; return 0; }
View Explanation
Verified Answer
Please login to view
Step-by-Step Analysis
The question presents a small C++ program that allocates memory, assigns a value, prints it, and then frees the memory.
Option analysis:
Since the only provided option is 'c. The program will print 10.', we will validate that outcome.
First, the function allocateMemory creates a new int on the ......Login to view full explanationLog in for full answers
We've collected over 50,000 authentic exam questions and detailed explanations from around the globe. Log in now and get instant access to the answers!
Similar Questions
Consider the function call: p = (data_t *)malloc((num - 1) * sizeof(data_t)) The intention of this function call is best described as:
Inside the main() function of "particletest.c", we have now allocated an array of 1024 particles of type Particle. As we would like this number to be flexible in the future, the array is allocated dynamically using malloc(), which is part of the C Standard General Utilities Library. 在"particletest.c"的 main()函数中,我们动态分配了一个包含 1024 个 Particle 类型粒子的数组。为了使这个数字在未来可以灵活调整,我们使用 C 标准通用工具库中的 malloc()函数来动态分配数组。 Our implementation uses the following approach: 我们的实现采用了以下方法: #include <stdio.h> #include <stdlib.h> #define NUM_PARTICLES 1024 ··· int main() { Particle *particles = (Particle *)malloc(NUM_PARTICLES); ··· } Despite the fact that the declaration seems correct, the code produces a segmentation fault exception in some experiments. However, in some other situations, no apparent errors are produced. Do you consider the declaration and allocation to be correct (and, thus, the error located somewhere else in the source code)?
Inside the main() function of "particletest.c", we have now allocated an array of 1024 particles of type Particle. As we would like this number to be flexible in the future, the array is allocated dynamically using malloc(), which is part of the C Standard General Utilities Library. Our implementation uses the following approach: #include <stdio.h> #include <stdlib.h> #define NUM_PARTICLES 1024 ··· int main() { Particle *particles = (Particle *)malloc(NUM_PARTICLES); ··· } Despite the fact that the declaration seems correct, the code produces a segmentation fault exception in some experiments. However, in some other situations, no apparent errors are produced. Do you consider the declaration and allocation to be correct (and, thus, the error located somewhere else in the source code)?
Which header file must be included to use dynamic memory allocation functions like malloc and free?
More Practical Tools for Students Powered by AI Study Helper
Making Your Study Simpler
Join us and instantly unlock extensive past papers & exclusive solutions to get a head start on your studies!