From Wikipedia, the free encyclopedia
در علم رایانه و برنامهنویسی، تایپ یا نوع داده، یک ویژگی داده است که به کامپایلر یا مترجم اطلاع میدهد چگونه برنامهنویس قصد دارد از دادهها استفاده کند. اکثر زبانهای برنامهنویسی از انواع دادههای اصلی اعداد صحیح (با اندازههای مختلف)، اعداد شناور (که تقریبا تمام اعداد واقعی است)، کاراکترها و اعداد بولین پشتیبانی میکنند. نوع داده مقادیری را که ممکن است یک عبارت (شامل متغیر یا عملگر) داشته باشد، محدود میکند. این نوع داده، عملیاتی را که میتوان بر روی دادهها، معنای دادهها و نحوه ذخیره مقادیر آن نوع انجام داد، تعریف میکند. نوع داده مجموعه ای از مقادیر را فراهم میکند که یک عبارت (به عنوان مثال متغیر، عملگر و غیره) میتواند مقادیر آن را بهدست آورد.
این مقاله نیازمند ویکیسازی است. لطفاً با توجه به راهنمای ویرایش و شیوهنامه، محتوای آن را بهبود بخشید. (آوریل ۲۰۱۳) |
انواع دادهای در سیستمهای نوع استفاده میشوند، که روشهای مختلفی برای تعریف، اجرای و استفاده از آنها ارائه میدهند. سیستمهای مختلف، درجههای مختلفی از ایمنی را تضمین میکنند.
تقریباً تمام زبانهای برنامهنویسی حاوی مفهوم نوع داده میباشند، هرچند زبانهای مختلف ممکن است از اصطلاحات مختلف استفاده کنند.
انواع دادههای متداول عبارتند از:
اعداد صحیح (integer)
اعداد شناور (Floating-point)
کاراکتر (Character)
رشته (string)
بولین (Boolean)
به عنوان مثال، در زبان برنامهنویسی جاوا، نوع int مجموعه ای از اعداد صحیح ۳۲ بیتی را نشان میدهد که از ۲۱۴۷۴۸۳۶۴۸- تا هستند ۲۱۴۷۴۸۳۶۴۷و همچنین عملیاتی که میتوان در اعداد صحیح انجام داد مانند جمع، تفریق و ضرب را شامل میشود. از طرف دیگر، ممکن است یک رنگ توسط سه بایت نشان داده شود که مقدار هر یک از رنگهای قرمز، سبز و آبی و یک رشته (string) که نمایشگر اسم آن رنگ است را نشان میدهد.
اکثر زبانهای برنامهنویسی اجازهٔ تعریف انواع دادههای اضافی را به برنامهنویس میدهند این کار معمولاً با ترکیب تایپهای متعدد و تعریف عملیات معتبر مربوط به نوع داده جدید صورت میگیرد. برای مثال، یک برنامهنویس ممکن است یک نوع داده جدید به نام "عدد مختلط" که شامل قسمت حقیقی و موهومی میباشد را ایجاد کند. نوع دادهها نیز نشان دهنده یک محدودیت برای تفسیر دادهها در یک سیستم انواع است، برای مثال:تعریف نمایش، تفسیر و ساختار ارزشها یا اشیاء ذخیره شده در حافظه کامپیوتر. سیستم انواع از انواع داده به منظور بررسی صحت برنامههای کامپیوتر و همچنین تغییر دادهها استفاده میکند. بسیاری از انواع دادهها -همانطور که در جدول زیر نشان داده شده است-در آمار مشابه تایپ دادهها در برنامهنویسی کامپیوتر و بالعکس است.
برنامهنویسی کامپیوتر | آمار |
---|---|
اعداد شناور (Floating-point) | دارای ارزش واقعی (مقیاس فاصله)
دارای ارزش واقعی (مقیاس نسبت) |
اعداد صحیح (integer) | شمارش دادهها (معمولاً غیر منفی) |
بولین (Boolean) | دادههای باینری (دودویی) |
نوع شمارشی داده(enumerated type) | دادههای طبقهبندی شده |
لیست یا آرایه | vector (بردار) تصادفی |
آرایه دو بعدی | ماتریس تصادفی |
درخت | درخت تصادفی |
(۱۹۷۶ Parnas , Shore & Weiss) پنج تعریف از «نوع» را که در بعضی مواقع بهطور ضمنی در ادبیات رایانه ای استفاده میشد، مشخص کردند. انواع که شامل رفتار داده می با شد بیشتر در راستای مدلهای شی گراست، در حالی که یک مدل برنامهنویسی ساختار یافته تمایل دارد کد را شامل نشود، و مدل داده قدیمی ساده نامیده میشود. پنج نوع عبارتند از:
نحوی
یک نوع یک برچسب صرفاً نحوی است که با متغیر مرتبط است. چنین تعاریفی از «نوع» معنای محتوایی به انواع نمیدهد.
نشانگر
یک نوع توسط انواع سادهتر تعریف میشود که معمولاً انواع ماشینی هستند.
نشانگر و رفتار
یک نوع با نشانگر آن و مجموعه ای از اپراتورهای دستکاری شده در این نشانگرها تعریف میشود.
فضای ارزشی
نوع مجموعه ای از مقادیر ممکن است که یک متغیر میتواند در اختیار داشته باشد. چنین تعاریفی اجازه میدهد در مورد انواع اعداد دکارتی صحبت کنیم.
فضای ارزشی و رفتار
یک نوع مجموعه ای از مقادیر است که یک متغیر میتواند در اختیار داشته باشد و مجموعه ای از توابع است که میتوان از آنها برای این مقادیر استفاده کرد.
تعریف نوع در محیط نشانگر مانند الگول و پاسکال اغلب به صورت دستوری بوده، در حالی که این تعریف در زبانهای سطح بالاتر مانند Simula و CLU به شکل فضای ارزشی و رفتار استفاده میشد.
انواع داده اولیه
انواع دادههای اولیه معمولاً نوعهایی هستند که در داخل زبان از پیش آماده یا ابه زبانی اصلی هستند.
انواع داده ماشین
کلیه دادههای رایانه ای بر اساس الکترونیک دیجیتال و به عنوان بیت (گزینههای ۰ و ۱) در پایینترین سطح نمایش داده میشود. کوچکترین واحد آدرس پذیر معمولاً گروهی از بیتها به نام بایت (معمولاً یک هشت رقمی است که ۸ بیت است) است. واحد پردازش شده توسط دستورالعملهای کد ماشین یک کلمه (بهطور معمول ۳۲ یا ۶۴ بیت) خوانده میشود. اکثر دستورالعملها این کلمه را به عنوان یک عدد باینری تفسیر میکنند، به گونه ای که یک کلمه ۳۲ بیتی میتواند مقادیر عدد صحیح علامت زده شده را از صفر تا یا مقادیر عدد صحیح از تا را دارا باشد.
به دلیل وجود دو علامت مکمل، زبان ماشین و ماشین بین این نوع دادههای تخصیص یافته و نیافته تفکیک انجام نمیدهند.
اعداد شناور مورد استفاده در ریاضیات شناور از تفسیر متفاوت بیتها در یک کلمه استفاده میکنند. برای توضیحات بیشتر ممیز شناور را مشاهده کنید.
انواع دادههای دستگاه باید در سیستمها یا زبانهای برنامهنویسی سطح پایین در دسترس قرار بگیرند و امکان کنترل دقیق سختافزار را فراهم آورند. به عنوان مثال، زبان برنامهنویسی C انواع اعداد صحیح با پهنای متفاوت ازجمله کوتاه(short) و بلند(long) را ایجاد میکند. اگر یک نوع دادهٔ اصلی در ساختار مقصد وجود نداشته باشد، کامپایلر آنها را به کدهای دارای انواع موجود تجزیه میکند. به عنوان مثال، اگر یک عدد صحیح ۳۲ بیتی در یک سکوی ۱۶ بیتی درخواست شود، کامپایلر بهطور ضمنی با آن به عنوان آرایه ای از دو عدد صحیح ۱۶ بیتی رفتار خواهد کرد.
در برنامهنویسی سطح بالاتر، انواع دادههای ماشین اغلب پنهان میباشند تا به عنوان وسیله ای برای جایگزین کردن کدهای کم دسترس تر مورد استفاده قرار بگیرند. به عنوان مثال، یک نوع عددی عادی ممکن است به جای عدد صحیح برخی از پهنای بیتهای خاص ایجاد شود.
نوع بولین
نوع بولین مقدار درست و نادرست را نشان میدهد. اگرچه فقط دو مقدار ممکن است، برای کارایی بیشتر به ندرت از این نوع بهعنوان یک رقم باینری واحد استفاده میشود.
بسیاری از زبانهای برنامهنویسی از نوع بولین برخوردار نیستند، درعوض تفسیر (به عنوان مثال) ۰ به عنوان نادرست و سایر مقادیر به عنوان درست هستند. دادههای بولین به ساختار منطقی نحوه تفسیر زبان به زبان ماشین اشاره دارد. در این حالت، یک بولین ۰ به منطق نادرست اشاره دارد. منطق درست همیشه غیر صفر است، به خصوص موردی که به بولین۱ معروف است.
انواع عددی
مانند:
انواع کامپوزیت
انواع کامپوزیت از بیش از یک نوع ابتدایی بهدست میآیند. برای رسیدن به آن روشهای مختلفی استفاده میشود. روشهای ترکیب آنها ساختمان دادهها نامیده میشوند. ترکیب یک نوع ابتدایی در یک نوع ترکیبی-تکمیلی بهطور کل به یک نوع جدید منجر میشود، به عنوان مثال آرایهٔ اعداد صحیح نوع دیگری از عدد صحیح است.
انواع دیگری نیز ممکن است، اما آنها تمایل به تغییر و ترکیب متفاوتی دارند. به عنوان مثال یک لیست پیوندی میتواند دادههای مشابه آرایه را ذخیره کند، اما دسترسی متوالی را به جای تصادفی فراهم میکند و از رکوردهای موجود در حافظه پویا تشکیل میشود.
انواع شمارشی
نوع شمارشی مقادیر مشخصی دارد که قابل مقایسه و اختصاص دهی است، اما لزوماً هیچ گونه نمایشگر مشخصی در حافظه کامپیوتر ندارد. کامپایلرها و مفسرها میتوانند خود نماینده آنها باشند. به عنوان مثال، چهار علامت موجود در یکدسته ورق بازی ممکن است چهار شمارشگر به نامهای خاج، خشت، دل و پیک باشد که متعلق به یک نوع شمارشی به نام طرح هستند. اگر متغیر V بهطور مثال این نوع داده را داشته باشد، میتوان هریک از چهار مقدار را به آن اختصاص داد. برخی از روشها به برنامه نویسان این امکان را میدهد که مقادیر عدد صحیح را به نوع شمارش اختصاص دهند، یا با آنها همانند عدد صحیح رفتار کنند.
انواع رشتهها و متنها
مانند:
انواع کاراکترها و رشتهها میتوانند توالی کاراکترها را از یک مجموعه کاراکتر مانند ASCII ذخیره کنند. از آنجا که بیشتر مجموعه کاراکترها رقمها را شامل میشوند، میتوان رشته عددیی مانند "۱۲۳۴" را در اختیار داشت. هر چند، بسیاری از زبانها این رشته عددی را متعلق به نوع دیگری با مقدار عددی ۱۲۳۴ میدانند.
انواع کاراکترها و رشتهها با توجه عرض کاراکتر مورد نیاز میتوانند دارای زیرگروههای مختلف باشند. ASCII ابا عرض ۷ بیت از انواع محدود کننده بود و توسط مجموعههای ۸ و ۱۶ بیتی جایگزین شد، که میتواند طیف گستردهای از الفبای غیر لاتین (مانند عبری و چینی) و سایر نمادها را رمزگذاری کنند. حتی در یک زبان برنامهنویسی مشابه با دیگری رشتهها ممکن است متغیر بر اساس اندازه یا به اندازه ثابت باشند. آنها همچنین ممکن است در سایز حداکثر خود قرار بگیرند.
توجه: رشتهها یک نوع داده اولیه در همه زبانها نیستند. به عنوان مثال، در C، آنها از یک سری کاراکترها تشکیل شدهاند.
Seamless Wikipedia browsing. On steroids.
Every time you click a link to Wikipedia, Wiktionary or Wikiquote in your browser's search results, it will show the modern Wikiwand interface.
Wikiwand extension is a five stars, simple, with minimum permission required to keep your browsing private, safe and transparent.