تور لحظه آخری
امروز : جمعه ، 23 شهریور 1403    احادیث و روایات:  پیامبر اکرم (ص):داناترين مردم كسى است كه دانش ديگران را به دانش خود بيفزايد.
سرگرمی سبک زندگی سینما و تلویزیون فرهنگ و هنر پزشکی و سلامت اجتماع و خانواده تصویری دین و اندیشه ورزش اقتصادی سیاسی حوادث علم و فناوری سایتهای دانلود گوناگون شرکت ها




آمار وبسایت

 تعداد کل بازدیدها : 1815307345




هواشناسی

نرخ طلا سکه و  ارز

قیمت خودرو

فال حافظ

تعبیر خواب

فال انبیاء

متن قرآن



اضافه به علاقمنديها ارسال اين مطلب به دوستان آرشيو تمام مطالب
archive  refresh

چگونگي پياده‌سازي بافرها


واضح آرشیو وب فارسی:سایت ریسک: sasan81629-01-2010, 12:59 PMhttp://www.jamejamonline.ir/Media/images/1388/11/04/100865620754.jpg انباره‌هاي داده همانند ‌malloc‌ در++ ‌C‌ عمل مي‌كنند و مي‌توان به‌صورت كاملا ديناميك داده‌ها را در حافظه ذخيره كرد و به آنها فضا تخصيص داد. از آنجايي كه استفاده از اين انباره‌هاي داده، به‌دليل رخ دادن پراكندگي ‌(Fragmentation)‌ بسيار كند مي‌شود، از اين رو در دنياي واقعي نمي‌شود از آنها استفاده كرد. چرا كه انباره‌هاي داده مقدار خود را در هر لحظه از كاربر مي‌گيرند و اندازه هر بلاك آنها با يكديگر متفاوت است. ‌ ‌ براي اين‌كه بشود از اين قابليت مهم و مفيد استفاده كرد، بايد يك ظرف ثابت تعريف كرد كه بلاك‌هاي حافظه را از پيش تعريف كرده باشد و در كنار هم در حافظه قرار داده باشد. بدين ترتيب، عمل تخصيص، استفاده، و آزادسازي داده‌ها را بايد در لايه برنامه‌نويسي انجام دهيم. ‌ ‌ پياده‌سازي يك ماژول ساده انباره داده مي‌تواند 3 انبار داده را در زمان كامپايل به‌خود اختصاص دهد، اين انباره‌ها داده را مي‌توان با كمك توابع فرضي زير پياده كرد: ‌ ‌ براي تخصيص فضا: MemPoolHandle allocateMemory ‌(size_t bytes);‌ براي دسترسي به يك خانه از انباره: ‌ ‌ ‌void * getPointer(MemPoolHandle h);‌ براي آزادسازي حافظه: ‌void freeMemory(MemPoolHandle h);‌ وقتي يك برنامه مي‌نويسيد، مشخص نمي‌شود كه برنامه چه‌مقدار حافظه به‌خود اختصاص مي‌دهد. بنابراين طول يك آرايه كه از مجموعه‌اي از ‌Structure‌ها تشكيل شده است، تا زمان اجراي برنامه و تخصيص حافظه پويا، مشخص نخواهد شد. در ‌C++‌ براي تخصيص حافظه از عملگري به‌نام ‌new‌ استفاده مي‌كنيم. و در صورتي كه بخواهيم يك مكان حافظه را حذف كنيم، از ‌delete‌ استفاده مي‌كنيم. ويژگي‌هاي انباره داده تخصيص حافظه در انباره‌هاي داده زمان ثابتي دارد. آزادكردن حافظه براي هزاران شيء در انباره داده، تنها يك عمليات به‌حساب مي‌آيد. اما در صورتي كه از ‌malloc‌ استفاده شود، بايد تك‌تك خانه‌ها را سوا كرد. سوم اين‌كه انباره‌هاي داده مي‌توانند به‌صورت ساختار درختي مرتبط شوند، بنابراين براي ساختارهاي خاص برنامه‌نويسي چون حلقه‌ها و توابع بازگشتي كاربرد زيادي خواهند داشت. از طرف ديگر، بهتر است انباره‌هاي داده را براي كاربرد مناسب در هر برنامه، بهينه كرد. وظايفي همچون تخصيص حافظه كافي براي استفاده، رهگيري و كنترل تخصيص‌ها، آزادسازي حافظه وقتي نيازي به متغير نيست، وظايف پيچيده‌اي هستند. اگر در اين وظايف كوتاهي شود، احتمال زيادي وجود دارد كه برنامه زير فشار كاملا خرد شود و يا در حالت بدتر، به بقيه سيستم هم آسيب برساند. انباره داده، يعني شيوه ديگري به‌جز ‌malloc()‌ و عدم استفاده مستقيم از سيستم عامل براي تخصيص حافظه. ‌ ‌ انباره‌ها به‌طور خودكار اندازه خود را افزايش مي‌دهند تا نيازهاي برنامه را رفع كنند و هر بار مقدار بيشتري حافظه دريافت مي‌كنند. اين اتفاق تا زماني مي‌افتد كه ديگر حافظه در دسترس براي سيستم وجود نداشته باشد. البته، اين پايان ماجرا نيست. انباره‌هاي داده در صورتي كه كنترل شوند، مي‌توانند با فراخواني توابع، تميز و نابود شوند. چنين توابعي به‌برنامه‌نويسان اجازه مي‌دهد بي‌دغدغه و با فراخواني يك دو جين تابع، كليه نيازهاي حافظه‌اي خود را با انباره‌هاي داده برطرف كنند و بعد از استفاده آن را تميز كنند. همانطور كه گفتيم، انباره‌هاي داده، ساختاري سلسله مراتبي هم دارند. بدين ترتيب مي‌توان براي هر انباره داده، تعدادي زيرانباره‌‌(Subpool)‌ نيز تعريف كرد. ‌ ‌از اين ويژگي مي‌توان در هنگام خالي كردن تمام زيرانباره‌ها استفاده كرد كه با خالي كردن انباره والد، تمام زيرانباره‌ها نيز خالي مي‌شوند. ‌ ‌ انباره‌هاي داده براي مديريت پايه حافظه بسيار مفيد است، ساختار انباره داده در سناريوي توابع بازگشتي و حلقه‌ها نقش مهمي دارد. هرچند كه ممكن است انباره‌هاي داده براي همه برنامه‌هايي كه مي‌نويسيد ايده‌آل نباشد. همچنين استفاده از انباره داده نياز به زمان دارد تا ويژگي‌ها و ضعف‌هاي آن را بشناسيد. توجه داشته باشيد كه رفع ايراد در برنامه‌هايي كه حافظه زيادي مصرف مي‌كنند، دشوارتر است. اميربهاالدين سبط‌الشيخ سایت ما را در گوگل محبوب کنید با کلیک روی دکمه ای که در سمت چپ این منو با عنوان +1 قرار داده شده شما به این سایت مهر تأیید میزنید و به دوستانتان در صفحه جستجوی گوگل دیدن این سایت را پیشنهاد میکنید که این امر خود باعث افزایش رتبه سایت در گوگل میشود




این صفحه را در گوگل محبوب کنید

[ارسال شده از: سایت ریسک]
[مشاهده در: www.ri3k.eu]
[تعداد بازديد از اين مطلب: 271]

bt

اضافه شدن مطلب/حذف مطلب




-


گوناگون

پربازدیدترینها
طراحی وب>


صفحه اول | تمام مطالب | RSS | ارتباط با ما
1390© تمامی حقوق این سایت متعلق به سایت واضح می باشد.
این سایت در ستاد ساماندهی وزارت فرهنگ و ارشاد اسلامی ثبت شده است و پیرو قوانین جمهوری اسلامی ایران می باشد. لطفا در صورت برخورد با مطالب و صفحات خلاف قوانین در سایت آن را به ما اطلاع دهید
پایگاه خبری واضح کاری از شرکت طراحی سایت اینتن