مجموعهای از شبکههای متصل که تحت کنترل یک یا چند مدیر شبکه قرار دارند و سیاست مسیریابی یکسانی را بهکار میبرند.
آزادسازی حافظه (Deallocation) به فرآیند آزاد کردن حافظهای اطلاق میشود که بهطور داینامیک در حین اجرای برنامه تخصیص داده شده است. هنگامی که حافظه دیگر نیازی به استفاده ندارد، باید آزاد شود تا از مصرف بیمورد منابع سیستم جلوگیری شده و از مشکلاتی مانند نشت حافظه (Memory Leak) جلوگیری گردد. آزادسازی حافظه معمولاً با استفاده از دستور یا توابع خاص در زبانهای برنامهنویسی انجام میشود.
در بیشتر زبانهای برنامهنویسی مانند C و C++، مسئولیت آزادسازی حافظه به عهده برنامهنویس است. در زبانهای سطح بالاتر مانند Java و Python، این کار بهطور خودکار توسط سیستم جمعآوری زباله (Garbage Collection) انجام میشود.
در زبانهای C و C++، پس از تخصیص حافظه داینامیک، لازم است که حافظه تخصیص داده شده آزاد شود تا از نشت حافظه جلوگیری شود. در این زبانها از توابع free() در C و delete یا delete[] در C++ برای آزادسازی حافظه استفاده میشود.
در زبان C، حافظه بهطور داینامیک با استفاده از توابع malloc یا calloc تخصیص داده میشود و پس از استفاده از آن، باید با استفاده از free() حافظه آزاد شود. در اینجا یک مثال از نحوه تخصیص و آزادسازی حافظه در زبان C آورده شده است:
#include <stdio.h> #include <stdlib.h> int main() {
int *arr;
int size = 5;
// تخصیص حافظه داینامیک برای آرایه
arr = (int *)malloc(size * sizeof(int));
if (arr == NULL) {
printf("Memory allocation failed\n");
return 1;
}
// استفاده از آرایه
for (int i = 0; i < size; i++) {
arr[i] = i * 10;
}
// آزادسازی حافظه
free(arr);
return 0; } در این مثال، حافظه برای آرایهای از 5 عدد صحیح با استفاده از malloc() تخصیص داده شده و پس از استفاده از آن، با استفاده از free() حافظه آزاد میشود.
در زبان C++، از new برای تخصیص حافظه و از delete برای آزادسازی حافظه استفاده میشود. در اینجا یک مثال از نحوه تخصیص و آزادسازی حافظه در زبان C++ آورده شده است:
#include <iostream> using namespace std; int main() {
int *arr;
int size = 5;
// تخصیص حافظه داینامیک با استفاده از new
arr = new int[size];
// استفاده از آرایه
for (int i = 0; i < size; i++) {
arr[i] = i * 10;
}
// آزادسازی حافظه با استفاده از delete
delete[] arr;
return 0; } در اینجا، حافظه برای آرایهای از 5 عدد صحیح با استفاده از new تخصیص داده شده است و سپس با استفاده از delete[] آزاد میشود. در C++، برای آزادسازی حافظهای که با new[] تخصیص داده شده باید از delete[] استفاده کرد.
در زبانهای Java و Python، جمعآوری زباله (Garbage Collection) مسئول آزادسازی حافظه است. در این زبانها، نیازی به مدیریت دستی حافظه نیست و سیستم بهطور خودکار حافظهای که دیگر مورد استفاده نیست را شناسایی کرده و آن را آزاد میکند.
در زبان Java، اشیاء بهطور خودکار در حافظه داینامیک تخصیص داده میشوند و زمانی که دیگر به آنها نیاز نیست، توسط سیستم جمعآوری زباله حذف میشوند. در اینجا یک مثال ساده از نحوه ایجاد یک شیء در Java آورده شده است:
public class Main {
public static void main(String[] args) {
// تخصیص حافظه داینامیک برای شیء
MyClass obj = new MyClass();
// استفاده از شیء
obj.display();
// شیء بهطور خودکار پس از پایان استفاده از حافظه حذف میشود (جمعآوری زباله)
} } class MyClass {
void display() {
System.out.println("Object is created");
} } در اینجا، شیء obj از کلاس MyClass بهطور خودکار در حافظه داینامیک ایجاد میشود و بعد از اتمام استفاده از آن، حافظه بهطور خودکار آزاد میشود.
در زبان Python، نیز جمعآوری زباله بهطور خودکار انجام میشود و نیازی به آزادسازی حافظه بهطور دستی نیست. در اینجا یک مثال ساده از تخصیص حافظه داینامیک در Python آورده شده است:
class MyClass:
def display(self):
print("Object is created") # تخصیص حافظه داینامیک برای شیء obj = MyClass() # استفاده از شیء obj.display() # شیء بهطور خودکار پس از پایان استفاده از حافظه حذف میشود (جمعآوری زباله) در Python نیز مشابه Java، پس از پایان استفاده از شیء، حافظه بهطور خودکار توسط سیستم جمعآوری زباله آزاد میشود.
در نهایت، آزادسازی صحیح حافظه یکی از نکات حیاتی در برنامهنویسی است که به شما این امکان را میدهد که از منابع سیستم بهطور بهینه استفاده کنید و از بروز مشکلاتی مانند نشت حافظه جلوگیری نمایید. در زبانهای مختلف برنامهنویسی، این فرآیند میتواند بهطور دستی یا خودکار انجام شود، بسته به نحوه مدیریت حافظه در آن زبان.
برای اطلاعات بیشتر، میتوانید از سایت saeidsafaei.ir و اسلایدهای محمد سعید صفایی بهرهبرداری کنید.
در این مبحث، به معرفی انواع دستورالعملهای شرطی پرداخته میشود و در راستای آن، عملگرهای منطقی بهطور کامل مورد بررسی قرار میگیرند. همچنین، با مفاهیمی مانند بلوک دستورالعمل، ارزیابی میانبری و تله سقوط آشنا میشویم. در نهایت، انواع کلمات کلیدی در برنامهنویسی معرفی شده و کاربردهای آنها توضیح داده میشود. هدف این جلسه، تقویت درک شرطها و نحوه استفاده صحیح از آنها در نوشتن برنامههای کاربردی است.
مجموعهای از شبکههای متصل که تحت کنترل یک یا چند مدیر شبکه قرار دارند و سیاست مسیریابی یکسانی را بهکار میبرند.
یادگیری خود-نظارتی یک روش یادگیری ماشین است که در آن مدلها از دادهها بدون برچسبهای صریح یاد میگیرند.
فرآیندی است که برای برنامهریزی، نظارت و کنترل منابع و زمانبندی به منظور رسیدن به اهداف پروژه انجام میشود.
شرط به معنای مقایسهای است که باید در حلقهها یا دستورات شرطی بررسی شود. شرط اگر درست باشد، عمل خاصی اجرا خواهد شد.
تحقیقات دیجیتال به تجزیه و تحلیل و بازیابی دادهها از سیستمهای دیجیتال برای تحقیقات قضائی و قانونی اطلاق میشود.
یک نیبل معادل 4 بیت است و معمولاً برای نمایش یک نیمکلمه در سیستمهای کامپیوتری استفاده میشود.
نمادهایی هستند که برای انجام عملیات ریاضی مانند جمع، تفریق، ضرب و تقسیم بر روی دادهها استفاده میشوند.
چگونگی چیدمان فیزیکی و منطقی اجزای شبکه که در آن نحوه اتصال گرهها و نحوه انتقال دادهها توصیف میشود.
هوش مصنوعی در تشخیصهای پزشکی به استفاده از الگوریتمهای هوش مصنوعی برای تجزیه و تحلیل دادهها و تشخیص بیماریها بهطور دقیقتر و سریعتر از انسان اطلاق میشود.
تولید زبان طبیعی به فرآیندی گفته میشود که در آن ماشینها قادر به تولید متن و محتوای طبیعی مشابه انسان میشوند.
بازگشتی زمانی است که یک تابع یا روش، خود را فراخوانی میکند تا زمانی که شرط خاصی به حقیقت بپیوندد.
یادگیری ماشین کوانتومی به استفاده از اصول کوانتومی در الگوریتمهای یادگیری ماشین برای بهبود عملکرد پردازش دادهها اطلاق میشود.
ساخت هوشمند به استفاده از هوش مصنوعی و رباتها برای طراحی و تولید محصولات در فرآیندهای صنعتی اطلاق میشود.
اینترنت کوانتومی به شبکهای گفته میشود که بر اساس اصول فیزیک کوانتومی برای انتقال دادهها با امنیت بالا عمل میکند.
این تکنیک در علم داده و تحلیل دادهها به معنای جمعآوری و تجزیه و تحلیل دادهها به گونهای است که از انتشار اطلاعات شخصی جلوگیری شود و همزمان از دادهها برای استخراج الگوهای عمومی استفاده شود.
کابلهای زوج به هم تابیده بدون پوشش فلزی برای کاهش هزینه و نصب آسان.
زمانی که روترها پیامهای Hello را برای شناسایی همسایگان OSPF ارسال میکنند.
سیستمهای شناختی مصنوعی به سیستمهایی اطلاق میشود که از الگوریتمها و مدلهای هوش مصنوعی برای شبیهسازی و بهبود عملکرد مغز انسان استفاده میکنند.
هوش جمعی به رفتار هماهنگ گروهی اطلاق میشود که از تعاملات میان موجودات ساده (مانند روباتها یا موجودات مصنوعی) به دست میآید.
جدولی که در آن آدرسهای MAC و IP دستگاههای متصل به شبکه ذخیره میشود.
آگاهی مصنوعی به ایجاد سیستمهای هوش مصنوعی اطلاق میشود که قادر به تجربه و درک مشابه انسانها باشند.
تابع درونخطی تابعی است که کد آن به جای فراخوانی معمولی مستقیماً در محل فراخوانی قرار میگیرد، که معمولاً برای توابع ساده و کوتاه استفاده میشود.
عملگرهای مقایسهای برای مقایسه دو مقدار و تعیین روابط آنها مانند بزرگتر از، کوچکتر از و مساوی استفاده میشوند.
روش دسترسی که در آن دستگاهها بهطور پویا درخواست دسترسی به رسانه میدهند و اولویت دسترسی بر اساس تقاضای دستگاهها تعیین میشود.
تحلیلهای زمان واقعی به تجزیه و تحلیل و پردازش دادهها بهطور همزمان با وقوع آنها گفته میشود.
نوعی VLAN که به دستگاهها اجازه میدهد در یک VLAN مشترک باشند اما نتوانند به یکدیگر دسترسی داشته باشند.
بلاکچین در زنجیره تأمین به استفاده از فناوری بلاکچین برای ردیابی و تأمین شفافیت در فرآیندهای زنجیره تأمین اطلاق میشود.
واحد محاسباتی و منطقی است که مسئول انجام محاسبات ریاضی و منطقی در پردازنده میباشد.
واحد دادهای است که در پروتکلهای مختلف استفاده میشود. این واحد در هر لایه از مدل OSI تغییر شکل میدهد.
نویز ناشی از میدانهای الکترومغناطیسی که از تجهیزات الکتریکی و الکترونیکی ایجاد میشود.
محدوده به بخشهایی از کد اطلاق میشود که در آنها یک متغیر یا تابع قابل دسترسی است.
بهینهسازی یادگیری عمیق به تکنیکهایی اطلاق میشود که برای بهبود عملکرد مدلهای یادگیری عمیق به کار میروند.
مقداردهی اولیه به متغیرها یا دادهها به معنای اختصاص مقدار اولیه به آنها پیش از استفاده در برنامه است.
کاهش مقدار یک متغیر به طور منظم در هر بار اجرا، که معمولاً در حلقهها برای شمارش معکوس یا تغییر مقدار استفاده میشود.
هوش مصنوعی جغرافیایی به استفاده از الگوریتمهای هوش مصنوعی برای تحلیل و پردازش دادههای جغرافیایی و مکانی اطلاق میشود.