Julia Language
सशर्त,
खोज…
वाक्य - विन्यास
- अगर कंडोम; तन; समाप्त
- अगर कंडोम; तन; अन्य; तन; समाप्त
- अगर कंडोम; तन; अन्योक्ति कंडस; तन; अन्य; समाप्त
- अगर कंडोम; तन; अन्योक्ति कंडस; तन; समाप्त
- कंडोम? iftrue: iffalse
- cond && iftrue
- कंडोम || iffalse
- ifelse (cond, iftrue, iffalse)
टिप्पणियों
सभी सशर्त ऑपरेटरों और कार्यों में बूलियन स्थितियों ( true या false ) का उपयोग करना शामिल है। जूलिया में, बूलियन्स के प्रकार है Bool । कुछ अन्य भाषाओं के विपरीत, अन्य प्रकार की संख्याएं (जैसे 1 या 0 ), स्ट्रिंग्स, सरणियाँ, और इसके बाद सीधे सशर्त में उपयोग नहीं की जा सकती हैं।
आमतौर पर, एक या तो प्रेडिकट फ़ंक्शंस (फ़ंक्शंस जो एक Bool लौटाता है) या सशर्त ऑपरेटर या फ़ंक्शन की स्थिति में तुलना ऑपरेटरों का उपयोग करता है।
अगर ... और अभिव्यक्ति
जूलिया में सबसे आम सशर्त है if ... else अभिव्यक्ति। उदाहरण के लिए, नीचे हम आधार मामले को संभालने के लिए एक सशर्त का उपयोग करके, सबसे बड़े सामान्य भाजक की गणना के लिए यूक्लिडियन एल्गोरिथ्म को लागू करते हैं:
mygcd(a, b) = if a == 0
abs(b)
else
mygcd(b % a, a)
end
if ... जूलिया में else रूप वास्तव में एक अभिव्यक्ति है, और इसका एक मूल्य है; मूल्य उस स्थिति में पूंछ की स्थिति में अभिव्यक्ति (यानी, अंतिम अभिव्यक्ति) है जो लिया जाता है। निम्नलिखित नमूना इनपुट पर विचार करें:
julia> mygcd(0, -10)
10
यहां, a 0 और b -10 । स्थिति a == 0 true , इसलिए पहली शाखा ली जाती है। लौटाया गया मान abs(b) जो 10 ।
julia> mygcd(2, 3)
1
यहाँ, a 2 और b 3 । स्थिति a == 0 गलत है, इसलिए दूसरी शाखा ली गई है, और हम mygcd(b % a, a) गणना mygcd(b % a, a) , जो mygcd(3 % 2, 2) । % ऑपरेटर शेष जब देता है 3 से विभाजित है 2 इस मामले में, 1 । इस प्रकार हम mygcd(1, 2) गणना mygcd(1, 2) , और इस बार a 1 और b 2 । एक बार फिर, a == 0 गलत है, इसलिए दूसरी शाखा ली गई है, और हम mygcd(b % a, a) , जो कि mygcd(0, 1) गणना mygcd(b % a, a) । इस बार, अंतिम पर a == 0 और इतना abs(b) वापस आ गया है, जो परिणाम 1 देता है।
अगर ... और बयान
name = readline()
if startswith(name, "A")
println("Your name begins with A.")
else
println("Your name does not begin with A.")
end
किसी भी अभिव्यक्ति, जैसे if ... else अभिव्यक्ति, को बयान की स्थिति में रखा जा सकता है। यह इसके मूल्य की अनदेखी करता है लेकिन फिर भी इसके दुष्प्रभावों के लिए अभिव्यक्ति को निष्पादित करता है।
अगर बयान
किसी अन्य अभिव्यक्ति की तरह, एक की वापसी मान if ... else अभिव्यक्ति पर ध्यान नहीं दिया जा सकता है (और इसलिए खारिज कर दिया)। यह आम तौर पर केवल तब उपयोगी होता है जब अभिव्यक्ति के शरीर पर दुष्प्रभाव होते हैं, जैसे किसी फ़ाइल पर लिखना, परिवर्तनशील चर, या स्क्रीन पर मुद्रण करना।
इसके अलावा, if की एक else शाखा ... else अभिव्यक्ति वैकल्पिक है। उदाहरण के लिए, हम आउटपुट के लिए निम्न कोड को स्क्रीन पर तभी लिख सकते हैं जब कोई विशेष शर्त पूरी हो।
second = Dates.second(now())
if iseven(second)
println("The current second, $second, is even.")
end
ऊपर के उदाहरण में, हम वर्तमान दूसरे को प्राप्त करने के लिए समय और दिनांक कार्यों का उपयोग करते हैं; उदाहरण के लिए, यदि यह वर्तमान में 10:55:27 है, तो चर second 27 होगा। यदि यह संख्या सम है, तो स्क्रीन पर एक लाइन प्रिंट की जाएगी। अन्यथा, कुछ भी नहीं किया जाएगा।
टर्नरी सशर्त संचालक
pushunique!(A, x) = x in A ? A : push!(A, x)
टर्नरी सशर्त ऑपरेटर कम चिंताजनक है if ... else अभिव्यक्ति हो।
वाक्य रचना विशेष रूप से है:
[condition] ? [execute if true] : [execute if false]
इस उदाहरण में, हम x को संग्रह A जोड़ते हैं यदि x पहले से ही A में नहीं है। अन्यथा, हम सिर्फ A अपरिवर्तित छोड़ देते हैं।
टर्नरी ऑपरेटर संदर्भ:
शॉर्ट-सर्किट ऑपरेटर: && और ||
ब्रांचिंग के लिए
शॉर्ट-सर्कुलेटिंग सशर्त ऑपरेटर && और || निम्नलिखित निर्माणों के लिए हल्के प्रतिस्थापन के रूप में इस्तेमाल किया जा सकता है:
-
x && y,x ? y : xबराबर हैx ? y : x -
x || y,x ? x : yबराबर हैx ? x : y
शॉर्ट-सर्किट ऑपरेटरों के लिए एक उपयोग किसी शर्त का परीक्षण करने और उस स्थिति के आधार पर एक निश्चित कार्रवाई करने के लिए एक अधिक संक्षिप्त तरीका है। उदाहरण के लिए, निम्न कोड तर्क को नकारात्मक && लिए && ऑपरेटर का उपयोग करता है यदि तर्क x नकारात्मक है:
function mysqrt(x)
x < 0 && throw(DomainError("x is negative"))
x ^ 0.5
end
|| ऑपरेटर का उपयोग त्रुटि जाँच के लिए भी किया जा सकता है, सिवाय इसके कि जब तक कोई शर्त रखता है, तब तक वह त्रुटि को ट्रिगर करता है, बजाय यदि स्थिति रखता है:
function halve(x::Integer)
iseven(x) || throw(DomainError("cannot halve an odd number"))
x ÷ 2
end
इसका एक और उपयोगी अनुप्रयोग किसी वस्तु के लिए डिफ़ॉल्ट मूल्य की आपूर्ति करना है, केवल अगर यह पहले से परिभाषित नहीं है:
isdefined(:x) || (x = NEW_VALUE)
यहाँ, यह जाँचता है कि क्या प्रतीक x को परिभाषित किया गया है (अर्थात यदि वस्तु x को दिया गया मान है)। अगर ऐसा है, तो कुछ नहीं होता। लेकिन, यदि नहीं, तो x को NEW_VALUE सौंपा जाएगा। ध्यान दें कि यह उदाहरण केवल बड़े पैमाने पर काम करेगा।
स्थितियों में
ऑपरेटर भी उपयोगी होते हैं क्योंकि उनका उपयोग दो स्थितियों का परीक्षण करने के लिए किया जा सकता है, जिनमें से दूसरे का मूल्यांकन केवल पहली स्थिति के परिणाम के आधार पर किया जाता है। जूलिया प्रलेखन से :
अभिव्यक्ति में
a && b, उपसूचकbकेवल मूल्यांकन किया जाता है, तोaके लिए मूल्यांकन करता हैtrueअभिव्यक्ति
a || b, सबफ्रेप्रेशनbका मूल्यांकन केवल तभी किया जाता है जबafalseमूल्यांकन करताfalse
इस प्रकार, जबकि a & b दोनों a & b और a && b दोनों true अगर a और b दोनों true , तो उनका व्यवहार a false है।
उदाहरण के लिए, मान लीजिए कि हम जांचना चाहते हैं कि कोई वस्तु पॉजिटिव नंबर है या नहीं, जहाँ यह संभव है कि वह नंबर भी न हो। इन दो प्रयासों के कार्यान्वयन के बीच अंतर पर विचार करें:
CheckPositive1(x) = (typeof(x)<:Number) & (x > 0) ? true : false
CheckPositive2(x) = (typeof(x)<:Number) && (x > 0) ? true : false
CheckPositive1("a")
CheckPositive2("a")
CheckPositive1() एक त्रुटि उत्पन्न करेगा यदि एक गैर-संख्यात्मक प्रकार को एक तर्क के रूप में आपूर्ति की जाती है। ऐसा इसलिए है क्योंकि यह पहले के परिणाम की परवाह किए बिना दोनों अभिव्यक्तियों का मूल्यांकन करता है , और जब कोई गैर-संख्यात्मक प्रकार के लिए इसका मूल्यांकन करने की कोशिश करता है, तो दूसरी अभिव्यक्ति में त्रुटि आएगी।
CheckPositive2() , हालांकि, एक गैर-संख्यात्मक प्रकार की आपूर्ति होने पर false (एक त्रुटि के बजाय) उत्पन्न करेगा, क्योंकि दूसरी अभिव्यक्ति का केवल तभी मूल्यांकन किया जाता है यदि पहला true ।
एक से अधिक शॉर्ट-सर्किट ऑपरेटर को एक साथ मारा जा सकता है। उदाहरण के लिए:
1 > 0 && 2 > 0 && 3 > 5
अगर कई शाखाओं के साथ बयान
d = Dates.dayofweek(now())
if d == 7
println("It is Sunday!")
elseif d == 6
println("It is Saturday!")
elseif d == 5
println("Almost the weekend!")
else
println("Not the weekend yet...")
end
की कोई भी संख्या elseif शाखाओं एक साथ इस्तेमाल किया जा सकता if बयान है, संभवतः के साथ या एक अंतिम बिना else शाखा। बाद की स्थितियों का मूल्यांकन केवल तभी किया जाएगा जब सभी पूर्व स्थितियां false पाई गई हों।
Ifelse फ़ंक्शन
shift(x) = ifelse(x > 10, x + 1, x - 1)
उपयोग:
julia> shift(10)
9
julia> shift(11)
12
julia> shift(-1)
-2
ifelse फ़ंक्शन दोनों शाखाओं का मूल्यांकन करेगा, यहां तक कि वह भी जो चयनित नहीं है। यह तब उपयोगी हो सकता है जब शाखाओं के दुष्प्रभाव होते हैं जिनका मूल्यांकन किया जाना चाहिए, या क्योंकि यह तेजी से हो सकता है यदि दोनों शाखाएं स्वयं सस्ती हैं।