<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0">
    <channel>
        <title>نوشته های امین پایدار</title>
        <link>https://virgool.io/feed/@aminpaydar</link>
        <description>Software Engineer at BaleMessenger</description>
        <language>fa</language>
        <pubDate>2026-06-16 17:46:29</pubDate>
        <image>
            <url>https://files.virgool.io/upload/users/7695/avatar/cCGHTm.png?height=120&amp;width=120</url>
            <title>امین پایدار</title>
            <link>https://virgool.io/@aminpaydar</link>
        </image>

                    <item>
                <title>در رو پشت سرمون قفل کنیم یا پیغام بگذاریم ؟</title>
                <link>https://virgool.io/@aminpaydar/%D8%AF%D8%B1-%D8%B1%D9%88-%D9%BE%D8%B4%D8%AA-%D8%B3%D8%B1%D9%85%D9%88%D9%86-%D9%82%D9%81%D9%84-%DA%A9%D9%86%DB%8C%D9%85-%DB%8C%D8%A7-%D9%BE%DB%8C%D8%BA%D8%A7%D9%85-%D8%A8%DA%AF%D8%B0%D8%A7%D8%B1%DB%8C%D9%85-op68bl5mjfhh</link>
                <description>برنامه‌‌هایی که در کد‌هایشان موازی‌سازی دارند مشکل مشترکی دارند. حالا بیاید ببینیم این مشکل چیه.برنامه‌ی شما از یک بخش حافظه استفاده می‌کند. وقتی که برنامه‌ی شما از یک نخ استفاده کند هیچ مشکلی ندارید چرا که در هر زمان فقط یک نخ منتظر حافظه می‌شود؛اما وقتی که چند نخ بخواهند از حافظه استفاده کنند ممکن است تغییرات هم‌دیگر در حافظه را دوباره‌نویسی کنند.برای حل این مشکل سه روش پیش رو دارید:قفل‌هامدل اکتورحافظه تراکنشی نرم‌افزاردر ادامه به توضیح هر یک از این راه‌حل ها می‌پردازیم.قفل‌هابا استفاده از قفل‌ها مانع اجرای یک تکه از کد توسط چند نخ به‌صورت هم‌زمان می‌شویم.نخی که وارد بخش بحرانی می‌شود آن را قفل می‌کند و نخ دیگر نمی‌تواند وارد بخش بحرانی شود، زمانی که نخ اول کارش تمام شود قفل را باز می‌کند و نخ دوم وارد آن می‌شود.مدل اکتورطراح مدل اکتور آقای Carl Hewitt است که ایده‌ی مدل اکتور را از نظریه‌ی نسبیت عام و مکانیک کوانتومی گرفته‌است. در این مدل، هر اکتور حالت درونی خود را دارد و تنها را ارتباط با یک اکتور فرستادن پیام به آن است. اکتور‌ها برای اینکه از حالت هم‌دیگر باخبر شوند و یا حالت درونی یکدیگر را تغییر دهند، با فرستادن پیام اینکار را انجام می‌دهند.در مدل اکتور:اکتور‌ها به هیچ‌وجه حالت درونی خود را به اشتراک نمی‌گذارد؛ به همین دلیل نیازی به دعوا سر قفل برای دسترسی به داده‌ی اشتراکی نیست.اکتور‌ها بلاک نمی‌شوند به همین دلیل هیچ وقت بن‌بست نخواهیم داشت.اکتورها بین نخ‌های مختلف به اشتراک گذاشته نمی‌شوند، پس همیشه یک نخ به حالت درونی اکتور دسترسی دارد.وقتی که پیامی به یک اکتور فرستاده می‌شود وارد جعبه‌ی پیام‌هایش می‌رود و اکتور یک‌به‌یک و به ترتیب عمل مورد نظر را انجام می‌دهد.حافظه تراکنشی نرم‌افزار (Software Transactional Memory)استفاده از STM بسیار ساده‌است و جایگزینی برای قفل‌ها می‌باشد. ایده‌ی STM شبیه تراکنش‌های پایگاه‌داده است.در زبان‌های مختلف پیاده‌سازی های مختلفی از STM وجود دارد که در این لینک لیستی از آنها وجود دارد. نحوه‌ی کار به این شکل است:متغیر‌ها را از جنس TVar تعریف می‌کنیم. برای به‌روز رسانی مقدار متغیر از writeTVar و برای خواندش از readTVar استفاده می‌کنیم.وقتی که TVar روی یک نخی ایجاد می‌شود، یک لاگ تراکنش برای آن نخ ایجاد می‌شود.۲. وقتی writeTVar با مقداری جدید فراخوانی می‌شود، آدرس TVar و مقدار جدیدش در لاگ تراکنش نوشته می‌شود.۳. وقتی readTVar فراخوانی می‌شود، ابتدا سراغ لاگ تراکنش می‌رود تا آخرین مقداری که با استفاده از writeTVar برای نوشتن در متغیر به لاگ اضافه شده‌است را بیابد، درصورتی که چیزی پیدا نکند سراغ خود TVar رفته و مقدار خود آن را برداشته سپس آدرس TVar و مقدارش در لاگ اضافه می‌شود.وقتی اجرای بلاک‌های اتمیک توسط هر نخ تمام شود باید لاگ‌ها معتبر شوند. این معتبرسازی به‌صورت زیر انجام می‌شود:هر‌یک از readTVar های موجود در لاگ‌ها را چک می‌کنیم که مقدار برگردانده‌شده با مقدار واقعی درون TVar یکسان باشد اگر یکسان باشد معتبرسازی با موفقیت تمام می‌شود و مقدار جدید از لاگ تراکنش به درون TVar ریخته می‌شود.اگر معتبر سازی با موفقیت انجام نشود، لاگ تراکنش حذف شده و بلاک اتمیک دوباره از ابتدا اجرا می‌شود.نتیجه‌گیریقفلهادر اکثر زبان‌ها وجود داردبه شما ابزار کنترل دقیق رو کدتان را می‌دهداستفاده از آن سخت استممکن است کدتان دچار بن‌بست یا قحطی(starvation) شودمدل اکتورحالت اشتراکی وجود ندارد، درنتیجه thread-safe بودن مثل آب خوردن استقفلی وجود ندارد، در‌نتیجه بن‌بستی وجود نداردتمام آنچه که کد شما نیاز دارد اکتور و فرستادن پیام است، درنتیجه احتمالا نیاز به تغییر معماری کدتان داشته باشیدحافظه تراکنشی نرم‌افزاراستفاده از آن ساده است. اگر در حال حاضر از قفل‌ها استفاده کرده اید مهاجرت به STM ساده استقفلی وجود ندارد، در‌نتیجه بن‌بستی وجود نداردبرگرفته از پست زیر http://adit.io/posts/2013-05-15-Locks,-Actors,-And-STM-In-Pictures.html </description>
                <category>امین پایدار</category>
                <author>امین پایدار</author>
                <pubDate>Fri, 19 Oct 2018 21:54:38 +0330</pubDate>
            </item>
            </channel>
</rss>