پهپادهای خودمختار به وسایل نقلیه هوایی بدون سرنشین اطلاق میشود که قادر به انجام وظایف خودکار مانند نقشهبرداری و نظارت هستند.
حافظه داینامیک (Dynamic Memory) به حافظهای اطلاق میشود که در زمان اجرا (Runtime) برای ذخیرهسازی دادهها تخصیص مییابد و در صورت نیاز میتوان آن را آزاد کرد. در برنامهنویسی، حافظه داینامیک به برنامهنویس این امکان را میدهد که بهطور داینامیک و در زمان اجرای برنامه حافظه را اختصاص داده و پس از استفاده از آن، حافظه را آزاد کند. این نوع حافظه برای مدیریت دادههایی که اندازه آنها در زمان کامپایل مشخص نیست بسیار مفید است.
در اکثر زبانهای برنامهنویسی مانند C، C++ و Java، حافظه داینامیک از طریق تخصیص و آزادسازی دستی یا خودکار مدیریت میشود. در زبانهای سطح پایین مانند C و C++، برنامهنویسان مسئول تخصیص و آزادسازی حافظه هستند، در حالی که در زبانهای سطح بالاتر مانند Java و Python، این فرآیند بهطور خودکار با استفاده از جمعآوری زباله (Garbage Collection) مدیریت میشود.
در زبانهای C و C++، از توابع malloc، calloc و realloc برای تخصیص حافظه داینامیک استفاده میشود و برای آزادسازی حافظه از 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;
}
// چاپ مقادیر آرایه
for (int i = 0; i < size; i++) {
printf("%d ", arr[i]);
}
printf("\n");
// آزادسازی حافظه
free(arr);
return 0; } در این مثال، از تابع malloc برای تخصیص حافظه داینامیک برای یک آرایه از نوع int استفاده میشود. پس از استفاده از آرایه، با استفاده از تابع 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;
}
// چاپ مقادیر آرایه
for (int i = 0; i < size; i++) {
cout << arr[i] << " ";
}
cout << endl;
// آزادسازی حافظه با استفاده از delete
delete[] arr;
return 0; } در این مثال، از new برای تخصیص حافظه داینامیک و از delete برای آزادسازی حافظه استفاده شده است. توجه داشته باشید که در C++، باید از delete[] برای آزادسازی حافظهای که با new[] تخصیص داده شده است، استفاده کرد.
در زبانهای 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، شیء obj از کلاس MyClass بهطور خودکار در حافظه داینامیک تخصیص داده میشود. مشابه Java، حافظه این شیء بعد از استفاده بهطور خودکار آزاد میشود.
در نهایت، حافظه داینامیک یکی از ویژگیهای کلیدی در برنامهنویسی است که به برنامهنویسان این امکان را میدهد که حافظه را بهطور مؤثر و انعطافپذیر تخصیص دهند و مدیریت کنند. استفاده صحیح از حافظه داینامیک باعث بهینهسازی عملکرد برنامهها و جلوگیری از مشکلاتی مانند نشت حافظه میشود.
برای اطلاعات بیشتر، میتوانید از سایت saeidsafaei.ir و اسلایدهای محمد سعید صفایی بهرهبرداری کنید.
در این مبحث، به معرفی انواع دستورالعملهای شرطی پرداخته میشود و در راستای آن، عملگرهای منطقی بهطور کامل مورد بررسی قرار میگیرند. همچنین، با مفاهیمی مانند بلوک دستورالعمل، ارزیابی میانبری و تله سقوط آشنا میشویم. در نهایت، انواع کلمات کلیدی در برنامهنویسی معرفی شده و کاربردهای آنها توضیح داده میشود. هدف این جلسه، تقویت درک شرطها و نحوه استفاده صحیح از آنها در نوشتن برنامههای کاربردی است.
پهپادهای خودمختار به وسایل نقلیه هوایی بدون سرنشین اطلاق میشود که قادر به انجام وظایف خودکار مانند نقشهبرداری و نظارت هستند.
پروتکلی ترکیبی از Distance Vector و Link State که از معیارهای مختلف برای انتخاب بهترین مسیر استفاده میکند.
فلوچارت نمایشی گرافیکی از فرایندهای یک الگوریتم است که به کمک آن میتوان دستورات و مراحل مختلف را به شکل تصویری سادهتری نمایش داد.
محاسبات بیولوژیکی به استفاده از فرآیندهای زیستی برای پردازش دادهها و ذخیرهسازی اطلاعات اشاره دارد.
محاسبات نوری به استفاده از فناوریهای نوری برای پردازش دادهها به جای روشهای الکترونیکی سنتی اشاره دارد.
کدگذاری عصبی مصنوعی به استفاده از مدلهای یادگیری عمیق برای شبیهسازی و بهبود عملکرد شبکههای عصبی انسانها اطلاق میشود.
اینترنت همهچیز (IoE) به شبکهای از اشیاء، دستگاهها، افراد و دادهها اطلاق میشود که به هم متصل و با هم تعامل دارند.
امنیت سایبری به مجموعهای از روشها و تکنیکها اطلاق میشود که برای محافظت از سیستمها، شبکهها و دادهها در برابر تهدیدات دیجیتال به کار میروند.
پروتکلی مشابه با OSPF که برای مسیریابی در لایه ۲ مدل OSI طراحی شده است.
علم اعصاب شناختی به مطالعه نحوه عملکرد مغز و سیستمهای عصبی در پردازش اطلاعات و تصمیمگیری اطلاق میشود.
چرخه ساعت معادل یک واحد زمانی است که پردازنده برای انجام عملیاتهای مختلف نیاز دارد.
معاملهگری الگوریتمی به استفاده از الگوریتمها برای انجام معاملات مالی با استفاده از دادههای تاریخی و پیشبینی روندها اطلاق میشود.
حلقه do-while مشابه با while است، با این تفاوت که ابتدا دستورالعملها اجرا میشود و سپس شرط بررسی میشود. بنابراین این حلقه حداقل یک بار اجرا میشود.
دیسکهای مغناطیسی که معمولاً به عنوان حافظههای ثانویه (مثل هارد دیسکها) برای ذخیرهسازی دائمی دادهها استفاده میشوند.
پروتکلی که برای شبکههای سیسکو طراحی شده است و از معیارهای مختلف مانند پهنای باند و تأخیر برای انتخاب بهترین مسیر استفاده میکند.
کشف دادههای افزوده به فرآیند تجزیه و تحلیل و استخراج الگوهای جدید از دادههای موجود به کمک هوش مصنوعی گفته میشود.
کانکتور مخصوص کابلهای تلفن که برای کابلهای UTP CAT-1 استفاده میشود.
مقیاسپذیری بلاکچین به ظرفیت شبکههای بلاکچین برای پردازش تعداد زیادی تراکنش بدون کاهش کارایی اشاره دارد.
برنامهنویسی کوانتومی به استفاده از اصول فیزیک کوانتومی برای توسعه برنامههایی گفته میشود که میتوانند مسائل پیچیده را سریعتر از برنامههای کلاسیک حل کنند.
اتوماسیون فرآیند دیجیتال به استفاده از نرمافزارهای خودکار برای انجام فرآیندهای تجاری و صنعتی اشاره دارد.
ویژگیای که مسیرهای یاد گرفته شده از یک رابط را با متریک بینهایت به همان رابط ارسال میکند تا از حلقههای مسیریابی جلوگیری شود.
پیامهایی که به سوئیچها اجازه میدهند اطلاعات توپولوژی شبکه را با یکدیگر به اشتراک بگذارند.
هوش مصنوعی (AI) به سیستمهایی اطلاق میشود که توانایی انجام کارهایی که نیاز به هوش انسانی دارند را دارند.
شبکههای عصبی مصنوعی (ANN) به مدلهای ریاضی اشاره دارد که از ساختار مغز انسان الهام گرفتهاند و برای پردازش دادهها استفاده میشوند.
دوقلو دیجیتال به مدلسازی یک سیستم فیزیکی به صورت دیجیتال گفته میشود که به آن امکان مانیتورینگ و پیشبینی عملکرد در زمان واقعی را میدهد.
بهینهسازی یادگیری عمیق به تکنیکهایی اطلاق میشود که برای بهبود عملکرد مدلهای یادگیری عمیق به کار میروند.
دستگاهی که برای متصل کردن چندین شبکه محلی LAN به یکدیگر استفاده میشود و در لایه دادهلینک (Layer 2) عمل میکند.
توزیع کلید کوانتومی (QKD) به استفاده از اصول فیزیک کوانتومی برای تولید و توزیع کلیدهای رمزنگاری بهصورت ایمن اشاره دارد.
عبور از آرایه به معنای مراجعه به تمام عناصر آرایه به صورت پشت سر هم است تا بتوان عملیاتی بر روی آنها انجام داد.
سیگنال آنالوگ سیگنالی است که میتواند هر مقدار پیوستهای از دادهها را منتقل کند.
سیستمهای حمل و نقل هوشمند به استفاده از فناوریهای نوین برای بهبود فرآیندهای حمل و نقل و مدیریت ترافیک اطلاق میشود.
هوش مصنوعی در کشاورزی به استفاده از الگوریتمهای یادگیری ماشین و هوش مصنوعی برای بهبود فرآیندهای کشاورزی اطلاق میشود.
یکپارچگی هوش مصنوعی در پردازش ابری به استفاده از مدلهای هوش مصنوعی برای تجزیه و تحلیل دادهها در سرویسهای ابری اطلاق میشود.
کابلهای زوج به هم تابیده با غلاف فلزی برای کاهش تداخل الکترومغناطیسی.
توزیع بار ترافیکی به طور یکنواخت بین منابع مختلف برای جلوگیری از ازدحام در یک مسیر خاص.