زبان‌های ایرانی

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






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

مهمترین زبان‌ها و گویش های ایرانی امروزی عبارتند از: فارسی (پارسی ، دری، یا تاجیکی)، مازنی، کردی، پشتو، بلوچی، لری، لکی، زازاکی، گیلکی، تالشی، تاتی و آسی

امروزه زبان‌های ایرانی بیشتر با خط‌های عربی، لاتین، و سیریلیک نوشته می‌شوند. زبان‌های ایرانی با زبان عربی و زبان‌های ترکی تاثیر متقابل بسیاری داشته‌اند.

زبان‌های ایرانی بیشتر در کشورها و مناطق ایران، افغانستان، تاجیکستان، باختر پاکستان، کردستان ترکیه، کردستان عراق، و بخش‌هایی از آسیای میانه و قفقاز روایی دارد.

سه زبان از زبان‌های ایرانی به عنوان زبان رسمی هم اکنون در چهار کشور استفاده می‌شود. این زبان‌ها عبارت اند از فارسی در ایران و تاجیکستان، فارسی و پشتو در افغانستان و کردی در عراق.

براورد می‌شود که امروزه حدود ۱۵۰ تا ۲۰۰ میلیون تن به زبان‌های ایرانی سخن بگویند. بنیاد تابستانی زبان‌شناسی (SIL International) در سال ۱۳۸۴ برآورد کرده‌است که امروزه به حدود ۸۷ گونه از زبان‌های ایرانی سخن گفته می‌شود؛ که شمار سخنوران بزرگترین این زبان‌ها به طور تخمینی عبارتند از: فارسی (۱۱۰ میلیون تن)، پشتو (۴۱ - ۶۰ میلیون تن) ، لری (۱۰ میلیون تن)،تبری و گیلکی (7 میلیون تن) ، کردی (۲۵ میلیون تن)، و بلوچی (۷ میلیون تن).






پیشینه

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

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







زبان‌های ایرانی به سه دسته تقسیم می‌شوند:

زبان‌های ایرانی باستان
زبان‌های ایرانی میانه
زبان‌های ایرانی نو (شرقی و غربی)

این دسته‌بندی مطلقاً از لحاظ زمانی نیست، بلکه از نظر زبان‌شناسی هم هست.






ایرانی باستان

زبان نیاایرانی نیای مستقیم این دسته از زبان‌های ایرانی است.

از جمله زبان‌های این دسته عبارت‌اند از زبان‌های اوستایی (که بیشتر از طریق متون اوستا به ما رسیده است)، فارسی باستان (که بیشتر از طریق کتیبه‌های هخامنشی به ما رسیده است)، سکایی باستان، و مادی (که فقط چند واژهٔ آن، آن هم از طریق چند وام‌واژه در فارسی باستان و چند واژهٔ ذکر شده در منابع یونانی به ما رسیده است).






ایرانی نو

زبان‌های ایرانی نو به دو دسته بخش می‌شوند:

شرقی
غربی

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






زبان‌های ایرانی‌تبار شرقی

نمونه زبان‌های شرقی ایرانی تبار این‌ها هستند:

پشتو
آسی
زبان‌های پامیری
پاشایی
یغنابی


زبان‌های ایرانی‌تبار غربی

زبان‌های ایرانی تبار غربی به دو گروه دسته بندی می‌شوند:

گروه شمال غربی:

این گروه شامل زبان‌ها و گویشهای آذری باستان، تفرشی، خوانساری، آرانی، بیدگُلی، گَزی، دری زرتشتی، سیوندی ، تبری ( مازندرانی )، کردی، گیلکی ، تالشی ، زازا-گورانی، پارتی، ، سمنانی، تاتی و بلوچی می‌باشد.

گروه جنوب غربی:

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






رسم‌الخط
زبان‌های ایرانی دارای رسم‌الخط‌های گوناگون هستند. از جمله خط میخی (در مورد پارسی باستان)؛ خط آرامی (در مورد نخستین کتیبه‌های پارسی میانه، پارتی، سغدی، و خوارزمی)؛ دو نوع خط سریانی، سطرنجیلی (در مورد پارسی میانه، پارتی، یاختری، سغدی و فارسی نو) و نستوری (سغدی مسیحی و فارسی نو)؛ خط عبری (در مورد فارسی نو و لهجه‌های محلی)؛ خط عربی (در مورد فارسی نو، خوارزمی، کُردی، پشتو و بلوچی)؛ خط براهمی (در مورد خُتَنی، تُمْشُقی و سغدی)؛ خط یونانی (در مورد باختری)؛ خط سیریلیک (در مورد اُسِتی و تاجیکی) و خط لاتین (در مورد کُردی و اُسِتی).





زبان پارسی میانه

زبان پارسی میانه، زبان پارسیگ یا زبان پهلوی (پهلویک) نیای مستقیم زبان پارسی امروزی است. پهلوی در معنای عام و نه چندان دقیق به زبان‌ها و مخصوصا خط‌های رایج دوره‌های اشکانی و ساسانی اطلاق می‌شود و محدود به ایالات نبوده‌است. پهلوی یا پارسی میانه شکلی از زبان پارسی است که واسطهٔ مستقیم میان پارسی باستان و پارسی امروزی است. به عبارت دیگر پارسی امروزی شکل تحول‌یافته‌تر از خود زبان پارسی میانه‌است. پارسی میانه زبان ارتباطی مشترک در تمامی شاهنشاهی ساسانی بود پارسی میانه یکی از زبان‌های ایرانی است که بنا به تعریف از اوایل دوران اشکانی نخست در جنوب غربی ایران و سپس در زمان ساسانیان به عنوان زبان رسمی همه امپراطوری ایران تا صدر اسلام رواج می‌داشته‌است. خاستگاه این زبان که فرزند پارسی باستان به حساب می‌آید پارس بود. در دوران اشکانیان پارسی میانه زبانی محلی بود و از پهلوی اشکانی تأثیراتی پذیرفت تا اینکه در زمان ساسانیان زبان رسمی شاهنشاهی شد. کتیبه‌ها و اسناد ساسانیان و بسیاری از کتاب‌ها به این زبان نوشته می‌شد. با برافتادن ساسانیان و تا چند سده پس از اسلام همچنان تولید اثر به این زبان ادامه داشت. گرچه عملاً زبانی نیم‌مرده به‌شمار می‌آمد.

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

گویش مردمان گز (برخوار و میمه)،گیلان،نهاوند، بروجرد، ملایر، تویسرکان، کازرون و گیو با پارسی میانه نزدیکی دارد. این زبان همواره از دیدگاه دستوری و واژگانی با گویش‌های محلی نواحی پارس نزدیکی داشته‌است.






نام زبان

در متن‌های نوشته شده به خود زبان فارسی میانه نام این زبان Pārsīg آمده که به معنای «زبان منسوب به قوم پارس» است. این زبان رفته‌رفته و به‌طور طبیعی دگرگونی‌هایی به خود دید و در نتیجۀ این دگرگونی‌ها بعدها تبدیل به زبانی شد که پارسی یا فارسی یا پارسی دری نام داشت. تبدیل شدن خود واژهٔ پارسیگ به پارسی هم از جملهٔ همین دگرگونی‌های طبیعی زبان یادشده بوده است؛ یعنی در این فرایندِ دگرگونی -گهای پایان واژه می‌افتاده‌اند. بنابراین، در دوره‌های آغازین پس از اسلام، هم زبان فارسی میانه و هم زبان فارسی نو نزد گویشورانشان یک نام داشتند، یعنی پارسیـ(ـگ) یا فارسی (برای نمونه در نوشته‌های دانشمند پارسی نِرْیُسَنْگْ، در شاهنامه و همین‌طور در نوشته‌های عرب‌ها و ایرانیان عربی‌نویس شاهد چُنین کاربردی هستیم). از این رو، مردمانی که اکنون به زبان فارسی نو سخن می‌گفتند به دلیلی (که در پی می‌آید) به فارسی میانه یا همان پارسیگ باید نام دیگری می‌دادند تا این دو از هم بازشناخته شوند. زبان فارسی میانه را در متن‌های کهن فارسی نو پهلوی و در متن‌های کهن عربی فهلوی نامیده‌اند. قدیم‌ترین مأخذی که در آن زبان فارسی میانه پهلوی نامیده شده روایت جاحظ (متوفّی به سال ۲۵۵ هـ ق) است. بنابراین، پهلوی نامیدن زبان فارسی میانه دست‌کم از سدهٔ سوم هجری رایج بوده است. دلیل به کار رفتن اصطلاح پهلوی برای نامیدن صورت کهن زبان پارسی آن بود که در سده‌های آغازین پس از اسلام واژهٔ پهلوی دربردارندهٔ این معنی‌ها نیز شده بوده: «ایرانی (در معنای کلی واژه)» و «قدیمی (البته نه هر قدیمی، بلکه راه و رسم ایرانی قدیمی، که در در شاهنانه بیشتر به این معنی برمی‌خوریم)» حتّی این واژه هاله‌ای از معناهای گوناگونی چون «اشرافی»، «باستانی»، «باشکوه» و ... یافته بوده که بازتاب آن را در شاهنامه می‌بینیم . بنابر این، زبانی که یادآور آیین‌ها و دوره‌های کهن ایران بود به سادگی می‌توانست زبان پهلوی نامیده شود. شایان یادآوری است که پَهْلَوی، پَهْلَوانی، فَهْلَوی و یا شکل عربی‌شدهٔ آن بَهْلَوی، به زبان‌ها و قوم‌های دیگری چون گویش‌های ایرانی شمال غربی نیز گفته شده است.

اما واژهٔ پَهْلَوی در اصل به چه معنایی بوده؟ این واژه در اصل به معنای «نسبت‌داده‌شده به پَهْلَو (یا همان پارت)» است. پَهْلَو از دورهٔ هخامنشی به بعد نام یکی از استان‌های شمال شرقی ایران بوده. نام این استان در سنگ‌نوشته‌های هخامنشی -Parθava آمده است. واژهٔ -Parθava با تبدیل‌هایِ بسیار رایجِ θ به h و r به l و نیز قلب جایگاه این دو در واژه، به Pahlaw بدل شده است. در دورهٔ ساسانی زبان رایج در استان پَهْلَو (یعنی همان استان پارت) را Pahlawīg یا Pahlawānīg می‌نامیدند. به سخن دیگر، پهلوی یا پهلوانی در اصل نام زبان دیگری بوده که با زبان فارسی میانه فرق دارد و امروزه آن را در کتاب‌های زبان‌شناسانه پهلوی اشکانی یا پارتی می‌نامند.

گویا نخستین بار کارل هِرمان زالِمانْ (به روسی: Karl Germanovitsh Zaleman) نام فارسی میانه (به آلمانی: Mittelpersisch) را برای این زبان به کار برده است. امروزه هم همچنان اصطلاح‌هایی چون پهلوی ساسانی و پهلوی برای نامیدن فارسی میانه به کار می‌رود. البته منظور از پهلوی بیشتر گونهٔ خاصی از فارسی میانه‌است که در کتاب‌های زردشتی به کار رفته‌است.






پس از اسلام

با آن‌که نام زبان و خط پهلوی از دیوان‌های کارگزاران عرب در ایران برافتاد، اما خط و زبان پهلوی در میان ایرانیان غیرمسلمان و مسلمان تا حدود سده پنجم کم و بیش رواج داشت چنانکه در برخی از نواحی ایران سنگ‌نگاره‌های سازه‌ها را به خط پهلوی یا بخط کوفی و پهلوی هر دو می‌نوشتند مانند کتیبه برج لاجیم نزدیک زیراب در مازندران که از سده پنجم هجری و یک خط آن به پهلوی و خط دیگر آن به کوفی است. این برج مقبره کیا ابوالفوارس شهریار بوده و در تاریخ ۴۱۳ بنا شده‌است. برج دیگری هم نزدیک برج لاجیم است که ظاهراً در آغاز سده پنجم بنا شده و کتیبه آن به خط کوفی و پهلوی است. برج رادکان نزدیک بندرگز نیز از همین گونه برج‌های آرامگاهی و دارای دو سنگ‌نوشته کوفی و پارسی میانه است.

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

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

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






آثار پارسی میانه

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






آثار زند و پازند

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






سنگ‌نبشته‌های پارسی میانه

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

برای نمونه ۲۵ سنگ‌نوشتهٔ کوچک به خط پیوسته پهلوی در باروی شهر دربند قفقاز کشف شده بود و اخیراً باستان‌شناسان شش کتیبه دیگر به پارسی میانه نیز در آن‌جا پیدا کردند. این سی و یک کتیبه نام سنگ‌تراشان یا کسانی را ذکر می‌کند که به نوعی در کشیدن دیوار سهم داشتند.






دستور زبان
نام

نام به پارسی و پهلوی (نام) خوانده می‌شود. و از نظر دستوری پهلوی با پارسی دری اختلاف زیادی ندارد.

۱-مفرد و جمع

مفرد و جمع برای جانداران (آن) هست مانند= مرتم(مردم) مرتمان(مردمان) درخت درختان

martōm

و برای جامدات(ایها) نیز می‌باشد

Kōstak=ناحیه

Kōstakīhā= نواحی

۲- اسم جمع نیز چون اسم جمع در پارسی دری است

(اسم جمع اسمی است که در ظاهر یکی است اما شامل گروهی است)

Spāhسپاه=

۳-معرفه و نکره

علامت معرفه در نکره (ی) است که در انتهای اسم می‌آید و ای حرف همان حرفی است که در پارسی دری بنام (یای وحدت) نامیده می‌شود.

Mart = Mart-ē

۴- اسم عام و خاص هیچ تفاوتی با پارسی دری ندارد

۵- صفت فاعلی و صیغهٔ مبالغه و اسم فاعل و اسم مفعول با ریشه‌های زمان حال یا گذشته فعل و پسوند بشرح زیر ساخته می‌شود:

از ریشه زمان حال (صیغه امر) و پسوند کار

Hāmōč=آموز

Hāmōčkar=آموزگار

از صیغه امر و پسوند آک

Dān= دان

DāNāk=دانا

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

از صیغه امر و پسوند آن

RAW=رو

Rawān=روان

از صیغه امر و پسوند اندک

Zīv= زی

Zīvandak=زنده

Frōš=فروش

Frōšandak= فروشنده

از ریشه گذشته و پسوند آر

Mēnēt= اندیشید

Mēnētār= اندیشمند

که به معنی اندیشه هست در واژه هخامنش نیزدیده می‌شود Mēn جا دارد اینجا بگویم که کلمه

با پسوند ایستان

Tāp=گرم

Tāpīstān=تابستان






صفت

صفت در زبان پهلوی سه حالت دارد: مطلق، برتر، برترین

نشانهٔ صفت برتر (-تر) و صفت برترین (-توم) است.

Vočurg=بزرگ

Vočurgtar-tum =بزرگ و بزرگترین

برای ساختن صفت عالی از پسوند (ایست) استفاده می‌شود

گاهی نیز با تغییر در اصل واژه صفت عالی می‌سازند که فعلآ از آن می‌گذریم برای مقایسه دو صفت از دو حرف اضافه (کو) و (هَچ) بهره می‌برند.

Nēst ērān-štr hač xvaš-tar gēvāk-ē

نیست ایران-شتر هَچ خوشتر گیواکِ

جائی خوشتر از ایرنشهر نیست.

از اسم مانند پارسی دری صفت می‌سازند

Zar=زر

Zarrēn= زرین

صفت و موصوف و مضافٌ‌الیه نیز با واسطه (ī) بجای کسره پارسی می‌آید.

Xvarāsān ī kōstak

خواراسان(خراسان) کسته(سو سمت)

در گذشته و کلماتی مانند خواهر خوراک... خوانده می‌شد

گاهی اوقات صفت پیش از فعل بیاید در این صورت حرف اضافه می‌شود

Hu-frayān=هو فریان فریان خوب گرمایی که در تن انسان و گوسفند است






نسبت

با پسوندهای زیر نسبت ساخته می‌شود.

(Ān īh īk)

mart īh= مردی

āsōrīk=آسوری

پسوند (ایک) همانست که هنوز در واژه تاری= تاریک وجود دارد

ابری پدید نی و کوفی نی بگرفت ماه و گشت جهان تاری

و نیز همین پسوند است که در زبانهای اروپائی هنوز بر قرار است مانند دموکراتیک دموکراسی یا اتم اتمیک.

پسوند (ایه) در پارسی بصورت (ای) در آمده است و همانست که در واژه مردی دیده می‌شود.

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

Pākān ī artaxšēr= اردشیر بابکان(اردشیر پسر بابک)

این واژه در واژه‌های بسیاری بویؤه در نام شهرها و روستاها هنوز جاری است مثل گیلان یعنی محل منسوب قوم گیل.






قید

قید نیز به شیوه گونه گون ساخته می‌شود و از آنجمله‌است:

با اضافه کردن (ایها) به اسم و بعضی صفات

Dāt=قانون

Dātīhā= قانونی

این پسوند (ایها) برای ساختن قید هنوز بکار می‌رود:

یکی در واژه تنها که پیش از این به صورت تنیها بوده‌است یعنی یک تنه یا یک تنانه

دیگر در قید نزدیکیها و زودیها و دیریها نیز در زبان امروزی می‌بایست جاری باشد.نزدیکیها به معنی همین نزدیکیها و زودیها به همین زودی.......

در زبان نیشابوری نیز دو صورت دیگر از قید بر جای مانده و آن دو قید (تشنگی) و (گرسنگی) است که بصورت (توشنیا= تشنگی‌ها) گوسنیا گرسنگی‌ها) این پسوند (ایا) بجای (ایها) در کردی نیز در واژهی تنیا بمعنی هنوز جاری است که در زبان تبری بگونهٔ (تنیا در آمده‌است







با افزودن

ē n

rāst= راست

Rāstēn راستین =

ضمیر(کلمه ایست که جای فاعل می‌آید در شوند تکرار آن)

ضمایر غیر متصل

Man=من

To=تو

Oy= او

Amah= ما (ما در دزفول بصورت (آمو)، در بختیاری و لری به شکل ایما و در سنندج و سردشت و بانه بصورت (ایمه). در مهاباد و پیرانشهر به صورت (أمه)و در گیلکی وتالشی وتاتی امه و در گویش لارستانی همان اما گفته میشود)

šma & šmah= شما

ōyšān= ایشان

ضمایر متصل درست همانند پارسی است. (م ت ش......)






ضمیر نسبی

یک نوع ضمیر دیگر در زبان پهلوی هست که موارد استعمال آن نیز بسیار است و بن ضمیر را که بجای همهٔ ضمایر در موارد بسیار زیاد بکار می‌رود ضمیر نسبی نا میده می‌شود که با حرف (ای کوتاه) نشان می‌دهند می‌دانیم که در زبانهای لاتین ضمایر بر حسب قرارگیری در جمله و نوع کار برد تغییر می‌کنند

مثلآ در انگلیسی (ای) در حالت مفعولی و اضافی و ملکی بصورت (می ماین) در می‌آید.

در زبانهای پارسی باستان و اوستایی این ضمایر بصورت (اَدَم) و (اَزِم) بوده‌است و در پهلوی و اشکانی بصورت (از) بکار می‌رفته‌است.

ضمایر متصل به این حروف میچسبند:

۱-(بی –به- اگر- او-و – کا گاهیمه هنکامیکه- کو که کجا چه برای اینکه- چه- چنانچه- اوم و مرا و من- کاش وقتیکه او را- چه‌ات- اذَگ آنگاه پس از آن انگاش – به‌اش- اگرت- تاک شان تاشان تا آنها را)

در جمله‌هایی که در آینده خواهد آمد می‌بینید که ضمیر متصل باین حرف ربط چسبیده ولی اسم یا واژهای که ضمیر متعلق به آنست بصورت آزاد آمده‌است اما در اینجا به یک مثال بسنده می‌کنیم:

Hast rāst man abāg mēnīšn agar-at

هست راست من اباگ منیشن اگرَت

اگر اندیشه‌ات با من راست است

این جمله را با شعری از سعدی مقایسه می‌کنیم

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

Humta-Huxta-Xvarašta

۲-به ضمیر نسبی (ای) آن کس که – که- انکه-

Bud rāst did i-m xvamn hān

بود راست دید ای-م خوومن هان

آن خوابی که دیدم راست بود

که در این جمله ضمیر نسبی (ای) چسبیده‌است اما در جمله زبان پارسی ضمیر بعنوان شناسه به فعل دیدن چسبیده‌است.

۳-به ضمیر (کی) کدام که

ضمیر اشاره (این – آن- او)

ضمیر او جمع می‌شود ایشان

ضمایر استفهامی (کی-که- چه- چی – کدام-)

ضمایر مشترک (خود- خویش- خویشتن---که از ضمیر خویش و اسم تن می‌آید)
2:01 am
کاربرد برنامه نویسی

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





زبان‌های برنامه نویسی با غالب زبان‌های انسانی تفاوتی دارد و آن این است که نیاز به بیان دقیق تر و کامل تری دارد. هنگام استفاده از زبان‌های طبیعی برای ارتباط با دیگر انسان‌ها، نویسندگان و گویندگان می‌توانند مبهم باشند و اشتباهات کوچک داشته باشند، و همچنان انتظار داشته باشند که مخاطب آنها متوجه شده باشد. اگرچه، مجازا، رایانه‌ها "دقیقاً آنچه که به آنها گفته شده را انجام می‌دهند." و نمی‌توانند "بفهمند" که نویسنده دقیقاً چه کدی مد نظر نویسنده بوده‌است] البته امروزه برنامه‌هایی برای انجام این کار تولید شده‌اند و تلاش‌های بسیاری در این زمینه انجام شده ولی هنوز به نتیجهٔ رضایت بخشی نرسیده است[. ترکیب تعریف زبان، یک برنامه، و ورودی برنامه بطور کامل رفتار خروجی را به هنگام اجرای برنامه (در محدوده کنترل آن برنامه) مشخص می‌کند. برنامه‌های یک رایانه ممکن است در یک فرایند ناپیوسته بدون دخالت انسان اجرا شوند، یا یک کاربر ممکن است دستورات را در یک مرحله فعل و انفعال مفسر تایپ کند.در این حالت "دستور"ها همان برنامه‌ها هستند، که اجرای آنها زنجیروار به هم مرتبطند.به زبانی که برای دستور دادن به برنامه‌ای استفاده می‌شود، زبان اسکریپت می‌گویند. بسیاری از زبان‌ها کنار گذاشته شده‌اند، برای رفع نیازهای جدید جایگزین شده‌اند، با برنامه‌های دیگر ترکیب شده‌اند و در نهایت استعمال آنها متوقف شده‌است. با وجود اینکه تلاش‌هایی برای طراحی یک زبان رایانه" کامل" شده‌است که تمام اهداف را تحت پوشش قرار دهد، هیچ یک نتوانستند بطور کلی این جایگاه را پر کنند. نیاز به زبان‌های رایانه‌ای گسترده از گستردگی زمینه‌هایی که زبان‌ها استفاده می‌شوند، ناشی می‌شود:

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

یک سیر رایج در گسترش زبان‌های برنامه نویسی این است که قابلیت حل مسائلی با درجات انتزاعی بالاتری را اضافه کنند. زبان‌های برنامه نویسی اولیه به سخت‌افزار رایانه گره خورده بودند. همانطور که زبان‌های برنامه نویسی جدید گسترش پیدا کرده‌اند، ویژگی‌هایی به برنامه‌ها افزوده شده که به برنامه نویس اجازه دهد که ایده‌هایی که از ترجمه ساده به دستورات سخت‌افزار دورتر هستند نیز استفاده کند. چون برنامه نویس‌ها کمتر به پیچیدگی رایانه محدود شده‌اند، برنامه‌های آنها می‌تواند محاسبات بیشتری با تلاش کمتر از سوی برنامه نویس انجام دهند. این به آنها این امکان را می‌دهد که کارایی بیشتردر واحد زمان داشته باشند. "پردازنده‌های زبان طبیعی" به عنوان راهی برای ازبین بردن نیاز به زبان‌های اختصاصی برنامه نویسی پیشنهاد شده‌اند. هرچند، این هدف دور است و فواید آن قابل بحث است. "ادسگر دیجسترا" موافق بود که استفاده از یک زبان رسمی برای جلوگیری از مقدمه سازی ساختارهای بی معنی واجب است، و زبان برنامه نویسی طبیعی را با عنوان "احمقانه" رد کرد، "آلن پرلیس" نیز مشابها این ایده را رد کرد. مطابق با متدولوژی نامتجانس استفاده شده توسط langpop.com در سال ۲۰۰۸، ۱۲ زبان پرکاربرد عبارتند از: C, C++, C#, Java, JavaScript, Perl, PHP, Python, Ruby, Shell, SQL, and Visual Basic.



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

فرم سطحی یک زبان برنامه نویسی دستور آن نامیده می‌شود. غالب زبان‌های برنامه نویسی کاملاً متنی اند؛ و از دنبالهٔ متون شامل کلمات، اعداد، نشانگذاری، بسیار شبیه زبان نوشتاری طبیعی استفاده می‌کنند. از طرف دیگر، برنامه‌هایی نیز وجود دارند که بیشتر گرافیکی اند، و از روابط بصری بین سمبل‌ها برای مشخص کردن برنامه استفاده می‌کنند. دستور یک زبان ترکیبات ممکن سمبل‌ها برای ایجاد یک برنامهٔ درست را از نظر دستوری مشخص می‌کند. معنایی که به یک ترکیب سمبل‌ها داده می‌شود با معناشناسی اداره می‌شود(قراردادی یا نوشته شده در پیاده سازی منبع). از آنجا که اغلب زبان‌ها متنی هستند، این مقاله دستور متنی را مورد بحث قرار می‌دهد.

دستور زبان برنامه نویسی معمولاً بوسیله ترکیب عبارات معین(برای ساختار لغوی) و فرم توضیح اعمال(برای ساختار گرامری) تعریف می‌شوند. متن زیر یک گرامر ساده، به زبان lisp است: expression ::= atom | list atom ::= number | symbol number ::= [+-]?['۰'-'۹']+ symbol ::= ['A'-'Za'-'z'].* list ::= '(' expression* ')' این گرامر موارد ذیل را مشخص می‌کند:

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

"۱۲۳۴۵"، "()"، "(a b c۲۳۲ (۱))" مثال‌هایی هستند از دنباله‌های خوش فرم در این گرامر.

همه برنامه‌هایی که از لحاظ دستوری درست هستند، از نظر معنا درست نیستند. بسیاری از برنامه‌های درست دستوری، بد فرم اند، با توجه به قوانین زبان؛ و ممکن است (بسته به خصوصیات زبان و درست بودن پیاده سازی) به خطای ترجمه و یا استثنا(exception) منتج شود. در برخی موارد، چنین برنامه‌هایی ممکن است رفتار نامشخصی از خود نشان دهند. حتی اگر یک برنامه در یک زبان به خوبی بیان شده باشد، ممکن است دقیقاً مطلوب نویسنده آن نبوده باشد.

به عنوان مثال در زبان طبیعی، ممکن نیست به برخی از جملات درست از لحاظ گرامری، معنای خاصی اطلاق کرد و یا ممکن است جمله نادرست باشد:

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

این قسمت از زبان C از نظر دستوری درست است، اما دستوری را انجام می‌دهد که از نظرمعنایی تعریف نشده است(چون p یک اشاره گر خالی است، عمل p->real,p->im معنای خاصی ندارد.) complex *p = NULL; complex abs_p = sqrt (p->real * p->real + p->im * p->im);

گرامر مورد نیاز برای مشخص کردن یک زبان برنامه نویسی می‌تواند با جایگاهش در "سلسله مراتب چامسکی" طبقه بندی شود. دستور اغلب زبان‌های برنامه نویسی می‌تواند بوسیله یک گرامر نوع ۲ مشخص گردد، برای مثال، گرامرهای مستقل از متن.




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


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

یک زبان نوع گذاری شده‌است اگر مشخصات هر عملیات، نوع داده‌های قابل اجرا توسط آن را با نشان دادن نوع‌هایی که برای آنها قابل اجرا نیست، تعیین کند. برای مثال، "این متن درون گیومه قرار دارد" یک رشته‌است. در غالب زبان‌های برنامه نویسی، تقسیم یک رشته با یک عدد معنایی ندارد. در نتیجه غالب زبان‌های برنامه نویسی مدرن ممکن است اجرای این عملیات را توسط برنامه‌ها رد کنند. در برخی زبان‌ها، عبارات بی معنی ممکن است هنگام ترجمه(compile) پیدا شود(چک کننده نوع ایستا)، و توسط کامپایلر رد شود، در حالی که در سایر برنامه‌ها، هنگام اجرا پیدا شود.(چک کننده نوع دینامیک) که به استثنای در حال اجرا منتج شود(runtime exception). حالت خاص زبان‌های نوع دار زبان‌های تک نوعند. این زبان‌ها غالباً اسکریپتی و یا مارک آپ هستند، مانند rexx وSGML و فقط یک داده گونه دارند—غالباً رشته‌های کاراکتری که هم برای داده‌های عددی و هم برای داده‌های سمبلی کاربرد دارند. در مقابل، یک زبان بدون نوع گذاری، مثل اکثر زبان‌های اسمبلی، این امکان را می‌دهد که هر عملیاتی روی هر داده‌ای انجام شود، که معمولاً دنباله‌ای از بیت‌ها با طول‌های متفاوت در نظر گرفته می‌شوند. زبان‌های سطح بالا که بی نوع هستند شامل زبان‌های ساده رایانه‌ای و برخی از انواع زبان‌های نسل چهارم.

در عمل، در حالیکه تعداد بسیار کمی از دیدگاه نظریه نوع، نوع گذاری شده تلقی می‌شوند(چک کردن یا رد کردن تمام عملیات‌ها)، غالب زبان‌های امروزی درجه‌ای از نوع گذاری را فراهم می‌کنند. بسیاری از زبان‌های تولیدکننده راهی را برای گذشتن یا موقوف کردن سیستم نوع فراهم می‌کنند.



نوع گذاری ایستا و متحرک

در نوع گذاری ایستا تمام عبارات نوع‌های خود را قبل از اجرای برنامه تعیین می‌کنند(معمولاً در زمان کامپایل). برای مثال، ۱ و (۲+۲) عبارات عددی هستند؛ آنها نمی‌توانند به تابعی که نیاز به یک رشته دارد داده شوند، یا در متغیری که تعریف شده تا تاریخ را نگه دارد، ذخیره شوند.


زبان‌های نوع گذاری شده ایستا می‌توانند با مانیفست نوع گذاری شوند یا با استفاده از نوع استنباط شوند. در حالت اول، برنامه نویس بیشتر صریحاً نوع‌ها را در جایگاه‌های منتنی مشخص می‌نویسد(برای مثال، در تعریف متغیرها). در حالت دوم، کامپایلر نوع عبارات و تعریف‌ها را بر اساس متن استنباط می‌کند. غالب زبان‌های مسیر اصلی(mainstream) ایستا نوع گذاری شده، مانند C#,C++ و Java، با مانیفست نوع گذاری می‌شوند



نوع گذاری قوی و ضعیف

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

نوع گذاری قوی مانع رخ دادن مشکل فوق می‌شود. تلاش برای انجام عملیات روی نوع نادرست متغیر منجر به رخ دادن خطا می‌شود. زبان‌هایی که نوع گذاری قوی دارند غالباً با نام "نوع-امن" و یا امن شناخته می‌شوند. تمام تعاریف جایگزین برای "ضعیف نوع گذاری شده" به زبان‌ها اشاره می‌کند، مثل perl, JavaScript, C++، که اجازه تعداد زیادی تبدیل نوع داخلی را می‌دهند. در جاوااسکریپت، برای مثال، عبارت ۲*x به صورت ضمنی x را به عدد تبدیل می‌کند، و این تبدیل موفقیت آمیز خواهد بود حتی اگر x خالی، تعریف نشده، یک آرایه، و یا رشته‌ای از حروف باشد. چنین تبدیلات ضمنی غالباً مفیدند، اما خطاهای برنامه نویسی را پنهان می‌کنند.

قوی و ایستا در حال حاضر عموماً دو مفهوم متعامد فرض می‌شوند، اما استفاده در ادبیات تفاوت دارد، برخی عبارت "قوی نوع گذاری شده" را به کار می‌برند و منظورشان قوی، ایستایی نوع گذاری شده‌است، و یا، حتی گیچ کننده تر، منظورشان همان ایستایی نوع گذاری شده‌است. بنابراین C هم قوی نوع گذاری شده و هم ضعیف و ایستایی نوع گذاری شده نامیده می‌شود.



معناشناسی اجرا

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

برای مثال، معناشناسی ممکن است استراتژی را که بویسله آن عبارات ارزیابی می‌شوند را تعریف کند و یا حالتی را که ساختارهای کنترلی تحت شرایطی دستورها را اجرا می‌کنند.


کتابخانه هسته
اغلب زبان‌های برنامه نویسی یک کتابخانه هسته مرتبط دارند(گاهی اوقات "کتابخانه استاندارد" نامیده می‌شوند، مخصوصا وقتی که به عنوان قسمتی از یک زبان استاندارد ارائه شده باشد)، که به طور قراردادی توسط تمام پیاده سازی‌های زبان در دسترس قرار گرفته باشند. کتابخانه هسته معمولاً تعریف الگوریتم‌ها، داده ساختارها و مکانیزم‌های ورودی و خروجی پرکاربرد را در خود دارد. کاربران یک زبان، غالباً با کتابخانه هسته به عنوان قسمتی از آن رفتار می‌کنند، اگرچه طراحان ممکن است با آن به صورت یک مفهوم مجزا رفتار کرده باشند. بسیاری از خصوصیات زبان هسته‌ای را مشخص می‌کنند که باید در تمام پیاده سازی‌ها موجود باشند، و در زبان‌های استاندارد شده این کتابخانه هسته ممکن است نیاز باشد. بنابراین خط بین زبان و کتابخانه هسته آن از زبانی به زبان دیگر متفاوت است. درواقع، برخی زبان‌ها به گونه‌ای تعریف شده‌اند که برخی از ساختارهای دستوری بدون اشاره به کتابخانه هسته قابل استفاده نیستند. برای مثالف در جاوا، یک رشته به عنوان نمونه‌ای از کلاس “java.lang.String” تعریف شده است؛ مشابها، در سمال تاک(smalltalk) یک تابع بی نام(یک "بلاک") نمونه‌ای از کلاس BlockContext کتابخانه می‌سازد. بطور معکوس، Scheme دارای چندین زیرمجموعه مرتبط برای ایجاد سایر ماکروهای زبان می‌باشد، و در نتیجه طراحان زبان حتی این زحمت را نیز تحمل نمی‌کنند که بگویند کدام قسمت زبان به عنوان ساختارهای زبان باید پیاده سازی شوند، و کدام یک به عنوان بخشی ازکتابخانه.


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



خصوصیات

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

تعریف صریح دستور، معناشناسی ایستا، ومعناشناسی اجرای زبان. درحالیکه دستور معمولاً با یک معناشناسی قراردادی مشخص می‌شود، تعاریف معناشناسی ممکن است در زبان طبیعی نوشته شده باشند (مثل زبان C)، یا معناشناسی قراردادی(مثل StandardML ,Scheme)
توضیح رفتار یک مترجم برای زبان(مثل C,fortran). دستور و معناشناسی یک زبان باید از این توضیح استنتاج شوند، که ممکن است به زبان طبیعی یا قراردادی نوشته شود.
پیاده سازی منبع یا مدل. گاهی اوقات در زبان‌های مشخص شده(مثل: prolog,ANSI REXX).دستور و معناشناسی صریحاً در رفتار پیاده سازی مدل موجودند.


پیاده سازی

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

خروجی یک کامپایلر ممکن است با سخت‌افزار و یا برنامه‌ای به نام مفسر اجرا شود. در برخی پیاده سازی‌ها که از مفسر استفاده می‌شود، مرز مشخصی بین کامپایل و تفسیر وجود ندارد. برای مثال، برخی پیاده سازی‌های زبان برنامه نویسی بیسیک کامپایل می‌کنند و سپس کد را خط به خط اجرا می‌کنند.

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

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



تاریخچه
پیشرفت‌های اولیه

اولین زبان برنامه نویسی به قبل از رایانه‌های مدرن باز می‌گردد. قرن ۱۹ دستگاه‌های نساجی و متون نوازنده پیانو قابل برنامه نویسی داشت که امروزه به عنوان مثال‌هایی از زبان‌های برنامه نویسی با حوزه مشخص شناخته می‌شوند. با شروع قرن بیستم، پانچ کارت‌ها داده را کد گذاری کردند و پردازش مکانیکی را هدایت کردند. در دهه ۱۹۳۰ و ۱۹۴۰، صورت گرایی حساب لاندای آلونزو چرچ و ماشین تورینگ آلن تورینگ مفاهیم ریاضی بیان الگوریتم‌ها را فراهم کردند؛ حساب لاندا همچنان در طراحی زبان موثر است.

در دهه ۴۰، اولین رایانه‌های دیجیتال که توسط برق تغذیه می‌شدند ایجاد شدند. اولین زبان برنامه نویسی سطح بالا طراحی شده برای کامپیوتر پلانکالکول بود، که بین سال‌های ۱۹۴۵ و ۱۹۴۳ توسط کنراد زوس برای ز۳ آلمان طراحی شد.

کامپیوترهای اوایل ۱۹۵۰، بطور خاص ÜNIVAC ۱ و IBM ۷۰۱ از برنامه‌های زبان ماشین استفاده می‌کردند. برنامه نویسی زبان ماشین نسل اول توسط نسل دومی که زبان اسمبلی نامیده می‌شوند جایگزین شد. در سال‌های بعد دهه ۵۰، زبان برنامه نویسی اسمبلی، که برای استفاده از دستورات ماکرو تکامل یافته بود، توسط سه زبان برنامه نویسی سطح بالا دیگر: FORTRAN,LISP , COBOL مورد استفاده قرار گرفت. نسخه‌های به روز شده این برنامه‌ها همچنان مورد استفاده قرار می‌گیرند، و هر کدام قویا توسعه زبان‌های بعد را تحت تاثیر قرار دادند. در پایان دهه ۵۰ زبان algol ۶۰ معرفی شد، و بسیاری از زبان‌های برنامه نویسی بعد، با ملاحظه بسیار، از نسل algol هستند. قالب و استفاده از زبان‌های برنامه نویسی به شدت متاثر از محدودیت‌های رابط بودند.



پالایش

دوره دهه ۶۰ تا اواخر دهه ۷۰ گسترش مثال‌های عمده زبان پرکاربرد امروز را به همراه داشت. با این حال بسیاری از جنبه‌های آن بهینه سازی ایده‌های اولیه نسل سوم زبان برنامه نویسی بود:

APL برنامه نویسی آرایه‌ای را معرفی کرد و برنامه نویسی کاربردی را تحت تاثیر قرار داد.
PL/i(NPL) دراوایل دهه ۶۰ طراحی شده بود تا ایده‌های خوب فورترن و کوبول را بهم پیوند دهد.
در دهه ۶۰، Simula اولین زبانی بود که برنامه نویسی شئ گرا را پشتیبانی می‌کرد، در اواسط دهه۷۰. Smalltalk به دنبال آن به

عنوان اولین زبان کاملاً شئ گرا معرفی شد.

C بین سال‌های ۱۹۶۹ تا ۱۹۷۳ به عنوان زبان برنامه نویسی سیستمی طراحی شد و همچنان محبوب است.
Prolog، طراحی شده در ۱۹۷۲، اولین زبان برنامه نویسی منطقی بود.
در ۱۹۷۸ ML سیستم نوع چند ریخت روی لیسپ ایجاد کرد، و در زبان‌های برنامه نویسی کاربردی ایستا نوع گذاری شده پیشگام شد.

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

دهه‌های ۶۰ و ۷۰ مناقشات بسیاری روی برنامه نویسی ساخت یافته به خود دیدند، و اینکه آیا زبان‌های برنامه نویسی باید طوری طراحی شوند که آنها را پشتیبانی کنند.

"ادسگر دیکسترا" در نامه‌ای معروف در ۱۹۶۸ که در ارتباطات ACM منتشر شد، استدلال کرد که دستورgoto باید از تمام زبان‌های سطح بالا حذف شود.

در دهه‌های ۶۰ و ۷۰ توسعهٔ تکنیک‌هایی صورت گرفت که اثر یک برنامه را کاهش می‌داد و در عین حال بهره وری برنامه نویس و کاربر را بهبود بخشید. دسته کارت برای ۴GL اولیه بسیار کوچکتر از برنامهٔ هم سطح بود که با ۳GL deck نوشته شده بود.




یکپارچگی و رشد

دهه ۸۰ سال‌های یکپارچگی نسبی بود. C++ برنامه نویسی شئ گرا و برنامه نویسی سیستمی را ترکیب کرده بود. ایالات متحده ایدا(زبان برنامه نویسی سیستمی که بیشتر برای استفاده توسط پیمان کاران دفاعی بود) را استاندارد سازی کرد. در ژاپن و جاهای دیگر، هزینه‌های گزافی صرف تحقیق در مورد زبان نسل پنجم می‌شد که دارای ساختارهای برنامه نویسی منطقی بود. انجمن زبان کاربردی به سمت استانداردسازی ML و Lisp حرکت کرد. به جای ایجاد مثال‌های جدید، تمام این تلاش‌ها ایده‌هایی که در دهه‌های قبل حلق شده بودند را بهتر کرد.

یک گرایش مهم در طراحی زبان در دهه ۸۰ تمرکز بیشتر روی برنامه نویسی برای سیستم‌های بزرگ از طریق مدول‌ها، و یا واحدهای کدهای سازمانی بزرگ مقیاس بود. مدول-۲، ایدا. و ML همگی سیستم‌های مدولی برجسته‌ای را در دهه ۸۰ توسعه دادند. با وجود اینکه زبان‌های دیگر، مثل PL/i، پشتیبانی بسیار خوبی برای برنامه نویسی مدولی داشتند. سیستم‌های مدولی غالباً با ساختارهای برنامه نویسی عام همراه شده‌اند.

رشد سریع اینترنت در میانه دهه ۹۰ فرصت‌های ایجاد زبان‌های جدید را فراهم کرد. Perl، در اصل یک ابزار نوشتن یونیکس بود که اولین بار در سال ۱۹۸۷ منتشر شد، در وب‌گاه‌های دینامیک متداول شد. جاوا برای برنامه نویسی جنب سروری مورد استفاده قرار گرفت. این توسعه‌ها اساساً نو نبودند، بلکه بیشتر بهینه سازی شده زبان و مثال‌های موجود بودند، و بیشتر بر اساس خانواده زبان برنامه نویسی C بودند. پیشرفت زبان برنامه نویسی همچنان ادامه پیدا می‌کند، هم در تحقیقات و هم در صنعت. جهت‌های فعلی شامل امنیت و وارسی قابلیت اعتماد است، گونه‌های جدید مدولی(mixin، نماینده‌ها، جنبه‌ها) و تجمع پایگاه داده.

۴GLها نمونه‌ای از زبان‌هایی هستند که محدوده استفاده آنها مشخص است، مثل SQL. که به جای اینکه داده‌های اسکالر را برگردانند، مجموعه‌هایی را تغییر داده و بر می‌گردانند که برای اکثر زبان‌ها متعارفند. Perl برای مثال، با "مدرک اینجا" خود می‌تواند چندین برنامه ۴GL را نگه دارد، مانند چند برنامه جاوا سکریبت، در قسمتی از کد پرل خود و برای پشتیبانی از چندین زبان برنامه نویسی با تناسب متغیر در "مدرک اینجا" استفاده کند.




سنجش استفاده از زبان

مشکل است که مشخص کنیم کدام زبان برنامه نویسی بیشتر مورد استفاده‌است، و اینکه کاربرد چه معنی می‌دهد با توجه به زمینه تغییر می‌کند. یک زبان ممکن است زمان بیشتری از برنامه نویس بگیرد، زبان دیگر ممکن است خطوط بیشتری داشته باشد، و دیگری ممکن است زمان بیشتری از پردازنده را مصرف کند. برخی زبان‌ها برای کاربردهای خاص بسیار محبوبند. برای مثال: کوبول همچنان در مراکزداده متحد، غالباً روی کامپیوترهای بزرگ توانا است؛ fortran در مهندسی برنامه‌های کاربردی، C در برنامه‌های تعبیه شده و سیستم‌های عامل؛ و بقیه برنامه‌ها معمولاً برای نوشتن انواع دیگر برنامه‌ها کاربرد دارند. روش‌های مختلفی برای سنجش محبوبیت زبان‌ها، هر یک متناسب یا یک ویژگی محوری متفاوت پیشنهاد شده‌است:

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

طبقه بندی‌ها هیچ برنامه غالبی برای دسته بندی زبان‌های برنامه نویسی وجود ندارد. یک زبان مشخص معمولاً یک زبان اجدادی ندارد. زبان‌ها معمولاً با ترکیب المان‌های چند زبان پیشینه بوجود می‌آیند که هربار ایده‌های جدید درگردشند. ایده‌هایی که در یک زبان ایجاد می‌شوند در یک خانواده از زبان‌های مرتبط پخش می‌شوند، و سپس از بین خلاهای بین خانواده‌ها منتقل شده و در خانواده‌های دیگر ظاهر می‌شوند.

این حقیقت که این دسته بندی ممکن است در راستای محورهای مختلف انجام شوند، این وظیفه را پیچیده تر می‌کند؛ برای مثال، جاوا هم یک زبان شیءگرا(چون به برنامه نویسی شیءگرا تشویق می‌کند) و زبان همزمان(چون ساختارهای داخلی برای اجرای چندین جریان موازی دارد) است. پایتون یک زبان اسکریپتی شیءگراست.

در نگاه کلی، زبان‌های برنامه نویسی به مثال‌های برنامه نویسی و یک دسته بندی بر اساس محدوده استفاده تقسیم می‌شوند. مثال‌ها شامل برنامه نویسی رویه‌ای، برنامه نویسی شیءگرا، برنامه نویسی کاربردی، وبرنامه نویسی منطقی؛ برخی زبان‌ها ترکیب چند مثالند. یک زبان اسمبلی مثالی از یک مدل مستقیم متضمن معماری ماشین نیست. با توجه به هدف، زبان‌های برنامه نویسی ممکن است همه منظوره باشند، زبان‌های برنامه نویسی سیستمی، زبان‌های اسکریپتی، زبان‌های محدوده مشخص، زبان‌های همزمان/ گسترده(و یا ترکیب اینها). برخی زبان‌های همه منظوره تا حد زیادی برای اهداف آموزشی طراحی شده‌اند.

یک زبان برنامه نویسی ممکن است با فاکتورهای غیر مرتبط به مثال‌های برنامه نویسی دسته بندی شود. برای مثال، غالب زبان‌های برنامه نویسی کلمات کلیدی زبان انگلیسی را استفاده می‌کنند، در حالیکه تعداد کمی این کار را نمی‌کنند. سایر زبان‌ها ممکن است براساس داخلی بودن یا نبودن دسته بندی شوند.
ساعت : 2:01 am | نویسنده : admin | تک گرافیک | مطلب قبلی
تک گرافیک | next page | next page