1 / 244

فصل اول

ساختار فایل ها (ذخیره و بازیابی اطلاعات) تهیه کننده : جعفر پورامینی منبع: سیستم و ساختار فایل مولف: زولیک تعداد واحد:3 www.darage1web.gigfa.com. فصل اول. آشنایی با طراحی و مشخصات ساختار فایل ها. هدف کتاب.

baruch
Download Presentation

فصل اول

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. ساختار فایل ها (ذخیره و بازیابی اطلاعات)تهیه کننده : جعفر پورامینی منبع: سیستم و ساختار فایل مولف: زولیکتعداد واحد:3www.darage1web.gigfa.com

  2. فصل اول آشنایی با طراحی و مشخصات ساختار فایل ها

  3. هدف کتاب • یافتن راههایی برای به حداقل رساندن دستیابی به دیسک، برای فایل هایی است که اندازه و محتویات آنها تغییر می کند. • ساختار فایل ترکیبی از نحوه نمایش داده ها در فایل ها و عملیات لازم برای دستیابی به داده ها است • در حالت ایده آل، کسب اطلاعات مورد نظر با یک دسترسی • در صورتی که امکان پذیر نیست با حداقل دسترسی • به حداکثر رساندن احتمال وجود اطلاعات مورد نظر در حافظه

  4. عوامل موثر در طراحی ساختار فایل • شرایط خاص دیسک ها این الزام را به وجود می آورد که ساختارهای ویژه ای برای ذخیره و بازیابی داده در آنها توسعه دهیم تا در حد امکان مشکل های کار با دیسک را کاهش دهیم • زمان دستیابی نسبتا کم دیسک ها • ظرفیت بالای آنها • حفظ اطلاعات پس از قطع جریان برق

  5. تاریخچه مختصری درباره طراحی ساختار فایل • دستیابی ترتیبی (فایل ها بر روی نوار) (مرتبه زمانی n) • درخت دودویی AVL (مرتبه زمانی log d) • درخت B • درخت B+:ترکیب درخت B و لیست پیوندی • دستیابی مستقیم

  6. کیت ابزار مفهومی: مواد ساختار فایل • ابزارهایی که برای حل مشکلات مشابه بکار گرفته می شوند • بافرها، بلوکها و باکتها: کاهش تعداد دستیابی به دیسک

  7. فصل دوم عملیات مهم پردازش فایل

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

  9. باز کردن فایل ها معرفی تابع OPEN FD=OPEN(FILENAME,FLAGS[,PMODE]) • FD:توصیف کننده فایل. • FILENAME:یک رشته کاراکتری حاوی نام فایل فیزیکی. • FLAGS:عملکرد تابع OPEN را کنترل کرده وتععیین می کند که فایل موجود را برای خواندن یا نوشتن باز می کند یا خیر. • PMODE:حالت محافظت فایل را بر می گرداند.

  10. بستن فایل ها • هنگامی که برنامه ای به صورت عادی پایان می یابد، فایل ها معمولا به طور خودکار بسته می شوند. • در نتیجه اجرای یک دستور بستن در داخل برنامه فقط برای محافظت آن در برابر اتلاف داده ها در صورت توقف برنامه و آزاد کردن نام فایل های منطقی برای استفاده مجدد می باشد.

  11. خواندن و نوشتن READ(SOURCE_FILE,DESTINATION_ADDR,SIZE) WRITE(DESTINATION_FILE,SOURCE_ADDR,SIZE) • DESTINATION: نام فایل مقصد • SOURCE: نام فایل منبع • SIZE: تعداد بایتهایی که باید خوانده یا نوشته شود

  12. پیگرد: عمل انتقال مستقیم به یک موقعیت معین در فایل را پیگرد می گویند. SEEK(SOURCE_FILE,OFFSET) SOURCE_FILE:نام فایل منطقی که در آن جستجو صورت می گیرد OFFSET:میزان حرکت اشاره گر فایل را مشخص می کند

  13. پیگرد با جریان های C POS=FSEEK(FILE,BYTE_OFFSET,ORIGIN) POS: یک مقدار صحیح بزرگ که توسط FSEEK بر گردانده می شود که برابر با موقعیت فعلی اشاره گر است. FILE: توصیف کننده فایلی که FSEEK باید در آن اعمال شود. BYTE_OFFSET: تعداد بایتهایی که باید از مبدا حرکت داده شود.

  14. برنامه نمایش محتویات با استفاده از جریان #INCLUDE<STDIO.H> Main( ) { Char ch ; FILE *file ; Char filename [20] ; Printf (" enter the name of the file") ; //step 1 Gets (filename) ; //step 2 File = fopen (filename, "r") ; //step 3 While (fread(&ch, 1, 1, file) ! = 0) ; //step 4a Fwrite (&ch, 1, 1, student) ; //step 4b Fclose (file) ; //step 5 }

  15. برنامه نمایش محتویات با استفاده از کلاسهای جریان ++ C: #include <fsream.h> main ( ) { char ch ; fstream file ; char file name [20] ; cout << "enter the name of the file: "; //step 1 cin >> filename; //step 2 file . open (filename,ios::in); //step 3 file . unsetf(ios::skipws); while (1) { file >> ch; //step 4a if (file.fail ()) break; cout << ch; //step 4b } file . close (); //step 5 }

  16. ساختار فهرست ها در یونیکس چون هر نام فایل در سیستم یونیکس بخشی از سیستم فایلی است که با ریشه آغاز می شود هر فایل را می توان انحصارا با دادن نام مسیر آن شناسایی کرد. هنگامی که فرمانهایی برای سیستم یونیکس صادر می شود این کار در داخل فهرستی انجام می شود که فهرست جاری نامیده می شود.

  17. نمونهای از فهرست ها در یونیکس BIN USR USR6 DEV BIN LIB ADDBCC KBD TAPE YACC MYDIR LIB CONSOLE LIBS.A LIBM.A ADDF DF

  18. دستگاههای فیزیکی و فایل های منطقی • در یونیکس، فایل مجموعهای از بایتها است • در یونیکس چگونگی و محل ذخیره فایل ها مهم نیست • در یونیکس مهم نیست که فایل ها از کجا می آیند • در یونیکس شکل فیزیکی فایل مهم نیست زیرا نمای منطقی فایل در یونیکس یکی است.

  19. فصل سوم حافظه جانبی و نرم افزار سیستم

  20. تعريف حافظه • هر دستگاهي که بتوان اطلاعات را در آن ذخيره نموده به نحوي که کاربرد در هر لحظه بتواند به اطلاعات مورد نظرش دستيابي پيدا کند حافظه ناميده مي شود.

  21. حافظه انواع دستگاه ها از نظر نوع دستیابی • دستیابی مستقیم (DASD): از طریق آدرس می‌توان به طور مستقیم به اطلاعات دسترسی داشت. زمان دسترسی در این حالت برای تمام اطلاعات تقریبا برابر است، مانند هارد دیسک‌ها • دستیابی سری: دستگاه‌هایی که دستیابی ترتیبی را پشتیبانی می‌کنند. در این حالت برای خواندن یا نوشتن یک قطعه داده‌ی خاص، باید از تمام داده‌های پیش از آن گذر کرد

  22. دیسکها • دیسک های مغناطیسی در اشکال مختلف وجود دارند • دیسک های سخت ظرفیتی بالا با هزینه پایین به ازای هر بیت ارائه می دهند. • دیسک های فلاپی ارزان هستند ولی سرعت آنها کم است و داده های نسبتا کمی را نگهداری می کنند.

  23. انواع حافظه هاي برون ماشيني از نظر تكنولوژي ساخت • چهار تكنولوژي وجود دارد: • تكنولوژي الكترومكانيك • الكترو مغناطيس • تكنولوژي الكترو اپتيك • تكنولوژي الكترومغنااپتيك

  24. سازمان دیسک ها • یک دیسک گردان معمولا از چند صفحه تشکیل شده است، که هر صفحه دو سطح دارد • هر صفحه شامل تعدادی شیار (TRACK) است • اطلاعات در شیارهایدیسک نگهداری می شود • هر شیار غالبا به چند سکتور (SECTOR) تقسیم می شود • سکتور کوچکترین بخشی از دیسک است که قابل آدرس دهی است.

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

  26. جایگاه سیلندروهدهای خواندن ونوشتن

  27. برآورد نیازهای سرعت و ظرفیت ها • ظرفیت شیار=تعداد سکتورها *طول هر سکتور بر حسب بایت • ظرفیت سیلندر=تعداد شیار ها در هر سیلندر*ظرفیت شیار • ظرفیت دیسک=تعداد سیلندرها*ظرفیت سیلندر

  28. سازماندهی شیارها به وسیله سکتورها • سازماندهی بر اساس سکتور • سازماندهی بر اساس بلوک‌های سازماندهی شده توسط کاربر

  29. روش های سازمان دهی داده ها بر روی دیسک • بر اساس سکتور • بر اساس بلوک های تعریف شده توسط کار بر

  30. سازمان دهی سکتور ها بر روی یک شیار • سکتور ها بخش های مجاور و با اندازه ثابت از یک شیار باشند(این روش راه خوبی برای در نظر گرفتن فایل به طور منطقی است اما راه خوبی برای نگه داشتن فیزیکی سکتور ها نیست.) • فاصله گذاری میان سکتورها(یعنی بین سکتور هایی که از نظر منطقی مجاورند چند سکتور فاصله می گذارند.)

  31. شیار سکتوروگپ

  32. کلاستر: • کلاستر عبارت از تعداد ثابتی از سکتور های پیوسته است • کلاستر های بزرگ تعداد زیادی از سکتور ها را بدون پیگرد می خوانند. • استفاده از کلاستر های بزرگ در هنگام پردازش ترتیبی فایل به کارایی بیشتر منجر می شود.

  33. پراکندگی طول تمام سکتور های موجود در یک دیسک باید یکسان باشد اما همیشه این تناسب بر قرار نیست .دو شیوه برای مقابله با این روش وجود دارد: • نگهداری یک رکورد در هر سکتور. • قرار دادن رکورد ها به طور متوالی به طوری که بخشی از رکورد در یک سکتور و بخش دیگر آن در سکتور دیگر قرار گیرد.

  34. سازمان دهی شیار ها به کمک بلوک • گاهی شیار ها به سکتور تقسیم نمی شوند بلکه به تعدادی از بلوک ها تقسیم می شوند. • همانند سکتور ها بلوکها را غالبا رکورد های فیزیکی می دانند. • سازمان دهی بلوکها مشکلات پوشایی سکتورها و پراکندگی را ندارد.

  35. زمان دستیابی به دیسک دستیابی به دیسک را می توان به سه عمل فیزیکی متمایز تقسیم کرد: • زمان پیگرد • تاخیر چرخشی • زمان انتقال

  36. تاخیر چرخشی زمان پیگرد

  37. زمان پیگرد • زمان لازم برای انتقال بازوی دستیابی به سیلندر مناسب را زمان پیگرد می گویند

  38. تاخیر چرخشی • زمان لازم برای چرخش دیسک تا سکتور مورد نظر زیر هد خواندن و نوشتن قرار گیرد.

  39. زمان انتقال زمان انتقال از فرمول زیر بدست می آید: زمان انتقال=(تعداد بایت های انتقال یافته/تعداد بایت های روی شیار)*زمان چرخش

  40. تنگنای دیسک راههای مقابله با تنگنای دیسک: • چند بر نامه ای (multiprogramming) • نوار بندی (striping) • موازی گرایی(parallelism)

  41. سازمان دهی داده ها در نوار ها • چون دستیابی به نوار ها به صورت ترتیبی است برای تشخیص موقعیت داده ها نیازی به آدرس نیست

  42. مقايسه اي از برخي سيستمهاي نواري

  43. نوار 7شیاره(A) 9شیاره(B)

  44. بيت توازن • بيت توازن بخشی از داده ها نيست. بلکه براي بررسي اعتبار داده ها به کار مي رود. اگر از توازن فرد استفاده شود اين بيت در کادرهاي فرد برابر 1 قرار داده مي شود. توازن روج نيز به همین صورت عمل مي کند. ولي در نوارها به ندرت از آن استفاده مي شود.

  45. در نوار دو نوع بيت توازن وجود دارد: • بيت پاريتي عرضي يا کاراکتري • بيت پاريتي طولي • بيت پاريتي عرضي براي هرکاراکتر و بيت پاريتي طولي، براي تعدادي کاراکتر ايجاد مي شود.

  46. نوار گردان ها اختلاف کارایی در میان نوار گردان ها را بر حسب سه کمیت می توان سنجید: • تراکم نوار • سرعت نوار • اندازه شکاف بین بلاک ها

  47. براورد طول نوار مورد نیاز طول فیزیکی یک بلوک از داده ها=b طول شکاف بین بلا ک ها=g تعداد بلاک های داده ها=n

  48. فصای لازم برای نگهداری فایل :s S=n*(b+g)

  49. اندازه بلوک / تراکم نوار=b طول بلوک=b

More Related