مدل انتقال دادهها به صورت سلولهای کوچک با اندازه ثابت برای ارائه کیفیت سرویس مناسب در شبکههای چندرسانهای.
دستکاری رشتهها (String Manipulation) به فرآیندهایی اطلاق میشود که بر روی دادههای متنی (رشتهها) انجام میشود تا آنها را تغییر داده، تجزیه یا تحلیل کند. دستکاری رشتهها در برنامهنویسی یکی از کاربردیترین و رایجترین عملیاتها است که میتواند شامل عملیاتهایی مانند تغییر طول رشته، جستجو در داخل رشته، جایگزینی بخشی از رشته و تقسیم رشته به بخشهای کوچکتر باشد.
در زبانهای مختلف برنامهنویسی مانند Python، Java و C++، ابزارهای مختلفی برای انجام دستکاری رشتهها وجود دارد. در اینجا به برخی از مهمترین و رایجترین عملیاتهای دستکاری رشتهها پرداخته میشود:
در زبان Python، دستکاری رشتهها بسیار ساده و کاربردی است. در اینجا چند نمونه از عملیاتهای مختلف دستکاری رشتهها در Python آورده شده است:
# طول رشته s = "Hello, World!" length = len(s) # محاسبه طول رشته print(length) # خروجی: 13 # دسترسی به کاراکترها first_char = s[0] # دسترسی به اولین کاراکتر print(first_char) # خروجی: H # جستجو در رشته position = s.find("World") # جستجو برای "World" در رشته print(position) # خروجی: 7 # جایگزینی رشته new_s = s.replace("World", "Python") # جایگزینی "World" با "Python" print(new_s) # خروجی: Hello, Python! # تقسیم رشته words = s.split(", ") # تقسیم رشته به بخشهای جداگانه print(words) # خروجی: ['Hello', 'World!'] در این مثال، از توابع و متدهای مختلف Python برای انجام عملیاتهای مختلف بر روی رشته استفاده شده است. این متدها به راحتی امکان دستکاری و پردازش رشتهها را فراهم میکنند.
در زبان Java نیز دستکاری رشتهها از طریق کلاس String انجام میشود. در اینجا یک مثال از نحوه انجام این عملیاتها در Java آورده شده است:
public class Main {
public static void main(String[] args) {
String s = "Hello, World!";
// طول رشته
int length = s.length(); // محاسبه طول رشته
System.out.println(length); // خروجی: 13
// دسترسی به کاراکترها
char firstChar = s.charAt(0); // دسترسی به اولین کاراکتر
System.out.println(firstChar); // خروجی: H
// جستجو در رشته
int position = s.indexOf("World"); // جستجو برای "World" در رشته
System.out.println(position); // خروجی: 7
// جایگزینی رشته
String newString = s.replace("World", "Java"); // جایگزینی "World" با "Java"
System.out.println(newString); // خروجی: Hello, Java!
// تقسیم رشته
String[] words = s.split(", "); // تقسیم رشته به بخشهای جداگانه
for (String word : words) {
System.out.println(word);
}
// خروجی:
// Hello
// World!
} } در اینجا، مشابه Python، از متدهای کلاس String برای انجام عملیاتهای مختلف مانند محاسبه طول رشته، دسترسی به کاراکترها، جستجو، جایگزینی و تقسیم رشته استفاده شده است.
در زبان C++ نیز میتوان از کلاس string برای دستکاری رشتهها استفاده کرد. در اینجا یک مثال از نحوه انجام این عملیاتها در C++ آورده شده است:
#include <iostream> #include <string> using namespace std; int main() {
string s = "Hello, World!";
// طول رشته
int length = s.length(); // محاسبه طول رشته
cout << length << endl; // خروجی: 13
// دسترسی به کاراکترها
char firstChar = s[0]; // دسترسی به اولین کاراکتر
cout << firstChar << endl; // خروجی: H
// جستجو در رشته
int position = s.find("World"); // جستجو برای "World" در رشته
cout << position << endl; // خروجی: 7
// جایگزینی رشته
size_t found = s.find("World");
if (found != string::npos) {
s.replace(found, 5, "C++"); // جایگزینی "World" با "C++"
}
cout << s << endl; // خروجی: Hello, C++!
// تقسیم رشته
size_t pos = 0;
string delimiter = ", ";
while ((pos = s.find(delimiter)) != string::npos) {
cout << s.substr(0, pos) << endl; // چاپ بخش اول رشته
s.erase(0, pos + delimiter.length());
}
cout << s << endl; // چاپ باقیمانده رشته
return 0; } در C++ نیز مانند Python و Java از متدهای موجود در کلاس string برای انجام دستکاری رشتهها استفاده میشود. این متدها شامل توابعی مانند length، find، replace، substr و erase هستند.
دستکاری رشتهها یکی از ضروریترین بخشهای برنامهنویسی است که در پردازش دادههای متنی، وارد کردن و خروجی دادن دادهها، و بسیاری از عملیاتهای دیگر به کار میرود. با استفاده از دستکاریهای مختلف رشته، میتوان دادههای ورودی را پردازش کرد و خروجیهای مورد نیاز را تولید کرد.
برای اطلاعات بیشتر، میتوانید از سایت saeidsafaei.ir و اسلایدهای محمد سعید صفایی بهرهبرداری کنید.
در این مبحث، به معرفی انواع دستورالعملهای شرطی پرداخته میشود و در راستای آن، عملگرهای منطقی بهطور کامل مورد بررسی قرار میگیرند. همچنین، با مفاهیمی مانند بلوک دستورالعمل، ارزیابی میانبری و تله سقوط آشنا میشویم. در نهایت، انواع کلمات کلیدی در برنامهنویسی معرفی شده و کاربردهای آنها توضیح داده میشود. هدف این جلسه، تقویت درک شرطها و نحوه استفاده صحیح از آنها در نوشتن برنامههای کاربردی است.
مدل انتقال دادهها به صورت سلولهای کوچک با اندازه ثابت برای ارائه کیفیت سرویس مناسب در شبکههای چندرسانهای.
سیستمهای ایمنی مصنوعی به سیستمهایی اطلاق میشود که از فرآیندهای مشابه سیستم ایمنی انسان برای تشخیص و مقابله با تهدیدات استفاده میکنند.
پروتکلی که برای ارتباطات شبکههای محلی (LAN) از آن استفاده میشود.
الگوریتم جستجو به فرآیند جستجو برای یافتن یک یا چند عنصر خاص در یک آرایه یا ساختار داده گفته میشود.
پردازش دادهها در زمان واقعی به تحلیل و پردازش دادهها بلافاصله پس از دریافت آنها گفته میشود، بدون نیاز به ذخیرهسازی طولانیمدت.
کد منبع کدهایی است که به زبان برنامهنویسی توسط توسعهدهندگان نوشته میشود. این کدها پس از تبدیل توسط کامپایلر به کد ماشین، قابل اجرا بر روی پردازندهها خواهند بود.
آرایه مجموعهای از دادهها است که به صورت یکپارچه ذخیره میشود و از اندیسها برای دسترسی به مقادیر مختلف آن استفاده میشود.
در این نوع توپولوژی، دستگاهها به صورت نقطهای به هم متصل میشوند و تمامی نودها با یکدیگر در ارتباط هستند.
پشته ساختار دادهای است که دادهها را به صورت FILO (First In, Last Out) ذخیره میکند. اولین داده وارد شده، آخرین دادهای است که از پشته برداشته میشود.
مرزهای IoT به دستگاههای فیزیکی در شبکههای IoT اطلاق میشود که قادر به انجام پردازش و تحلیل دادهها در لبه شبکه هستند.
روش دسترسی به رسانه که در آن منابع فرکانسی بهطور ثابت بین دستگاهها تقسیم میشود.
بهینهسازی مسیرها و استفاده از منابع شبکه برای بهبود عملکرد کلی شبکه.
مفهوم VLANای که ترافیک به آن هدایت میشود اما هیچ دستگاه یا موجودیتی در آن وجود ندارد تا ترافیک را پردازش کند.
کاوش دادهها به فرآیند استخراج الگوها و اطلاعات مفید از مجموعههای بزرگ داده اشاره دارد.
ارز دیجیتال به انواع ارزهای مبتنی بر فناوری بلاکچین گفته میشود که بهطور دیجیتال ذخیره و منتقل میشوند.
برنامهنویسی کوانتومی به استفاده از اصول فیزیک کوانتومی برای توسعه برنامههایی گفته میشود که میتوانند مسائل پیچیده را سریعتر از برنامههای کلاسیک حل کنند.
آزادسازی حافظه به فرآیند آزاد کردن حافظه اختصاصیافته به برنامه یا دادهها پس از پایان استفاده از آنها اطلاق میشود.
روشهای انتقال داده از یک دستگاه به دستگاه دیگر شامل Simplex، Half-Duplex و Full-Duplex.
روش دسترسی به رسانه که در آن زمانبندی برای تقسیم دسترسی به رسانه بین دستگاهها استفاده میشود، هر دستگاه یک بازه زمانی برای ارسال داده دارد.
رایانههای کوچک که میتوانند تعداد کمی از کاربران را به صورت همزمان پشتیبانی کنند و به طور معمول در شرکتها و سازمانهای متوسط استفاده میشوند.
میزان دادهای که در واحد زمان توسط یک دستگاه فیزیکی قابل ارسال یا دریافت باشد، معمولاً بر حسب بیت بر ثانیه (bps) اندازهگیری میشود.
قسمت صحیح یک عدد که بدون هیچ نقطه اعشاری است. این قسمت معمولاً در تبدیلهای مبنای مختلف ابتدا محاسبه میشود.
در فلوچارت، مرحله تصمیمگیری به لوزی گفته میشود که در آن بر اساس شرایط خاص، الگوریتم مسیر متفاوتی را انتخاب میکند.
پروتکلی که ترکیبی از ویژگیهای Distance Vector و Link State است و از نقاط قوت هر دو استفاده میکند.
GraphQL یک زبان پرسوجو است که برای دریافت دادهها از یک API استفاده میشود و در مقایسه با REST، انعطافپذیری بیشتری دارد.
کلاس در برنامهنویسی شیگرا قالبی است که برای ایجاد اشیاء استفاده میشود. هر کلاس میتواند ویژگیها و متدهایی را تعریف کند.
یک کیلوبایت معادل 1024 بایت است و به عنوان واحدی برای اندازهگیری دادههای کم حجم استفاده میشود.
لایهای که مسئول انتقال دادهها در یک شبکه محلی و اطمینان از انتقال بدون خطاست.
توابع ساختهشده توسط کاربر توابعی هستند که برنامهنویسان برای انجام کارهای خاص خود میسازند. این توابع میتوانند به صورت مجزا از برنامه فراخوانی شوند.
الگوریتم مرتبسازی حبابی سادهترین الگوریتم مرتبسازی است که عناصر مجاور را مقایسه کرده و در صورت لزوم جابهجا میکند.
عملگرهایی هستند که برای انجام عملیات منطقی مانند AND, OR, NOT و XOR بر روی دادهها به کار میروند.
الگوریتم مرتبسازی سریع یک الگوریتم تقسیم و غلبه است که عنصر مرجعی را انتخاب کرده و آرایه را به دو بخش مرتب تقسیم میکند.
روش دسترسی به رسانه که در آن یک توکن بهصورت مداوم در شبکه میان دستگاهها جابهجا میشود و تنها دستگاهی که توکن را در اختیار دارد میتواند داده ارسال کند.
فاکتوریل یک عدد n با ضرب آن در تمام اعداد صحیح مثبت کوچکتر از خودش تعریف میشود. این مقادیر بهطور معمول برای محاسبات ریاضی یا بازگشتی استفاده میشوند.
شبکهای که از سنسورهای بیسیمی تشکیل میشود که میتوان آنها را حمل کرده یا درون لباس تعبیه کرد.