MFC - स्ट्रिंग्स
Stringsऐसी वस्तुएँ हैं जो वर्णों के अनुक्रम को दर्शाती हैं। C- शैली वर्ण स्ट्रिंग C भाषा के भीतर उत्पन्न हुई और C ++ के भीतर समर्थित होना जारी है।
यह स्ट्रिंग वास्तव में वर्णों का एक आयामी आयाम है, जिसे एक अशक्त चरित्र '\ 0' द्वारा समाप्त किया जाता है।
अशक्त-समाप्त स्ट्रिंग में वर्ण होते हैं जिसमें एक नल के बाद स्ट्रिंग शामिल होता है।
यहाँ चरित्र सरणी का सरल उदाहरण है।
char word[12] = { 'H', 'e', 'l', 'l', 'o', ' ', 'W', 'o', 'r', 'l', 'd', '\0' };
इसका प्रतिनिधित्व करने का एक और तरीका निम्नलिखित है।
char word[] = "Hello, World";
Microsoft Foundation Class (MFC) लाइब्रेरी स्ट्रिंग नामक हेरफेर करने के लिए एक वर्ग प्रदान करता है CString। सीएसट्रिंग की कुछ महत्वपूर्ण विशेषताएं निम्नलिखित हैं।
CString में आधार वर्ग नहीं है।
एक CString ऑब्जेक्ट वर्णों की एक चर-लंबाई अनुक्रम के होते हैं।
CString बेसिक के समान सिंटैक्स का उपयोग करके फ़ंक्शन और ऑपरेटर प्रदान करता है।
सरलीकरण और तुलना ऑपरेटरों, सरलीकृत स्मृति प्रबंधन के साथ मिलकर, CString वस्तुओं को साधारण चरित्र सरणियों की तुलना में उपयोग करना आसान बनाते हैं।
यहाँ CString का निर्माण है।
अनु क्रमांक। | विधि और विवरण |
---|---|
1 | CString विभिन्न तरीकों से सीएसट्रिंग ऑब्जेक्ट्स का निर्माण करता है |
यहाँ ऐरे तरीकों की एक सूची है -
अनु क्रमांक। | विधि और विवरण |
---|---|
1 | GetLength एक CString ऑब्जेक्ट में वर्णों की संख्या देता है। |
2 | IsEmpty टेस्ट कि क्या एक CString ऑब्जेक्ट में कोई वर्ण नहीं है। |
3 | Empty एक स्ट्रिंग को 0 लंबाई के लिए मजबूर करता है। |
4 | GetAt एक निर्दिष्ट स्थान पर चरित्र लौटाता है। |
5 | SetAt एक निर्दिष्ट स्थान पर एक चरित्र सेट करता है। |
यहाँ तुलना विधियों की एक सूची है -
अनु क्रमांक। | विधि और विवरण |
---|---|
1 | Compare दो तारों की तुलना (केस संवेदनशील)। |
2 | CompareNoCase दो स्ट्रिंग्स की तुलना (केस असंवेदनशील)। |
यहाँ निष्कर्षण विधियों की एक सूची है -
अनु क्रमांक। | विधि और विवरण |
---|---|
1 | Mid एक स्ट्रिंग के मध्य भाग को निकालता है (जैसे बेसिक एमआईडी $ फंक्शन)। |
2 | Left एक स्ट्रिंग के बाएं हिस्से को निकालता है (जैसे मूल बाएँ $ फ़ंक्शन)। |
3 | Right एक स्ट्रिंग के दाहिने हिस्से को निकालता है (जैसे बेसिक राइट $ फंक्शन)। |
4 | SpanIncluding स्ट्रिंग से वर्णों को निकालता है, जो दिए गए वर्ण सेट में हैं। |
5 | SpanExcluding स्ट्रिंग से वर्णों को निकालता है जो दिए गए वर्ण सेट में नहीं हैं। |
यहां रूपांतरण विधियों की एक सूची दी गई है।
अनु क्रमांक। | विधि और विवरण |
---|---|
1 | MakeUpper इस स्ट्रिंग के सभी वर्णों को अपरकेस वर्णों में परिवर्तित करता है। |
2 | MakeLower इस स्ट्रिंग के सभी वर्णों को अक्षरों को छोटा करने में परिवर्तित करता है। |
3 | MakeReverse इस स्ट्रिंग में वर्णों को उलट देता है। |
4 | Format स्प्रिंट के रूप में स्ट्रिंग को प्रारूपित करें। |
5 | TrimLeft स्ट्रिंग से प्रमुख सफेद-अंतरिक्ष वर्णों को ट्रिम करें। |
6 | TrimRight स्ट्रिंग से सफेद-अंतरिक्ष वर्णों को ट्रिम करें। |
यहाँ खोज विधियों की एक सूची दी गई है।
अनु क्रमांक। | विधि और विवरण |
---|---|
1 | Find एक चरित्र को ढूँढता है या एक बड़ी स्ट्रिंग के अंदर प्रतिस्थापित करता है। |
2 | ReverseFind एक बड़े स्ट्रिंग के अंदर एक चरित्र पाता है; अंत से शुरू होता है। |
3 | FindOneOf एक सेट से पहला मिलान चरित्र पाता है। |
यहाँ बफर एक्सेस मेथड्स की एक सूची दी गई है।
अनु क्रमांक। | विधि और विवरण |
---|---|
1 | GetBuffer CString में वर्णों के लिए एक सूचक लौटाता है। |
2 | GetBufferSetLength निर्दिष्ट लंबाई को रौंदते हुए, CString में वर्णों के लिए एक सूचक लौटाता है। |
3 | ReleaseBuffer GetBuffer द्वारा लौटाए गए बफर का नियंत्रण |
4 | FreeExtra स्ट्रिंग को पहले से आवंटित किसी अतिरिक्त मेमोरी को मुक्त करके इस स्ट्रिंग ऑब्जेक्ट के किसी भी ओवरहेड को हटा देता है। |
5 | LockBuffer संदर्भ गिनती को अक्षम करता है और बफर में स्ट्रिंग की सुरक्षा करता है। |
6 | UnlockBuffer संदर्भ गिनती में सक्षम करता है और स्ट्रिंग को बफर में जारी करता है। |
यहां विंडोज-विशिष्ट तरीकों की एक सूची दी गई है।
अनु क्रमांक। | विधि और विवरण |
---|---|
1 | AllocSysString CString डेटा से BSTR आवंटित करता है। |
2 | SetSysString किसी मौजूदा BSTR ऑब्जेक्ट को CString ऑब्जेक्ट के डेटा के साथ सेट करता है। |
3 | LoadString Windows CE संसाधन से मौजूदा CString ऑब्जेक्ट लोड करता है। |
CString ऑब्जेक्ट्स पर विभिन्न ऑपरेशन निम्नलिखित हैं -
स्ट्रिंग बनाएँ
आप एक स्ट्रिंग शाब्दिक का उपयोग करके या CString वर्ग का एक उदाहरण बनाकर एक स्ट्रिंग बना सकते हैं।
BOOL CMFCStringDemoDlg::OnInitDialog() {
CDialogEx::OnInitDialog();
// Set the icon for this dialog. The framework does this automatically
// when the application's main window is not a dialog
SetIcon(m_hIcon, TRUE); // Set big icon
SetIcon(m_hIcon, FALSE); // Set small icon
CString string1 = _T("This is a string1");
CString string2("This is a string2");
m_strText.Append(string1 + L"\n");
m_strText.Append(string2);
UpdateData(FALSE);
return TRUE; // return TRUE unless you set the focus to a control
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट दिखाई देगा।
खाली स्ट्रिंग
आप खाली स्ट्रिंग शाब्दिक का उपयोग करके या CString :: खाली () विधि का उपयोग करके एक रिक्त स्ट्रिंग बना सकते हैं। आप यह भी जांच सकते हैं कि बूलियन संपत्ति का उपयोग करते हुए कोई स्ट्रिंग खाली है या नहीं।
BOOL CMFCStringDemoDlg::OnInitDialog() {
CDialogEx::OnInitDialog();
// Set the icon for this dialog. The framework does this automatically
// when the application's main window is not a dialog
SetIcon(m_hIcon, TRUE); // Set big icon
SetIcon(m_hIcon, FALSE); // Set small icon
CString string1 = _T("");
CString string2;
string2.Empty();
if(string1.IsEmpty())
m_strText.Append(L"String1 is empty\n");
else
m_strText.Append(string1 + L"\n");
if(string2.IsEmpty())
m_strText.Append(L"String2 is empty");
else
m_strText.Append(string2);
UpdateData(FALSE);
return TRUE; // return TRUE unless you set the focus to a control
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट दिखाई देगा।
स्ट्रिंग कॉनटेनटेशन
दो या अधिक स्ट्रिंग्स को समेटने के लिए, आप दो स्ट्रिंग्स या एक CString :: परिशिष्ट () विधि को संक्षिप्त करने के लिए + ऑपरेटर का उपयोग कर सकते हैं।
BOOL CMFCStringDemoDlg::OnInitDialog() {
CDialogEx::OnInitDialog();
// Set the icon for this dialog. The framework does this automatically
// when the application's main window is not a dialog
SetIcon(m_hIcon, TRUE); // Set big icon
SetIcon(m_hIcon, FALSE); // Set small icon
//To concatenate two CString objects
CString s1 = _T("This "); // Cascading concatenation
s1 += _T("is a ");
CString s2 = _T("test");
CString message = s1;
message.Append(_T("big ") + s2);
// Message contains "This is a big test".
m_strText = L"message: " + message;
UpdateData(FALSE);
return TRUE; // return TRUE unless you set the focus to a control
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट दिखाई देगा।
स्ट्रिंग लंबाई
स्ट्रिंग की लंबाई जानने के लिए आप CString :: GetLength () विधि का उपयोग कर सकते हैं, जो एक CString ऑब्जेक्ट में वर्णों की संख्या लौटाता है।
BOOL CMFCStringDemoDlg::OnInitDialog() {
CDialogEx::OnInitDialog();
// Set the icon for this dialog. The framework does this automatically
// when the application's main window is not a dialog
SetIcon(m_hIcon, TRUE); // Set big icon
SetIcon(m_hIcon, FALSE); // Set small icon
CString string1 = _T("This is string 1");
int length = string1.GetLength();
CString strLen;
strLen.Format(L"\nString1 contains %d characters", length);
m_strText = string1 + strLen;
UpdateData(FALSE);
return TRUE; // return TRUE unless you set the focus to a control
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट दिखाई देगा।
स्ट्रिंग तुलना
दो स्ट्रिंग चर की तुलना करने के लिए आप == ऑपरेटर का उपयोग कर सकते हैं
BOOL CMFCStringDemoDlg::OnInitDialog() {
CDialogEx::OnInitDialog();
// Set the icon for this dialog. The framework does this automatically
// when the application's main window is not a dialog
SetIcon(m_hIcon, TRUE); // Set big icon
SetIcon(m_hIcon, FALSE); // Set small icon
CString string1 = _T("Hello");
CString string2 = _T("World");
CString string3 = _T("MFC Tutorial");
CString string4 = _T("MFC Tutorial");
if (string1 == string2)
m_strText = "string1 and string1 are same\n";
else
m_strText = "string1 and string1 are not same\n";
if (string3 == string4)
m_strText += "string3 and string4 are same";
else
m_strText += "string3 and string4 are not same";
UpdateData(FALSE);
return TRUE; // return TRUE unless you set the focus to a control
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट दिखाई देगा।