عملگر کاهش Decrement Operator
عملگر کاهش یا Decrement Operator چیست؟
عملگر کاهش (Decrement Operator) عملگری یکانی است که عملوند خود را یک واحد کاهش میدهد. هر چند این عمل به صورت معمولی و از طریق عملگرهای تفریق و انتساب نیز قابل انجام است ولی به دلیل رایج بودن و کاربرد بالای آن در برنامهنویسی، توسط اغلب زبانهای امروزی مورد پشتیبانی قرار میگیرد.
معمولا این عملگر با دو علامت خط تیره (یا تفریق) نمایش داده میشود. به عنوان مثال در قطعه کد زیر که به زبان C++ نوشته شده است، مقدار متغیر x پس از اجرای خط سوم یک واحد کاهش مییابد و برابر با عدد 1 میشود:
int x = 2; int result; result = x--;
در برخی از زبانهای برنامهنویسی از جمله C++ عملگر کاهش دارای دو مدل میباشد که اندکی با یکدیگر تفاوت دارند. در مدل اول که عملگر پس از عملوند قرار میگیرد، عملوند یک واحد کاهش مییابد اما حاصل عبارت، مقدار اصلی عملوند پیش از کاهش خواهد بود. به عبارت بهتر در این حالت، ابتدا عبارت بدون در نظر گرفتن عملگر کاهش ارزیابی میشود و سپس عملوند کاهش مییابد. درنتیجه، در مثال فوق مقدار متغیر x برابر با 1 اما مقدار متغیر result برابر با 2 خواهد بود. به این عملگر، عملگر پسا-کاهش (Post-Decrement) یا کاهش پسوندی (Postfix Decrement) نیز گفته میشود. میتوان دستورات فوق را به صورت زیر معادلسازی نمود:
int x = 2; int result; result = x; x = x - 1;
اما در مدل دوم، عملگر پیش از عملوند خود قرار میگیرد، ابتدا عملوند یک واحد کاهش مییابد و همین مقدار کاهش یافته به عنوان حاصل عبارت مورد استفاده قرار میگیرد. به این عملگر، عملگر پیش-کاهش (Pre-Decrement) یا کاهش پیشوندی (Prefix Decrement) نیز گفته میشود. با اجرای قطعه کد زیر، مقدار هر دو متغیر x و result برابر با 1 خواهد شد:
int x = 2; int result; result = --x;
همانند نمونهی قبل، این قطعه کد را نیز میتوان به صورت زیر معادلنویسی کرد:
int x = 2; int result; x = x - 1; result = x;
گفتنی است عملگر افزایش (Increment Operator) که با نماد ++ نشان داده میشود نیز عملی مشابه را برای افزایش یک واحدی عملوند خود انجام میدهد.
پیوندهای پیشنهادی تک دیک