مفهوم ماشین حالت : دیدگاهی متفاوت در کدنویسی

blog
۱۳۹۶-۰۵-۰۲
5 دقیقه

هر برنامه‌نویس پیش از اینکه نوشتن برنامه را آغاز کند اگر بتواند دیاگرام مسئله شامل ورودی‌ها و حالت‌های موردانتظار را مشخص کند در برنامه‌نویسی موفق‌تر خواهد بود.

حتی اگر بتوان این نوع تفکر را در ساختار کدنویسی خود وارد کنیم می‌توانیم بسیاری از اشکالات برنامه‌نویسی خود را برطرف کنیم و برنامه‌ای با سطح خوانایی بالا داشته باشیم.

در این پست قصد داریم به مفهوم ماشین حالت و کاربرد آن در برنامه‌نویسی بپردازیم.

یکی از مشکلات برنامه‌نویسان ایجاد حلقه‌های بی‌نهایت در برنامه است. برای نمونه وجود تعداد زیادی وقفه و دستورات شرطی در برنامه ممکن است احتمال چنین خطایی را افزایش دهد.

گفتنی است حلقه بی‌نهایت دنباله‌ای از دستورالعمل‌ها در یک برنامه است که به شکل نامحدودی تکرار می‌شود یا به این دلیل که شرطی برای پایان یافتن حلقه تعیین نشده، یا اگر تعیین شده، طوری است که آن شرایط هیچگاه اتفاق نمی‌افتد.

حلقه‌های بی‌نهایت باعث می‌شوند تا برنامه کل زمان در دسترس پردازنده را مصرف کند، اما معمولاً کاربر می‌تواند آنها را از بین ببرد. یکی از دلایلی که می‌تواند باعث هنگ کردن سیستم شود همین حلقه‌های بی‌نهایت هستند.

یکی از روش‌های معمول برای رهایی از این خطا به کارگیری تایمرها و یا watchdog برای ریست سیستم است اما این روش به از دست رفتن داده یا رفتارهای ناخواسته‌ی برنامه منجر می‌شود.

از کاربردهای ماشین حالت می‌توان جلوگیری از اشکالات برنامه‌نویسی، آسان‌تر کردن اشکال‌زدایی برنامه و متوقف کردن حلقه‌های بی‌نهایت را نام برد.

از سوی دیگر معمولا برنامه‌های پیچیده و عملی در طول اجرا از تعدادی حالت مختلف عبور می‌کنند. توصیف رفتار برنامه به عنوان ماشین حالت بسیار مفید است و برنامه را ساده‌تر می‌کند.

با مفهوم ماشین حالت شما می‌توانید برنامه‌های پیچیده‌ را به صورت منطقی و با خوانایی بالا بنویسید. ممکن است در ابتدا ماشین حالت را پیچیده بدانیم یا کاربرد آن را به موارد خاص محدود کنیم اما قصد داریم برتری نوشتن برنامه بر اساس مفهوم ماشین حالت را بیان کنیم.

در این مقاله روش‌های مختلف پیاده‌سازی ماشین حالت در برنامه را دنبال خواهیم کرد.

ماشین حالت – Finite state machines

ماشین حالت، یک ابزار ریاضی برای توصیف پردازش توسط یک ماشین است و نحوه‌ی واکنش ماشین به رویدادهای مختلف را بیان می‌کند. ماشین حالت را می‌توان مدلی تشکیل شده از حالت‌ها (State)، رویدادها ، انتقال‌ها، اعمال و شرط‌ها دانست.

یک رویداد (Event)، اتفاقی است که به ماشین حالت اعمال می‌شود و به آن ورودی‌ ماشین (Input) نیز گفته می‌شود.

نحوه‌ی‌ رفتار ماشین حالت به رویدادی خاص را انتقال (Transition) می‌نامند. در یک انتقال، مشخص می‌شود که ماشین حالت بر اساس حالت جاری خود، با دریافت یک رویداد، چه عکس العملی را باید بروز دهد.

در طی یک انتقال، ماشین از یک حالت به حالتی دیگر منتقل خواهد شد.

گاهی نیاز است پیش از انجام عکس‌العمل، شرطی بررسی شده و سپس انتقال رخ دهد، به این شرط، guard یا منطق شرطی (Conditional Logic) گفته می‌شود. در صورت درست بودن شرط، انتقال انجام می‌گیرد.

یک عمل(action) بیانگر نحوه پاسخگویی ماشین حالت در طول دوره انتقال است.

Finite state machines

نمودار حالت

نمودار حالت نوعی دیاگرام برای تشریح و توضیح رفتار سیستم است.

این نمودار مجموعه‌ای از رویدادها را که در حالات مختلف و ممکن یک سیستم رخ می‌دهد تجزیه و تحلیل می‌کند. در نمودار حالت، کلیه حالات یک ماشین در نظر گرفته می‌شود.

نمودار حالت در واقع شکل بصری جدول حالت یک ماشین یا مدار منطقی است و به وسیله آن دید بهتری را می‌توان نسبت به سیستم به دست آورد.

برنامه‌ی ساده زمان‌سنج دیجیتالی را در نظر بگیرید که دارای دو حالت آغاز زمان و پایان زمان است. در تصویر زیر نمودار ماشین حالت این برنامه را مشاهده می‌کنید.

آشنایی با مفهوم ماشین حالت

1) توصیف رفتار ماشین حالت با دستورات شرطی

رایج‌ترین روش پیاده‌سازی ماشین حالت در برنامه‌نویسی C، نوشتن منطق برنامه با دستورات شرطی switch-case و if-else است. در برنامه‌ای که در ادامه آورده شده با دستورات شرطی switch-case، حالات و رویدادهای برنامه‌ی زمان‌سنج در نظر گرفته شده است. در ابتدا حالت‌ها و رویدادها را تعریف می‌کنیم. اگر رویدادی رخ دهد حالت کنونی بررسی می‌شود و با توجه به رویداد، حالت تغییر می‌کند و یک عمل اجرا می‌شود.

مزایای دستورات شرطی : برنامه ساده و قابل فهم است.

معایب دستورات شرطی: برنامه با دستورات شرطی مقیاس‌پذیر نیست یعنی برای تعداد حالت‌های بیشتر عملی و کارآمد نخواهد بود. اگر در برنامه‌های دارای تعداد زیاد حالت از این روش استفاده کنیم کد برنامه طولانی خواهد شد و در صورت تغییر در بخشی از برنامه، تغییر کد بسیار مشکل است. در این نحوه‌ی نوشتن کد، میان اجزای ماشین حالت مانند حالت‌ها و رویدادها و عمل‌ها تفکیک واضحی وجود ندارد و در نتیجه دارای خوانایی کمی خواهد بود.

2) توصیف رفتار برنامه با جدول انتقال حالت

آشنایی با مفهوم ماشین حالت : دیدگاهی نو برای کدنویسی

جدول انتقال حالت زمان سنج

مزایای جدول انتقال حالت: استفاده از جدول انتقال حالت به جای دستورات شرطی، باعث مقیاس پذیری برنامه می‌شود یعنی گسترش برنامه به تعداد حالت‌های بیشتر امکان‌پذیر است و کد برنامه خوانایی بالاتری دارد چراکه از یک جدول انتقال برای تعریف ماشین حالت استفاده می‌شود. بر خلاف دستورات شرطی از ساختارهای تکراری استفاده نمی‌شود. هنگام تغییر برنامه یا اضافه‌کردن حالت بیشتر به برنامه تنها جدول انتقال تغییر می‌کند.

3) تفکیک حالت‌ها در توابع

در کدی که ارائه می‌شود هر عمل (action) در یک تابع تعریف شده و برنامه به صورت تفکیک شده است.

اطلاعات
5
0
لینک و اشتراک
profile

Khatereh Akbari

متخصص الکترونیک

مقالات بیشتر
slide

پالت | بازار خرید و فروش قطعات الکترونیک

قطعات اضافه و بدون استفاده همیشه یکی از سرباره‌‌های شرکتها و طراحان حوزه برق و الکترونیک بوده و هست. پالت سامانه‌ای است که بصورت تخصصی اجازه خرید و فروش قطعات مازاد الکترونیک را فراهم می‌کند. فروش در پالت
family

آیسی | موتور جستجوی قطعات الکترونیک

سامانه آی سی سیسوگ (Isee) قابلیتی جدید و کاربردی از سیسوگ است. در این سامانه سعی شده است که جستجو، انتخاب و خرید مناسب تر قطعات برای کاربران تسهیل شود. وقتی شما در این سامانه، قطعه الکترونیکی را جستجو می‌کنید؛ آی سی به سرعت نتایج جستجوی شما در اکثر فروشگاه‌های آنلاین در حوزه قطعات الکترونیک را نمایش می‌دهد. جستجو در آیسی
family

فروشگاه سیسوگ

فروشگاه سیسوگ مجموعه ای متمرکز بر تکنولوژی های مبتنی بر IOT و ماژول های M2M نظیر GSM، GPS، LTE، NB-IOT، WiFi، BT و ... جایی که با تعامل فنی و سازنده، بهترین راهکارها انتخاب می شوند. برو به فروشگاه سیسوگ
family

سیسوگ فروم | محلی برای پاسخ پرسش‌های شما

دغدغه همیشگی فعالان تخصصی هر حوزه وجود بستری برای گفتگو و پرسش و پاسخ است. سیسوگ فروم یک انجمن آنلاین است که بصورت تخصصی امکان بحث، گفتگو و پرسش و پاسخ در حوزه الکترونیک را فراهم می‌کند. پرسش در سیسوگ فرم
become a writer

نویسنده شو !

سیسوگ با افتخار فضایی برای اشتراک گذاری دانش شماست. برای ما مقاله بنویسید.

ارسال مقاله
become a writer

نویسنده شو !

سیسوگ با افتخار فضایی برای اشتراک گذاری دانش شماست. برای ما مقاله بنویسید.

ارسال مقاله
خانواده سیسوگ

پالت | بازار خرید و فروش قطعات الکترونیک

قطعات اضافه و بدون استفاده همیشه یکی از سرباره‌‌های شرکتها و طراحان حوزه برق و الکترونیک بوده و هست. پالت سامانه‌ای است که بصورت تخصصی اجازه خرید و فروش قطعات مازاد الکترونیک را فراهم می‌کند.
family

آیسی | موتور جستجوی قطعات الکترونیک

سامانه آی سی سیسوگ (Isee) قابلیتی جدید و کاربردی از سیسوگ است. در این سامانه سعی شده است که جستجو، انتخاب و خرید مناسب تر قطعات برای کاربران تسهیل شود. وقتی شما در این سامانه، قطعه الکترونیکی را جستجو می‌کنید؛ آی سی به سرعت نتایج جستجوی شما در اکثر فروشگاه‌های آنلاین در حوزه قطعات الکترونیک را نمایش می‌دهد.
family

فروشگاه سیسوگ

فروشگاه سیسوگ مجموعه ای متمرکز بر تکنولوژی های مبتنی بر IOT و ماژول های M2M نظیر GSM، GPS، LTE، NB-IOT، WiFi، BT و ... جایی که با تعامل فنی و سازنده، بهترین راهکارها انتخاب می شوند.
family

سیسوگ فروم | محلی برای پاسخ پرسش‌های شما

دغدغه همیشگی فعالان تخصصی هر حوزه وجود بستری برای گفتگو و پرسش و پاسخ است. سیسوگ فروم یک انجمن آنلاین است که بصورت تخصصی امکان بحث، گفتگو و پرسش و پاسخ در حوزه الکترونیک را فراهم می‌کند.
family

دیدگاه ها

profile
پارسا گفت :
۱۴۰۰-۰۶-۲۳ ۲۰:۱۳

بی زحمت ی مثال کامل از روش دوم با avr قرار بدید که بتونیم بفهمیم چیه دقیقا

profile
حسین گفت :
۱۳۹۹-۰۸-۲۳ ۲۰:۱۱

سلام.
مطلب خوبی بود .
ولی معایب جدول انتقال حالت رو نفرمودید .
علی القاعده باید از منابع سیستم بیشتر استفاده کنه …

profile
مهدی گفت :
۱۳۹۹-۰۷-۱۰ ۰۰:۳۴

سلام تشکر بابت مطالب خوبتون عالیه
لطفا ادامه بدید
درضمن لطفا روحساب اینکه همه بلدند توضیح ندید
یکم بیشتر جامع تر و بامثال بیشتر ..
من حالت اول رو بلد بودم اما حالت دوم جالب بود اما بد نبود مثال دقیق تر و کاربردی تر(یعنی در مین اصلی استفاده شده )ی ارائه میدادید
جاداره ادامش بدید

profile
مهدی گفت :
۱۳۹۸-۱۲-۱۳ ۲۱:۵۶

سلام وقت به خیر ممنون از مطلب جالب
من کمی با مثالی که برای حالت جدولی آوردید مشکل دارم. تابع main برنامه کجاست و توابع action و start و stop کجا فراخوانی می شوند؟ اگر در یک وضعیتی بخواهیم یک وظیفه را به صورت ادامه دار انجام دهیم – مانند چک کردن وضعیت یک کلید ورودی – اون قسمت از کد باید کجا بیاد؟
ممنون

profile
زئوس Zeus گفت :
۱۳۹۸-۱۲-۲۴ ۱۰:۰۵

خوب این یه شبح برنامه است و برنامه کامل نیست که این جزییات رو داشته باشه :/

become a writer

نویسنده شو !

سیسوگ با افتخار فضایی برای اشتراک گذاری دانش شماست. برای ما مقاله بنویسید.

ارسال مقاله
become a writer

نویسنده شو !

سیسوگ با افتخار فضایی برای اشتراک گذاری دانش شماست. برای ما مقاله بنویسید.

ارسال مقاله