字符串\字符串处理常用函数

简介: 字符串\字符串处理常用函数

一些函数,比如strcpy,strcat,可能存在数组越界的安全隐患,建议改用strncpy,strncat

注意要在后面补上参数,限制字符个数

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
int main()
{
  //1、计算长度
  char line[]="HELLO";
  printf("strlen=%lu\n",strlen(line));  //五个字节的字母
  printf("strlen=%lu\n",sizeof(line));  //多了一个字节的\0
 
  //2、比较——编译器不同输出情况可能不一样
  char s1[]="abC";
  char s2[]="abc";
  printf("%d\n",strcmp(s1,s2));
  //逐个比较同位大小,若相等,比较下一位,不等则输出结果
  
  //3、字符串复制
  char s4[4];
  char *s3=strcpy(s2,s1);
  for(int i=0;i<strlen(s1);i++)
  {
    s4[i]=*s3;
    s3++;
  }
  printf("des=");   //这里的s4如果直接用%s输出,后面会有一串“烫烫烫”
  for(int i=0;i<strlen(s1);i++)
    printf("%c",s4[i]);   //感觉有点麻烦,但好像也能输出
  printf("\n");
 
  //可能这才是正确用法
  char a[20], c[] = "I am a teacher!";
  strcpy(a,c);
  printf("c=%s\n",c);
  printf("a=%s\n",a);
 
  char b[15]={0}, d[] = "I am a teacher!\0";  //初始化带个\0就不会出现“烫烫烫”的字符
  strncpy(b,d,7);
  printf("d=%s\n",d);
  printf("b=%s\n",b);
 
  //4、字符串的查找
  char s5[]="internet";
  char *m=s5;
  //左查找(从左到右第一个的指针)
  m=strchr(s5,'e');
  printf("%p\n",m);
  //右查找(从右往左第一个的指针)
  m=strrchr(s5,'e');  //可以试着看看它的位置
  printf("%p\n",m); //如果找不到就会报错
 
  //5、大写转小写
  printf("%s\n",strupr(c));
 
  //6、小写转大写
  printf("%s\n",strlwr(c));
 
  printf("\n#####使用实例#####\n");
  //使用实例
  //初始化
  char str[20]="Programming";
  char cstr[20];
  char tmp[20];
  int i;
 
  //输入字符串
  printf("请输入字符串:");
  gets(cstr);
 
  //比较,小的放在str中
  if(strcmp(str,cstr)>0)
  {
    strcpy(tmp,str);
    strcpy(str,cstr);
    strcpy(cstr,tmp);
  }
 
  //连个"**"
  strcat(cstr,"**");  //给较大的字符串连
  i=strlen(cstr);
 
  //判断输出
  if(i+strlen(str)<20)
  {
    strcat(cstr,str);
    puts(cstr);   //输出连接后的结果
  }
  else
    printf("strcat搞不定啊\n");
 
  //升为大写
  strupr(cstr);
  puts(cstr);
 
  system("pause");
  return 0;
}


目录
相关文章
|
12月前
|
存储 人工智能 Cloud Native
重磅!阿里云公有云产品及战略能力全球第二
重磅!阿里云公有云产品及战略能力全球第二
628 5
|
SQL Java 数据库连接
如何使用`DriverManager.getConnection()`连接数据库,并利用`PreparedStatement`执行参数化查询,有效防止SQL注入。
【10月更文挑战第6天】在代码与逻辑交织的世界中,我从一名数据库新手出发,通过不断探索与实践,最终成为熟练掌握JDBC的开发者。这段旅程充满挑战与惊喜,从建立数据库连接到执行SQL语句,再到理解事务管理和批处理等高级功能,每一步都让我对JDBC有了更深的认识。示例代码展示了如何使用`DriverManager.getConnection()`连接数据库,并利用`PreparedStatement`执行参数化查询,有效防止SQL注入。
407 5
|
网络协议 Linux 网络安全
如何使用 ping 命令进行故障排除**
【8月更文挑战第24天】
458 0
|
jenkins Java Shell
解决jenkins结束后kill掉衍生进程
解决jenkins结束后kill掉衍生进程
|
SQL 分布式计算 前端开发
MaxCompute操作报错合集之SQL脚本设置参数set odps.mapred.reduce.tasks=18;没有生效,是为什么
MaxCompute是阿里云提供的大规模离线数据处理服务,用于大数据分析、挖掘和报表生成等场景。在使用MaxCompute进行数据处理时,可能会遇到各种操作报错。以下是一些常见的MaxCompute操作报错及其可能的原因与解决措施的合集。
373 5
|
SQL 关系型数据库 MySQL
|
数据可视化 搜索推荐 Devops
从DevOps实践者的角度谈谈云效Flow
一名DevOps实践者参与了云效流水线Flow的评测,认为Flow对新手友好,具有可视化编排功能。但在上手过程中,了解相关术语和流畅编排设计可能构成一些挑战。Flow的功能基本满足需求,但开放性有待提高,建议开放插件开发以丰富生态。YAML编排作为趋势,Flow在易用性和功能完善上仍有进步空间,如语法检查、智能提示等功能。此外,产品模块间的逻辑性和交互清晰度也需改进。总结来说,Flow功能齐全,适合中小企业,但在用户体验和生态建设上有改进余地。
655 3
|
SQL 缓存 监控
如何在数据库查询中使用参数化查询?
【4月更文挑战第30天】如何在数据库查询中使用参数化查询?
561 1
|
监控 NoSQL 大数据
深入解析 MongoDB Map-Reduce:强大数据聚合与分析的利器
深入解析 MongoDB Map-Reduce:强大数据聚合与分析的利器
268 0

热门文章

最新文章