吾爱汇编

 找回密码
 立即注册

QQ登录

绑定QQ避免忘记帐号

查看: 2560|回复: 67

[C/C++] 新手学习字符串控制string.h头文件用法和函数

  [复制链接]
gwgirl 发表于 2021-12-13 16:38 | 显示全部楼层 |阅读模式

[C] 纯文本查看 复制代码
//1.strcat字符串拼接函数
void main(void){
    char dest[50];
    char *a = "china";
    char *b = " is powerful!";
    strcpy(dest,a);
    strcat(dest,b);
    printf("%s\n",dest);

    system("pause");
}

//2.strchr在一个串中查找给定字符的第一个匹配之处
void main(void){
    char *str = "I want go to USA!";
    //U元素的指针
    //str+3
    char* p = strchr(str,'w');
    if (p){
        printf("索引位置:%d\n", p - str);
    }
    else{
        printf("没有找到");
    }

    system("pause");
}

//3.strstr 从字符串haystack中寻找needle第一次出现的位置
void main(void){
    char *haystack = "I want go to USA!";
    char *needle = "to";
    //U元素的指针
    
    char* p = strstr(haystack, needle);
    if (p){
        printf("索引位置:%d\n", p - haystack);
    }
    else{
        printf("没有找到");
    }

    system("pause");
}

//4.strcmp 比较字符串 strcmpi 比较字符串,忽略大小写
void main(void){
    char *str1 = "abc";
    char *str2 = "ABC";
    //int r = strcmpi(str1, str2);
    int r = _strcmpi(str1, str2);
    printf("%d\n",r);
    //str1 > str2
    if (r > 0){
        printf("str1 大于str2\n");
    }
    else if (r == 0){
        printf("str1 等于str2\n");
    }
    //str1 < str2
    else if (r < 0){
        printf("str1 小于str2\n");
    }

    system("pause");
}

//5.strset 把字符串s中的所有字符都设置成字符c
void main(void){
    char str[] = "internet change the world!";
    _strset(str,'w');
    printf("%s\n",str);
    system("pause");
}

//6.strrev 把字符串s的所有字符的顺序颠倒过来
void main(void){
    char str[] = "internet change the world!";
    _strrev(str);
    printf("%s\n", str);
    system("pause");
}

//7.atoi 字符串转为int类型、atol():将字符串转换为长整型值
void main(void){
    char* str = "a78";
    //int r = atoi(str);    
    printf("%d\n", r);
    system("pause");
}

//8.字符串转为double类型
void main(void){
    char* str = "77b8b";
    char** p = NULL;
    //char* p = str + 2;
    //参数说明:str为要转换的字符串,endstr 为第一个不能转换的字符的指针
    double r = strtod(str,p);
    printf("%lf\n", r);
    printf("%#x\n", p);
    system("pause");
}

//9.strupr转换为大写
void main(void){
    char str[] = "CHINA motherland!";
    _strupr(str);
    printf("%s\n",str);
    system("pause");
}

//10.转换为小写
void mystrlwr(char str[],int len)
{
    int i = 0;
    for (; i < len; i++)
{
        //A-Z 字母 a-Z
        if (str[i] >= 'A' && str[i] <= 'Z')
{
            str[i] = str[i]-'A' + 'a';
        }
    }
}

void main(void){
    char str[] = "CHINA motherland!";
    mystrlwr(str,strlen(str));
    printf("%s\n", str);
    system("pause");
}

//11.练习:删除字符串中指定的字符
void delchar(char *str, char del){
    char *p = str;
    while (*str != '\0') {
        if (*str != del) {
            *p++ = *str;
        }
        str++;
    }
    *p = '\0';
}
//删除最后一个字符
int main()
{
    char str[] = "vencent ppqq";
    delchar(str,'t');
    printf("%s\n", str);
    system("pause");
}
//Java String replaceAll
//StringBuffer buff.deleteCharAt(buff.length()-1);
//删除最后一个字符
void main(void){
    char str[] = "internet,";
    str[strlen(str) - 1] = '\0';
    printf("%s\n", str);
    //作业:realloc实现StringBuffer的拼接,而不是一开始开辟一个很大的数组
    //结构体StringBuffer
    system("pause");
}

//12.memcpy 由src所指内存区域复制count个字节到dest所指内存区域
void main(void){
    char src[] = "C,C++,Java";
    char dest[20] = {0};
    //字节
    memcpy(dest,src,5);
    printf("%s\n",dest);
    system("pause");
}

//13.memchr 从buf所指内存区域的前count个字节查找字符ch。
void main(void){
    char src[] = "C,C++,Java";
    char ch = 'C';
    //字节 (分段截取)
    char* p = memchr(src+3, ch, 5);
    if (p){
        printf("索引:%d\n", p - src);
    }
    else{
        printf("找不到\n");
    }
    system("pause");
}

//14.memmove 由src所指内存区域复制count个字节到dest所指内存区域。
void main(){
    char s[] = "Michael Jackson!";
    //截取的效果 
    memmove(s, s + 8, strlen(s) - 8 - 1);
    s[strlen(s) - 8] = 0;
    printf("%s\n", s);
    getchar();
}

//14.在字符串s1中寻找字符串s2中任何一个字符相匹配的第一个字符的位置,空字符NULL不包括在内
void main(){
    char *s1 = "Welcome To Beijing";
    char *s2 = "to"; 
    char *p;

    p = strpbrk(s1, s2);
    if (p)
        printf("%s\n", p);
    else
        printf("Not Found!\n");

    p = strpbrk(s1, "Da");
    if (p)
        printf("%s", p);
    else
        printf("Not Found!");

    getchar();
}


评分

参与人数 12HB +8 THX +5 收起 理由
花盗睡鼠 + 1 [吾爱汇编论坛52HB.COM]-学破解防破解,知进攻懂防守!
消逝的过去 + 1
zxjzzh + 1 [吾爱汇编论坛52HB.COM]-吃水不忘打井人,给个评分懂感恩!
风里去 + 1 [吾爱汇编论坛52HB.COM]-软件反汇编逆向分析,软件安全必不可少!
agan8888 + 1
pmm018 + 1
playboy + 1
lovekaixin + 1
brswbx201610 + 1
endbeach + 1 + 1
king51999 + 1 [快捷评语]--积极评分,从我做起。感谢分享!
foreversos + 1

查看全部评分

吾爱汇编论坛-学破解,防破解!知进攻,懂防守!逆向分析,软件安全!52HB.COM
playboy 发表于 2021-12-29 22:17 | 显示全部楼层
吾爱汇编论坛-学破解,防破解!知进攻,懂防守!逆向分析,软件安全!52HB.COM
阔达发卡 发表于 2022-1-22 16:32 | 显示全部楼层

感谢楼主
吾爱汇编论坛-学破解,防破解!知进攻,懂防守!逆向分析,软件安全!52HB.COM
健壮就帆布鞋 发表于 2022-1-22 19:14 | 显示全部楼层
吾爱汇编论坛-学破解,防破解!知进攻,懂防守!逆向分析,软件安全!52HB.COM
愤怒保卫水杯 发表于 2022-1-22 19:33 | 显示全部楼层

我现在已经把楼主作为我的学习目标了!
吾爱汇编论坛-学破解,防破解!知进攻,懂防守!逆向分析,软件安全!52HB.COM
拉长有大神 发表于 2022-1-22 22:08 | 显示全部楼层
吾爱汇编论坛-学破解,防破解!知进攻,懂防守!逆向分析,软件安全!52HB.COM
畅快迎耳机 发表于 2022-1-22 22:26 | 显示全部楼层

感谢楼主
吾爱汇编论坛-学破解,防破解!知进攻,懂防守!逆向分析,软件安全!52HB.COM
VXBlSUP138 发表于 2022-1-24 13:18 | 显示全部楼层

谢谢分享
吾爱汇编论坛-学破解,防破解!知进攻,懂防守!逆向分析,软件安全!52HB.COM
KcthLpNC593 发表于 2022-1-24 13:20 | 显示全部楼层

感谢楼主
吾爱汇编论坛-学破解,防破解!知进攻,懂防守!逆向分析,软件安全!52HB.COM
sKmUGeBk 发表于 2022-1-24 15:33 | 显示全部楼层

谢谢啊,滴水之恩涌泉相报~
吾爱汇编论坛-学破解,防破解!知进攻,懂防守!逆向分析,软件安全!52HB.COM
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

警告:本站严惩灌水回复,尊重自己从尊重他人开始!

1层
2层
3层
4层
5层
6层
7层
8层
9层
10层

免责声明

吾爱汇编(www.52hb.com)所讨论的技术及相关工具仅限用于研究学习,皆在提高软件产品的安全性,严禁用于不良动机。任何个人、团体、组织不得将其用于非法目的,否则,一切后果自行承担。吾爱汇编不承担任何因为技术滥用所产生的连带责任。吾爱汇编内容源于网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除。如有侵权请邮件或微信与我们联系处理。

站长邮箱:SharkHeng@sina.com
站长QQ:1140549900


QQ|RSS|手机版|小黑屋|帮助|吾爱汇编 ( 京公网安备11011502005403号 , 京ICP备20003498号-6 )|网站地图

Powered by Discuz!

吾爱汇编 www.52hb.com

快速回复 返回顶部 返回列表