پروتکلی در لایه 2 برای جلوگیری از حلقههای شبکهای و مدیریت مسیرهای انتقال دادهها.
حافظه داینامیک (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 و اسلایدهای محمد سعید صفایی بهرهبرداری کنید.
در این مبحث، به معرفی انواع دستورالعملهای شرطی پرداخته میشود و در راستای آن، عملگرهای منطقی بهطور کامل مورد بررسی قرار میگیرند. همچنین، با مفاهیمی مانند بلوک دستورالعمل، ارزیابی میانبری و تله سقوط آشنا میشویم. در نهایت، انواع کلمات کلیدی در برنامهنویسی معرفی شده و کاربردهای آنها توضیح داده میشود. هدف این جلسه، تقویت درک شرطها و نحوه استفاده صحیح از آنها در نوشتن برنامههای کاربردی است.
پروتکلی در لایه 2 برای جلوگیری از حلقههای شبکهای و مدیریت مسیرهای انتقال دادهها.
سیستمهایی هستند که قادرند دادهها را پردازش کرده و بر اساس آنها تصمیمگیری نمایند، به گونهای که شبیه به تفکر انسان عمل میکنند.
مجموعهای از دادهها است که به صورت ساختار یافته ذخیره شده و به راحتی میتوان به آنها دسترسی داشت.
سیستمهای اتوماسیون هوشمند به استفاده از هوش مصنوعی برای انجام فرآیندهای خودکار و بهینهسازی سیستمها اطلاق میشود.
جدول هش یک ساختار دادهای است که برای ذخیره دادهها بر اساس کلیدها و انجام عملیات جستجو سریع طراحی شده است.
پایگاههای داده گراف به پایگاههای دادهای اطلاق میشود که برای ذخیره و مدیریت اطلاعات در قالب گرافها طراحی شدهاند.
نویز ناشی از تداخل سیگنالهای رادیویی از منابع مختلف مانند فرستندههای رادیویی و تلویزیونی.
حافظه کش یک نوع حافظه سریع است که برای نگهداری دادههای پرکاربرد و دستورالعملهایی که به طور مکرر استفاده میشوند، طراحی شده است. دسترسی به کش سریعتر از حافظه اصلی است.
نرخ بیت متغیر که در آن نرخ انتقال دادهها بسته به نیاز و پیچیدگی دادهها تغییر میکند.
سیستمهای تحویل خودران به وسایل نقلیه و رباتهایی اطلاق میشود که بهطور خودکار کالاها را به مقصد ارسال میکنند.
ورودیهایی که به عنوان بخشی از خروجیهای قبلی سیستم وارد میشوند و تاثیر زیادی بر بهبود یا اصلاح فرآیندهای سیستم دارند.
هوش مصنوعی در مراقبتهای بهداشتی به استفاده از الگوریتمها و مدلهای هوش مصنوعی برای بهبود خدمات پزشکی و پیشبینی بیماریها اطلاق میشود.
واحد پردازش گرافیکی است که برای انجام محاسبات پیچیده گرافیکی و پردازش دادههای بصری به کار میرود.
عبور از آرایه به معنای مراجعه به تمام عناصر آرایه به صورت پشت سر هم است تا بتوان عملیاتی بر روی آنها انجام داد.
دستگاه ساده در شبکه که دادهها را بدون توجه به آدرس مقصد به تمام دستگاههای متصل ارسال میکند.
امنیت بیومتریک به استفاده از ویژگیهای بیولوژیکی برای احراز هویت افراد و محافظت از دادهها اشاره دارد.
سیستم اولیه ورودی و خروجی است که وظیفه بوت کردن سیستم را به عهده دارد و مراحل ابتدایی راهاندازی سیستم را کنترل میکند.
محاسبات با عملکرد بالا به استفاده از قدرت پردازشی پیشرفته برای حل مسائل پیچیده و پردازش دادههای بسیار بزرگ اطلاق میشود.
این نوع رمزگذاری به شما امکان میدهد که دادههای رمزنگاریشده را بدون نیاز به رمزگشایی پردازش کنید. این تکنیک برای حفظ حریم خصوصی و امنیت دادهها در هنگام پردازش بسیار مهم است.
پروتکلی مشابه با OSPF که برای مسیریابی در لایه ۲ مدل OSI طراحی شده است.
سیگنالی که به صورت پیوسته تغییر میکند و معمولاً به صورت موج سینوسی نمایش داده میشود.
دیسکهای مغناطیسی که معمولاً به عنوان حافظههای ثانویه (مثل هارد دیسکها) برای ذخیرهسازی دائمی دادهها استفاده میشوند.
بلاکچین 2.0 به نسخهای پیشرفته از بلاکچین گفته میشود که ویژگیهایی مانند قراردادهای هوشمند و مقیاسپذیری بهتر را ارائه میدهد.
مدلسازی سهبعدی به فرآیند ایجاد مدلهای دیجیتالی از اشیاء یا محیطها با استفاده از نرمافزارهای کامپیوتری اطلاق میشود.
فاکتوریل یک عدد n با ضرب آن در تمام اعداد صحیح مثبت کوچکتر از خودش تعریف میشود. این مقادیر بهطور معمول برای محاسبات ریاضی یا بازگشتی استفاده میشوند.
آدرس فیزیکی هر دستگاه در شبکه که برای شناسایی آن در لایه دسترسی شبکه استفاده میشود.
توزیع بار ترافیکی به طور یکنواخت بین منابع مختلف برای جلوگیری از ازدحام در یک مسیر خاص.
ساختارهایی در برنامهنویسی هستند که به برنامه اجازه میدهند که یک مجموعه از دستورات را بارها و بارها اجرا کنند تا زمانی که یک شرط خاص برآورده شود.
استاندارد شبکههای بیسیم (Wi-Fi) که پروتکلهای ارتباط بیسیم در باندهای مختلف فرکانسی را تعریف میکند.
فناوری پوشیدنی به دستگاههایی اطلاق میشود که به کاربران امکان میدهند تا بهطور پیوسته دادهها را جمعآوری و تجزیه و تحلیل کنند.
اتصالاتی با پهنای باند بالا که میتوانند حجم زیادی از داده را به سرعت بالا منتقل کنند.
توکنهای بلاکچین به واحدهای دیجیتالی اطلاق میشود که در شبکههای بلاکچین برای انجام تراکنشها و ذخیرهسازی دادهها استفاده میشوند.
عملیات صف شامل عملیاتهای مختلفی مانند درج دادهها در انتهای صف و حذف دادهها از ابتدای صف است.
مرکز کنترل شبکه که مسئول مدیریت و تخصیص منابع در شبکه است، بهویژه در روشهای دسترسی پویا مانند DDMA.
در این توپولوژی، انتقال اطلاعات در لحظه فقط در یک جهت انجام میشود. هر نود شبکه به یک کابل متصل است.