码迷,mamicode.com
首页 > 其他好文 > 详细

串和串的赋值操作

时间:2020-06-25 12:09:03      阅读:194      评论:0      收藏:0      [点我收藏+]

标签:ras   字符串   ssi   malloc   free   color   结束   max   while   

1.串的存储结构

typedef struct{
    char str[MaxSize+1];//末尾+‘\0‘ 
    int length;
}Strfix;
//变长存储结构 
typedef struct{
    char *ch;
    int length;
}StrNonfix;
    StrNonfix S;
    S.length=10;
    S.ch=(char*)malloc((S.length+1)*sizeof(char));
    S.ch[8]=J;
    cout<<S.ch[8]<<endl;
    free(S.ch);//free函数是free首地址,malloc给的就是首地址 

2.串的赋值操作

int strAssign(StrNonfix& str,char* ch){
    //释放原有的内容 
    if(str.ch){
        free(str.ch); 
    } 
    int len=0;
    char *c=ch;
    //确定赋值目标串的长度 
    //遇到‘\0‘就结束 
    while(*c){
        ++len;
        ++c;
    }
    //目标字符串没有除‘\0‘以外的字符 
    if(len == 0){
        str.ch=NULL;
        str.length=0;
        return 1;
    }else{
        str.ch=(char*)malloc(sizeof(char)*(len+1));
        //分配失败
        if(str.ch == NULL){
            return 0;
        }else{
            c=ch;
            //len+1次把‘\0‘赋值过去 
            for(int i=0;i<=len;++i,++c){
                str.ch[i]=*c;
            }
            str.length=len;
            return 1; 
        }
         
    }
     
} 

 

串和串的赋值操作

标签:ras   字符串   ssi   malloc   free   color   结束   max   while   

原文地址:https://www.cnblogs.com/jcahsy/p/13191284.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!