ایمنی حافظه
ایمنی حافظه یک نگرانی در توسعه نرمافزار است که قصد دارد از اشکالات نرمافزاری که باعث آسیب پذیریهای امنیتی در برخورد با دسترسی به حافظه دسترسی تصادفی (RAM) میشود جلوگیری کند، مانند انوع buffer Overflow و اشاره گر آویزان.
انواع خطاهای حافظه
انواع مختلفی از خطاهای حافظه میتواند رخ دهد، بسته به نوع زبان برنامه نویسی استفاده میشود.
- سرریز بافر:
- خطاهای حافظه:
- درجه دو آزاد:
- درجه نامعتبر:
- متغیرهای مقداردهی نشده
- اشاره گر وحشی
- خطاهای خارج از حافظه
سرریز پشته - هنگامی رخ میدهد که یک برنامه خارج از فضای پشته اجرا میشود تخصیص شکست - این برنامه تلاش میکند تااز حافظه بیش از مقدار موجوداستفاده شود. در برخی از زبانها، این وضعیت را باید بعد از هر تخصیص دستی بررسی شود.
اشاره گر معلق
یک اشاره گر است که اشاره به حافظه شدهاست.
int *a = new int;
int *b = a;
delete b;
/* a and b are now dangling pointers */
*a = 4; /* Memory error: we may be overwriting another pointer's data */
سر ریز بافر
بافر ناحیه ذخیرهسازی موقت دادهاست. سرریز بافر وقتی رخ میدهد که یک برنامه سعی میکند دادههای بیشتری را در یک بافر از آن برای نگهداری در نظر گرفته شده بود ذخیره کند.
# include <stdio.h>
# define ARRAY_SIZE 128
int main(int argc, char *argv[])
{
char arr[ARRAY_SIZE];
if(argc <2)
return -1;
else
{
strcpy(arr, argv[1]);
return 0;
}
}
این برنامه دچار مشکل سرریز بافر میباشد. راه حل برای این مشکل، از ویژگیهای است که اجرای برنامه از کد را در بخش پشته از حافظه اجازه نمیدهد. برخی از زبانهای برنامه نویسی سیستم نسبت به سرریز بافر ایمن هستند.
پرل به صورت خودکار تغییر و تنظیم اندازه آرایهها را انجام میدهد، و Ada95 تشخیص و جلوگیری از سرریز بافر را.