वाक्य - विन्यास:
char* strcpy (char*गंतव्य_स्थान, स्थिरांक char*स्रोत_स्ट्रिंग);strcpy को समझना ():
strcpy() फ़ंक्शन का एकमात्र उद्देश्य एक स्ट्रिंग को स्रोत से गंतव्य तक कॉपी करना है। अब, हम strcpy() फ़ंक्शन के उपरोक्त सिंटैक्स को देखते हैं। strcpy () फ़ंक्शन दो मापदंडों को स्वीकार करने में सक्षम है -
- चार * गंतव्य
- कास्ट चार * स्रोत
यह सुनिश्चित करने के लिए स्रोत यहां स्थिर है कि strcpy() फ़ंक्शन स्रोत स्ट्रिंग को नहीं बदल सकता है। strcpy() फ़ंक्शन स्रोत स्ट्रिंग से गंतव्य तक सभी वर्णों (स्ट्रिंग के अंत में NULL वर्ण सहित) की प्रतिलिपि बनाता है। एक बार कॉपी ऑपरेशन स्रोत से गंतव्य तक पूरा हो जाने के बाद, strcpy() फ़ंक्शन गंतव्य का पता कॉलर फ़ंक्शन पर वापस कर देता है।
यहां ध्यान देने वाली महत्वपूर्ण बात यह है कि strcpy() फ़ंक्शन स्रोत स्ट्रिंग को गंतव्य स्ट्रिंग के साथ नहीं जोड़ता है। यह गंतव्य की सामग्री को स्रोत स्ट्रिंग की सामग्री से बदल देता है।
साथ ही, strcpy() फ़ंक्शन यह सुनिश्चित करने के लिए कोई जांच नहीं करता है कि गंतव्य का आकार स्रोत स्ट्रिंग से अधिक है, यह पूरी तरह से प्रोग्रामर की जिम्मेदारी है।
उदाहरण:
अब, हम strcpy() फ़ंक्शन को समझने के लिए कई उदाहरण देखेंगे:
- strcpy() - सामान्य ऑपरेशन (example1.c)
- strcpy() - केस -1 (example2.c)
- strcpy() - केस -2 (example3.c)
- strcpy() - केस -3 (example4.c)
- strcpy() - उपयोगकर्ता परिभाषित संस्करण (example5.c)
- strcpy() - उपयोगकर्ता परिभाषित संस्करण अनुकूलित (example6.c)
strcpy() - सामान्य ऑपरेशन (example1.c):
यह उदाहरण प्रोग्राम दिखाता है कि सी प्रोग्रामिंग भाषा में strcpy() फ़ंक्शन का उपयोग करके सामान्य स्ट्रिंग कॉपी ऑपरेशन कैसे करें। कृपया ध्यान दें कि गंतव्य स्ट्रिंग की लंबाई 30 (चार गंतव्य_स्ट्र [30]; ) है, जो स्रोत स्ट्रिंग की लंबाई से अधिक है (न्यूल वर्ण सहित लंबाई 18 है) ताकि गंतव्य सभी वर्णों को समायोजित कर सके स्रोत स्ट्रिंग।
#शामिल
#शामिल
NSमुख्य()
{
charsource_str[] = 'www.linuxhint.com';
charगंतव्य_स्त्र[30];
printf ('strcpy() फ़ंक्शन को कॉल करने से पहले:एनएन');
printf ('टीस्रोत स्ट्रिंग = %sएन',source_str);
printf ('टीगंतव्य स्ट्रिंग = %sएनएन',गंतव्य_स्त्र);
strcpy (गंतव्य_स्त्र,source_str);
printf ('strcpy() फ़ंक्शन निष्पादित करने के बाद:एनएन');
printf ('टीस्रोत स्ट्रिंग = %sएन',source_str);
printf ('टीगंतव्य स्ट्रिंग = %sएनएन',गंतव्य_स्त्र);
वापसी 0;
}
strcpy() - केस -1 (example2.c):
इस उदाहरण कार्यक्रम का उद्देश्य स्पष्ट रूप से यह बताना है कि क्या होता है जब गंतव्य स्ट्रिंग की लंबाई स्रोत स्ट्रिंग की लंबाई से कम होती है। ऐसे मामलों में, गंतव्य स्थान में स्रोत स्ट्रिंग से सभी वर्णों (नल वर्ण सहित) को समायोजित करने के लिए पर्याप्त स्थान/बाइट्स नहीं होंगे। दो बातें, आपको हमेशा ध्यान में रखनी चाहिए:
- strcpy() फ़ंक्शन यह जांच नहीं करेगा कि गंतव्य में पर्याप्त स्थान है या नहीं।
- यह एम्बेडेड सॉफ़्टवेयर में खतरनाक हो सकता है क्योंकि strcpy() गंतव्य की सीमा से परे स्मृति क्षेत्र को बदल देगा।
आइए उदाहरण कार्यक्रम को देखें। हमने source_str घोषित किया है और इसे शुरू किया है www.linuxhint.com , जो स्ट्रिंग के अंत में नल वर्ण सहित, स्टोर करने के लिए स्मृति में 18 बाइट्स लेगा। फिर, हमने केवल 5 के आकार के साथ एक और वर्ण सरणी यानी डेस्टिनेशन_स्ट्र घोषित किया है। इसलिए, डेस्टिनेशन_स्ट्र 18 बाइट्स के कुल आकार के साथ सोर्स स्ट्रिंग को होल्ड नहीं कर सकता है।
लेकिन, फिर भी, हम स्रोत स्ट्रिंग को गंतव्य स्ट्रिंग में कॉपी करने के लिए strcpy() फ़ंक्शन को कॉल कर रहे हैं। नीचे दिए गए आउटपुट से, हम देख सकते हैं कि strcpy() ने बिल्कुल भी शिकायत नहीं की। इस स्थिति में, strcpy() फ़ंक्शन स्रोत स्ट्रिंग से वर्ण की प्रतिलिपि बनाना शुरू कर देगा (जब तक कि यह स्रोत स्ट्रिंग में NULL वर्ण नहीं पाता) गंतव्य पते पर (भले ही गंतव्य सीमा पार हो जाए)। इसका मतलब है कि strcpy() फ़ंक्शन गंतव्य सरणी के लिए कोई सीमा जाँच नहीं करता है। अंत में, strcpy() फ़ंक्शन उन स्मृति पतों को अधिलेखित कर देगा जो गंतव्य सरणी को आवंटित नहीं किए गए हैं। यही कारण है कि strcpy() फ़ंक्शन स्मृति स्थानों को अधिलेखित कर देगा जो एक अलग चर के लिए आवंटित किया जा सकता है।
इस उदाहरण में, हम नीचे दिए गए आउटपुट से देख सकते हैं कि strcpy() फ़ंक्शन स्रोत स्ट्रिंग को ही अधिलेखित कर देता है। प्रोग्रामर को हमेशा ऐसे व्यवहार से सावधान रहना चाहिए।
#शामिल#शामिल
NSमुख्य()
{
charsource_str[] = 'www.linuxhint.com';
charगंतव्य_स्त्र[5];
printf ('strcpy() फ़ंक्शन को कॉल करने से पहले:एनएन');
printf ('टीस्रोत स्ट्रिंग = %sएन',source_str);
printf ('टीगंतव्य स्ट्रिंग = %sएनएन',गंतव्य_स्त्र);
strcpy (गंतव्य_स्त्र,source_str);
printf ('strcpy() फ़ंक्शन निष्पादित करने के बाद:एनएन');
printf ('टीस्रोत स्ट्रिंग = %sएन',source_str);
printf ('टीगंतव्य स्ट्रिंग = %sएनएन',गंतव्य_स्त्र);
// प्रिंटफ ('स्रोत पता =% u (0x% x) n', और स्रोत_स्ट्र [0], और स्रोत_स्ट्र [0]);
// प्रिंटफ ('गंतव्य पता =% u (0x% x) n', और गंतव्य_स्ट्र [0], और गंतव्य_स्ट्र [0]);
वापसी 0;
}
strcpy() - केस -2 (example3.c):
यह प्रोग्राम उस स्थिति को दिखाता है जब गंतव्य स्ट्रिंग का आकार स्रोत स्ट्रिंग आकार से बड़ा होता है और गंतव्य स्ट्रिंग पहले से ही कुछ मान के साथ प्रारंभ की जाती है। इस उदाहरण में, हमने आरंभ किया है:
- source_str से www.linuxhint.com [आकार = १७+१ = १८]
- गंतव्य_स्ट्र से I_AM_A_DESTINATION_STRING [आकार = 25+1 = 26]
strcpy() फ़ंक्शन सभी 17 वर्णों और NULL वर्ण को स्रोत स्ट्रिंग से गंतव्य स्ट्रिंग में कॉपी करेगा। लेकिन, यह गंतव्य सरणी में शेष बाइट्स (बाइट 19 से 26, एक आधारित) को प्रतिस्थापित / परिवर्तित नहीं करेगा। हमने गंतव्य सरणी पर पुनरावृति करने के लिए लूप का उपयोग किया है और यह साबित करने के लिए पूरे सरणी को प्रिंट किया है कि बाइट -19 से 26 गंतव्य सरणी में अपरिवर्तित हैं। इसलिए हम अंतिम आउटपुट को इस प्रकार देखते हैं:
#शामिल#शामिल
/* यह प्रोग्राम उस स्थिति को दिखाता है जब :
गंतव्य स्ट्रिंग आकार> स्रोत स्ट्रिंग आकार
और हम कॉपी करने के लिए strcpy() फ़ंक्शन निष्पादित करते हैं
गंतव्य के लिए स्रोत स्ट्रिंग।
नोट: गंतव्य स्ट्रिंग का आकार हमेशा होना चाहिए
स्रोत स्ट्रिंग से बड़ा या उसके बराबर हो।
* /
NSमुख्य()
{
charsource_str[] = 'www.linuxhint.com';
charगंतव्य_स्त्र[26] = 'I_AM_A_DESTINATION_STRING';
printf ('strcpy() फ़ंक्शन को कॉल करने से पहले:एनएन');
printf ('टीस्रोत स्ट्रिंग = %sएन',source_str);
printf ('टीगंतव्य स्ट्रिंग = %sएनएन',गंतव्य_स्त्र);
strcpy (गंतव्य_स्त्र,source_str);
printf ('strcpy() फ़ंक्शन निष्पादित करने के बाद:एनएन');
printf ('टीस्रोत स्ट्रिंग = %sएन',source_str);
printf ('टीगंतव्य स्ट्रिंग = %sएनएन',गंतव्य_स्त्र);
/* लूप के लिए उपयोग करके गंतव्य स्ट्रिंग प्रिंट करें*/
printf ('गंतव्य स्ट्रिंग चार को चार द्वारा प्रिंट करें:एनएन');
printf ('टीगंतव्य स्ट्रिंग = ');
के लिये(NSमैं=0;मैं<25;मैं++)
{
printf ('% सी',गंतव्य_स्त्र[मैं]);
}
printf ('एनएन');
वापसी 0;
}
strcpy() - केस -3 (example4.c):
हमने इस कार्यक्रम को यह दिखाने के लिए एक उदाहरण के रूप में माना है कि हमें कभी भी strcpy() को स्ट्रिंग अक्षर के साथ गंतव्य के रूप में कॉल नहीं करना चाहिए। यह अपरिभाषित व्यवहार का कारण बनेगा और अंततः, प्रोग्राम क्रैश हो जाएगा।
#शामिल#शामिल
NSमुख्य()
{
charsource_str[] = 'www.linuxhint.com';
printf ('strcpy() फ़ंक्शन को कॉल करने से पहले:एनएन');
printf ('टीस्रोत स्ट्रिंग = %sएन',source_str);
/* स्ट्रिंग अक्षर के साथ कभी भी strcpy() को गंतव्य के रूप में कॉल न करें।
प्रोग्राम क्रैश हो जाएगा।
* /
strcpy ('गंतव्य_स्ट्र',source_str);
printf ('strcpy() फ़ंक्शन निष्पादित करने के बाद:एनएन');
printf ('टीस्रोत स्ट्रिंग = %sएन',source_str);
वापसी 0;
}
strcpy() - उपयोगकर्ता परिभाषित संस्करण (example5.c):
इस उदाहरण कार्यक्रम में, हमने दिखाया है कि strcpy() फ़ंक्शन का उपयोगकर्ता-परिभाषित संस्करण कैसे लिखना है।
#शामिलchar *strcpy_user_defined(char *गंतव्य, स्थिरांक char *एसआरसी);
/* strcpy() फ़ंक्शन का उपयोगकर्ता परिभाषित संस्करण */
char *strcpy_user_defined(char *गंतव्य, स्थिरांक char *एसआरसी)
{
char *गंतव्य_बैकअप=गंतव्य;
जबकि(*एसआरसी! = ' 0') /* ' ' मिलने तक पुनरावृति करें।*/
{
*गंतव्य= *एसआरसी; /* स्रोत चार को गंतव्य पर कॉपी करें */
एसआरसी++; /* इंक्रीमेंट सोर्स पॉइंटर */
गंतव्य++; /* इंक्रीमेंट डेस्टिनेशन पॉइंटर */
}
*गंतव्य= ' 0'; /* गंतव्य में स्पष्ट रूप से ' ' डालें*/
वापसीगंतव्य_बैकअप;
}
NSमुख्य()
{
charsource_str[] = 'www.linuxhint.com';
charगंतव्य_स्त्र[30];
printf ('उपयोगकर्ता परिभाषित स्ट्रिंग कॉपी फ़ंक्शन को कॉल करने से पहले:एनएन');
printf ('टीस्रोत स्ट्रिंग = %sएन',source_str);
printf ('टीगंतव्य स्ट्रिंग = %sएनएन',गंतव्य_स्त्र);
/* उपयोगकर्ता परिभाषित स्ट्रिंग कॉपी फ़ंक्शन को कॉल करना */
strcpy_user_defined(गंतव्य_स्त्र,source_str);
printf ('उपयोगकर्ता परिभाषित स्ट्रिंग कॉपी फ़ंक्शन निष्पादित करने के बाद:एनएन');
printf ('टीस्रोत स्ट्रिंग = %sएन',source_str);
printf ('टीगंतव्य स्ट्रिंग = %sएनएन',गंतव्य_स्त्र);
वापसी 0;
}
strcpy() - उपयोगकर्ता परिभाषित संस्करण अनुकूलित (example6.c):
अब, इस उदाहरण कार्यक्रम में, हम strcpy() के उपयोगकर्ता-परिभाषित संस्करण को अनुकूलित करने जा रहे हैं।
#शामिलchar *strcpy_user_defined(char *गंतव्य, स्थिरांक char *एसआरसी);
/* उपयोगकर्ता परिभाषित strcpy() फ़ंक्शन का अनुकूलित संस्करण */
char *strcpy_user_defined(char *गंतव्य, स्थिरांक char *एसआरसी)
{
char *गंतव्य_बैकअप=गंतव्य;
जबकि(*गंतव्य++ = *एसआरसी++)
;
वापसीगंतव्य_बैकअप;
}
NSमुख्य()
{
charsource_str[] = 'www.linuxhint.com';
charगंतव्य_स्त्र[30];
printf ('उपयोगकर्ता परिभाषित स्ट्रिंग कॉपी फ़ंक्शन को कॉल करने से पहले:एनएन');
printf ('टीस्रोत स्ट्रिंग = %sएन',source_str);
printf ('टीगंतव्य स्ट्रिंग = %sएनएन',गंतव्य_स्त्र);
/* उपयोगकर्ता परिभाषित स्ट्रिंग कॉपी फ़ंक्शन को कॉल करना */
strcpy_user_defined(गंतव्य_स्त्र,source_str);
printf ('उपयोगकर्ता परिभाषित स्ट्रिंग कॉपी फ़ंक्शन निष्पादित करने के बाद:एनएन');
printf ('टीस्रोत स्ट्रिंग = %sएन',source_str);
printf ('टीगंतव्य स्ट्रिंग = %sएनएन',गंतव्य_स्त्र);
वापसी 0;
}
निष्कर्ष :
सी प्रोग्रामिंग भाषा में स्ट्रिंग कॉपी ऑपरेशन करने के लिए strcpy() फ़ंक्शन एक बहुत ही लोकप्रिय और आसान लाइब्रेरी फ़ंक्शन है। यह मुख्य रूप से स्ट्रिंग को एक स्थान से दूसरे स्थान पर कॉपी करने के लिए उपयोग किया जाता है। हालाँकि, हम इस तथ्य को दोहराना चाहते हैं कि strcpy() फ़ंक्शन गंतव्य सरणी के लिए सीमा जाँच नहीं करता है, जिसे अनदेखा करने पर एक गंभीर सॉफ़्टवेयर बग हो सकता है। यह सुनिश्चित करने के लिए हमेशा प्रोग्रामर की जिम्मेदारी होती है कि गंतव्य सरणी में NULL वर्ण सहित स्रोत स्ट्रिंग से सभी वर्णों को रखने के लिए पर्याप्त स्थान हो।