ฟังก์ชันการจัดสรรหน่วยความจำ C ไลบรารีเป็นโมฆะ *malloc(ขนาด size_t) จะจัดสรรหน่วยความจำที่ร้องขอและส่งคืนตัวชี้ไปยังหน่วยความจำนั้น
ฟังก์ชันการจัดสรรหน่วยความจำ
หน่วยความจำสามารถจัดสรรได้สองวิธีตามที่อธิบายไว้ด้านล่าง -

เมื่อจัดสรรหน่วยความจำ ณ เวลาคอมไพล์แล้ว จะไม่สามารถเปลี่ยนแปลงได้ในระหว่างการดำเนินการ จะมีปัญหาเรื่องความไม่เพียงพอหรือการสูญเสียความจำอย่างอื่น
วิธีแก้ไขคือสร้างหน่วยความจำแบบไดนามิก เช่น ตามความต้องการของผู้ใช้ระหว่างการทำงานของโปรแกรม
ฟังก์ชันไลบรารีมาตรฐานที่ใช้สำหรับการจัดการหน่วยความจำแบบไดนามิกมีดังนี้ -
- malloc ( )
- calloc ( )
- realloc ( )
- ฟรี ( )
ฟังก์ชัน Malloc()
ฟังก์ชันนี้ใช้สำหรับการจัดสรรบล็อกหน่วยความจำเป็นไบต์ที่รันไทม์ ส่งคืนตัวชี้เป็นโมฆะ ซึ่งชี้ไปยังที่อยู่ฐานของหน่วยความจำที่จัดสรร
ไวยากรณ์สำหรับ malloc() มีดังต่อไปนี้ −
void *malloc (size in bytes)
ตัวอย่างที่ 1
ตัวอย่างต่อไปนี้แสดงการใช้งานฟังก์ชัน malloc()
int *ptr; ptr = (int * ) malloc (1000); int *ptr; ptr = (int * ) malloc (n * sizeof (int));
หมายเหตุ - คืนค่า NULL หากหน่วยความจำไม่ว่าง
ตัวอย่างโปรแกรม
รับด้านล่างเป็นโปรแกรม C เพื่อแสดงฟังก์ชันการจัดสรรหน่วยความจำแบบไดนามิก - malloc()
#include<stdio.h>
#include<stdlib.h>
void main(){
//Declaring variables and pointer//
int numofele,i;
int *p;
//Reading elements as I/p//
printf("Enter the number of elements in the array: ");
scanf("%d",&numofele);
//Declaring malloc function//
p = (int *)malloc(numofele * (sizeof(int)));
//Reading elements into array of pointers//
for(i=0;i<numofele;i++){
p[i]=i+1;
printf("Element %d of array is : %d\n",i,p[i]);
}
} ผลลัพธ์
เมื่อโปรแกรมข้างต้นทำงาน มันจะให้ผลลัพธ์ดังต่อไปนี้ −
Enter the number of elements in the array: 4 Element 0 of array is : 1 Element 1 of array is : 2 Element 2 of array is : 3 Element 3 of array is : 4
ตัวอย่างที่ 2
ต่อไปนี้เป็นโปรแกรม C เพื่อแสดงองค์ประกอบโดยใช้ฟังก์ชันการจัดสรรหน่วยความจำแบบไดนามิก -
ห้าบล็อกแรกควรว่างเปล่า ห้าบล็อกที่สองควรมีตรรกะ
#include<stdio.h>
#include<stdlib.h>
void main(){
//Declaring variables and pointers,sum//
int numofe,i,sum=0;
int *p;
//Reading number of elements from user//
printf("Enter the number of elements : ");
scanf("%d",&numofe);
//Calling malloc() function//
p=(int *)malloc(numofe*sizeof(int));
/*Printing O/p -
We have to use if statement because we have to check if memory
has been successfully allocated/reserved or not*/
if (p==NULL){
printf("Memory not available");
exit(0);
}
//Printing elements//
printf("Enter the elements : \n");
for(i=0;i<numofe;i++){
scanf("%d",p+i);
sum=sum+*(p+i);
}
printf("\nThe sum of elements is %d",sum);
free(p);//Erase first 2 memory locations//
printf("\nDisplaying the cleared out memory location : \n");
for(i=0;i<numofe;i++){
printf("%d\n",p[i]);//Garbage values will be displayed//
}
} ผลลัพธ์
เมื่อโปรแกรมข้างต้นทำงาน มันจะให้ผลลัพธ์ดังต่อไปนี้ −
Enter the number of elements : 5 Enter the elements : 12 10 24 45 67 The sum of elements is 158 Displaying the cleared out memory location : 7804032 0 7799120 0 67