cstring char*补充

1.传给未分配内存的const char* (LPCTSTR)指针.
   CString cstr(asdd);
   const char* ch = (LPCTSTR)cstr;
   ch指向的地址和cstr相同。但由于使用const保证ch不会修改,所以安全.

2.传给未分配内存的指针.
    CString cstr = "ASDDSD";
    char *ch = cstr.GetBuffer(cstr1.GetLength() + 1);
    cstr.ReleaseBuffer();
    //修改ch指向的值等于修改cstr里面的值.
    //PS:用完ch后,不用delete ch,因为这样会破坏cstr内部空间,容易造成程序崩溃.

3.第二种用法。把CString 值赋给已分配内存的char *。
    CString cstr1 = "ASDDSD";
    int strLength = cstr1.GetLength() + 1;
    char *pValue = new char[strLength];
    strncpy(pValue, cstr1, strLength);

4.第三种用法.把CString 值赋给已分配内存char[]数组.
    CString cstr2 = "ASDDSD";
    int strLength1 = cstr1.GetLength() + 1;
    char chArray[100];
    memset(chArray,0, sizeof(bool) * 100); //将数组的垃圾内容清空.

英语单词的前缀构成有一定的规律,例如"incorrect"和 "inability"有相同前缀"in"。请完成如下的C++函数功能: findCommonPrefix(char *word1, char * word2, char *prefix) 该函数分析得到word1和word2两个单词的最长共同前缀, 分析结果存到参数prefix中(题目保证prefix所指向空间足够大)。 例如,"disadvantage"和"disagree"的最长共同前缀是"disa", "disadvantage"和"misunderstand"的最长共同前缀是空串。 提示:可能用到的字符串函数说明如下, strlen(char *str):返回字符串str的长度; strcpy(char *dest, char *src):把字符串src复制到dest; strcat(char *dest, char *src):把字符串src连接到dest后面; char *strstr(const char *s1, const char *s2):从s1中查找子串s2第一次出现的位置。 输入格式: 输入在一行中给出两个英文单词(单词内部不含空格等分隔字符),以空格进行分隔。 输出格式: 在一行中输出两个英文单词的最长共同前缀。 输入样例: disadvantage disagree 输出样例: disa 注意:仅在标有”Program”和”End”的注释行之间补充填写代码。 请勿改动主函数main和其它任何已有内容。 初始代码: #include <iostream> #include <fstream> #include <cstring> using namespace std; void findCommonPrefix(char *word1, char *word2, char *prefix) { /**********Program**********/ /********** End **********/ } int main() { char word1[100], word2[100]; char prefix[100]; cin >> word1 >> word2; findCommonPrefix(word1, word2, prefix); cout << prefix << endl; return 0; }
最新发布
06-05
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值