超级字符串技能:提升你的编码游戏

嘿嘿,uu们,今天咱们来详解字符函数与字符串函数,好啦,废话不多讲,开干!


1.:字符分类函数

C语言中又一系列的函数是专门做字符分类的,也就是一个字符属于什么类型的字符的,这些函数的使用需要包含头文件ctype.h

这些函数的使用方法都十分类似,博主在这里就举两到三个例子,其他的都是换汤不换药~

1.1:islower函数

islower函数是能够判断参数部分的c是否是小写字符的

通过返回值来判断是否是小写字母,如果是小写字母就返回非0的整数,如果不是小写字母,则返回0.

#include <stdio.h>
#include <ctype.h>
int main()
{char c = 'a';char a = 'A';printf("%d %d\n", islower(c), islower(a));return 0;
}

1.2:isspace函数

isspacer函数是能够判断参数部分的c是否是空白字符:空格' ’,换页'\f',换行'\n',回车'\r',制表符'\t'或者垂直制表符'\v'的.

通过返回值来判断是否是空白字符:空格' ’,换页'\f',换行'\n',回车'\r',制表符'\t'或者垂直制表符'\v',如果是这些字符,则返回非0的整数,反之则返回0.

#include <stdio.h>
#include <ctype.h>
int main()
{char a = ' ';char b = '\v';char c = 'A';char d = '\t';printf("%d\n",isspace(c));printf("%d\n",isspace(b));printf("%d\n",isspace(a));printf("%d\n",isspace(d));return 0;
}

2.字符转换函数

C语言提供了2个字符转换函数.

1.:int tolower ( int c ); //将参数传进去的⼩写字⺟转⼤写
2.:int toupper ( int c ); //将参数传进去的⼤写字⺟转⼩写 
#include <stdio.h>
#include <ctype.h>
int main()
{int i = 0;char str[] = "Test String Function.\n";char c;while (str[i]){c = str[i];//若为小写字符if (islower(c))//转换为大写字符c = toupper(c);//若为大写字符else if (isupper(c))//转换为小写字符c = tolower(c);putchar(c);i++;}return 0;
}

3.strlen函数的使用与模拟实现

3.1:strlen的使用

size_t strlen ( const char * str );
  • 字符串以'\0'作为结束标志,strlen函数返回的是在字符串中'\0'前面出现的字符个数(不包含'\0').
  • 参数指向的字符串必须要以'\0'结束.
  • 注意函数的返回值为size_t,是无符号的.
#include <stdio.h>
#include <string.h>
int main()
{const char* str1 = "abcdefg";const char* str2 = "abde";if (strlen(str1) > strlen(str2))printf("str1 > str2");elseprintf("str2 > str1");return 0;
}

3.2:strlen的模拟实现

3.2.1:计数器的方式

#include <stdio.h>
#include <string.h>
#include <assert.h>
int my_strlen(const char* str)
{//避免传过来的指针是空指针assert(str);//统计字符出现的个数int count = 0;while (*str != '\0'){count++;str++;}return count;
}
int main()
{const char* str = "abcdefg";printf("%zd\n", my_strlen(str));return 0;
}

上述方式则是通过计数器的方式模拟实现strlen,当*str = '\0'时,此时跳出循环.

3.2.2:递归的方式

#include <stdio.h>
#include <string.h>
#include <assert.h>
int my_strlen(const char* str)
{assert(str);if (*str == '\0')return 0;return 1 + my_strlen(str + 1);
}
int main()
{const char* str = "abcdefg";printf("%zd\n", my_strlen(str));return 0;
}

3.2.3:指针-指针的方式

#define  _CRT_SECURE_NO_WARNINGS
#include <assert.h>
#include <stdio.h>
int mystrlen(const char* str)
{assert(str);//记录起始位置const char* begin = str;while (*str != '\0'){str++;}return str - begin;
}int main()
{const char* str = "abcdef";int result = mystrlen(str);printf("%d\n", result);return 0;
}

4:strcpy函数的使用与实现.

strcpy函数的功能是将soure指向的字符串拷贝到destination,同时也会拷贝'\0'.

char* strcpy(char * destination, const char * source );
  • 源字符串必须以'\0'结束.
  • 会将源字符串中的'\0'拷贝到目标空间.
  • 目标空间必须足够大,以确保能存放到源字符串.
  • 目标空间必须可变. 

4.1:strcpy函数的使用

#define  _CRT_SECURE_NO_WARNINGS
#include <assert.h>
#include <stdio.h>
#include <string.h>int main()
{char str1[200]= "abc";char str2[150]="hello world";printf("拷贝前:%s\n", str1);strcpy(str1,str2);printf("拷贝后:%s\n",str1);return 0;
}

4.2:strcpy函数的模拟实现

#define  _CRT_SECURE_NO_WARNINGS
#include <assert.h>
#include <stdio.h>
#include <string.h>char* my_strcpy(char* destination, const char* source) 
{char* result = destination;//防止空指针的传递assert(destination && source);while(*source != '\0'){//拷贝当前字符*destination = *source;destination++;source++;}//拷贝'\0'*destination = *source;return result;
}int main()
{char str1[200]= "abc";char str2[150]="hello world";printf("请输入源头字符串:>");scanf("%s",str1);printf("请输入要拷贝的字符串:>");scanf("%s",str2);printf("拷贝前:%s\n", str1);my_strcpy(str1, str2);printf("拷贝后:%s\n",str1);return 0;
}

5:strcat函数的使用与实现

strcat的功能是追加字符串,将目标字符串追加到源字符串的后面,同时也会追加\0'.

  • 源字符串必须以'\0'结束.
  • 目标字符串也得有'\0',否则没办法知道追加从哪里开始.
  • 目标空间必须有足够的大,能够容纳下源字符串的内容.
  • 目标空间必须可修改.

5.1:strcat函数的使用

#define  _CRT_SECURE_NO_WARNINGS
#include <assert.h>
#include <stdio.h>
#include <string.h>int main()
{char str1[200]= "abc";char str2[150]="hello world";printf("追加前:%s\n", str1);strcat(str1, str2);printf("追加后:%s\n",str1);return 0;
}

5.2:strcat函数的模拟实现

#define  _CRT_SECURE_NO_WARNINGS
#include <assert.h>
#include <stdio.h>
#include <string.h>char* my_strcat(char* destination, const char* source) 
{char* result = destination;//防止空指针的传递assert(destination && source);//目标字符串遍历到'\0'的位置while (*destination != '\0'){destination++;}while (*source != '\0'){//进行追加*destination = *source;destination++;source++;}//拷贝'\0'*destination = *source;return result;
}int main()
{char str1[200]= "abc";char str2[150]="hello world";printf("请输入源头字符串:>");scanf("%s",str1);printf("请输入要拷贝的字符串:>");scanf("%s",str2);printf("追加前:%s\n", str1);my_strcat(str1, str2);printf("追加后:%s\n",str1);return 0;
}

6:strcmp的使用与模拟实现

strcmp的功能是比较字符串的大小.

  • 第⼀个字符串大于第二个字符串,则返回⼤于0的数字
  • 第⼀个字符串等于第二个字符串,则返回0
  • 第⼀个字符串小于第二个字符串,则返回⼩于0的数字
  • 那么如何判断两个字符串? ⽐较两个字符串中对应位置上字符ASCII码值的大小.

6.1:strcmp的使用

#define  _CRT_SECURE_NO_WARNINGS
#include <assert.h>
#include <stdio.h>
#include <string.h>int main()
{char str1[200]= "abc";char str2[150]="hello world";printf("请输入源头字符串:>");scanf("%s",str1);printf("请输入要比较的字符串:>");scanf("%s",str2);if(strcmp(str1,str2) > 0){printf("str1 > str2\n");}else if (strcmp(str1, str2) == 0){printf("str1 == str2");}else{printf("str1 < str2");}return 0;
}

6.2:strcmp的模拟实现

#define  _CRT_SECURE_NO_WARNINGS
#include <assert.h>
#include <stdio.h>
#include <string.h>int my_strcmp(const char * str1,const char * str2)
{//防止空字符串assert(str1);assert(str2);//越过相等的字符while(*str1 == *str2){/*确认当循环退出时(即*str1和*str2不再相等)如果* str1 是 '\0',则说明 str1 和 str2 是相等的,因为它们都到达了结束符*/if (*str1 == '\0')return 0;str1++;str2++;}return *str1 - *str2;
}int main()
{char str1[200]= "abc";char str2[150]="hello world";printf("请输入源头字符串:>");scanf("%s",str1);printf("请输入要比较的字符串:>");scanf("%s",str2);if(my_strcmp(str1,str2) > 0){printf("str1 > str2\n");}else if (my_strcmp(str1, str2) == 0){printf("str1 == str2");}else{printf("str1 < str2");}return 0;
}

7:strncpy函数的使用与模拟实现

7.1:strncpy函数的使用

char * strncpy ( char * destination, const char 1 * source, size_t num );
  • 拷贝num个字符从源字符串到目标空间。
  • 如果源字符串的长度小于num,则拷贝完源字符串之后,在目标的后边追加0,直到num个.
#define  _CRT_SECURE_NO_WARNINGS
#include <assert.h>
#include <stdio.h>
#include <string.h>int main()
{int num = 0;char str1[200]= "abc";char str2[150]="hello world";printf("请输入源头字符串:>");scanf("%s",str1);printf("请输入要拷贝的字符串:>");scanf("%s",str2);printf("请输入要拷贝的字符个数:>");scanf("%d",&num);printf("拷贝前:>%s\n", str1);strncpy(str1, str2, num);printf("拷贝后:>%s\n", str1);return 0;
}

7.2:strncpy函数的模拟实现

#define  _CRT_SECURE_NO_WARNINGS
#include <assert.h>
#include <stdio.h>
#include <string.h>char* my_strncpy(char* str1, const char* str2, size_t num)
{char* result = str1;//防止空字符串assert(str1);assert(str2);//拷贝字符串while (num--){*str1 = *str2;str1++;str2++;}return result;
}int main()
{int num = 0;char str1[200] = "abc";char str2[150] = "hello world";printf("请输入源头字符串:>");scanf("%s", str1);printf("请输入要拷贝的字符串:>");scanf("%s", str2);printf("请输入要拷贝的字符个数:>");scanf("%d", &num);printf("拷贝前:>%s\n", str1);my_strncpy(str1, str2, num);printf("拷贝后:>%s\n", str1);return 0;
}

8.:strncat函数的使用与模拟实现

8.1:strncat函数的使用

比较str1和str2的前num个字符,如果相等就继续往后比较,最多比较num个字⺟,如果提前发现不一样,就提前结束,大的字符所在的字符串大于另外一个。如果num个字符都相等,就是相等返回0.
#define  _CRT_SECURE_NO_WARNINGS
#include <assert.h>
#include <stdio.h>
#include <string.h> int main()
{int num = 0;char str1[200]= "abc";char str2[150]="hello world";printf("请输入源头字符串:>");scanf("%s",str1);printf("请输入要追加的字符串:>"); scanf("%s",str2);printf("请输入要追加的字符个数:>");scanf("%d",&num);printf("追加前:>%s\n", str1);strncat(str1, str2, num);printf("追加后:>%s\n", str1);return 0;
}

8.2:strncat的模拟实现
 

#define  _CRT_SECURE_NO_WARNINGS
#include <assert.h>
#include <stdio.h>
#include <string.h> 
char * my_strncat(char * str1,const char * str2,size_t num)
{char* result = str1;//防止空字符串assert(str1);assert(str2);while(num--){*str1 = *str2;str1++;str2++;}return str1;
}int main()
{int num = 0;char str1[200]= "abc";char str2[150]="hello world";printf("请输入源头字符串:>");scanf("%s",str1);printf("请输入要追加的字符串:>"); scanf("%s",str2);printf("请输入要追加的字符个数:>");scanf("%d",&num);printf("追加前:>%s\n", str1);strncat(str1, str2, num);printf("追加后:>%s\n", str1);return 0;
}

9.strncmp函数的使用与模拟实现

9.1:strncmp函数的使用

int main()
{int num = 0;char str1[200]= "abc";char str2[150]="hello world";printf("请输入源头字符串:>");scanf("%s",str1);printf("请输入要比较的字符串:>"); scanf("%s",str2);printf("请输入要比较的字符个数:>");scanf("%d",&num);size_t result = strncmp(str1, str2, num);if(result > 0){printf("str1 > str2\n");}else if( result == 0){printf("str1与str2的前num个字符相等\n");}else{printf("str1 < str2\n");}return 0;
}

9.2:strncmp函数的模拟实现

#define  _CRT_SECURE_NO_WARNINGS
#include <assert.h>
#include <stdio.h>
#include <string.h> 
int my_strncmp(const char* str1, const char* str2, size_t num)
{//防止空字符串assert(str1);assert(str2);while (num != 0 && (*str1 == *str2)){/*确认当循环退出时(即*str1和*str2不再相等)如果* str1 是 '\0',则说明 str1 和 str2 是相等的,因为它们都到达了结束符*/if (*str1 == '\0')return 0;str1++;str2++;num--;}return *str1 - *str2;
}int main()
{int num = 0;char str1[200] = "abc";char str2[150] = "hello world";printf("请输入源头字符串:>");scanf("%s", str1);printf("请输入要比较的字符串:>");scanf("%s", str2);printf("请输入要比较的字符个数:>");scanf("%d", &num);size_t result = strncmp(str1, str2, num);if (result > 0){printf("str1 > str2\n");}else if (result == 0){printf("str1与str2的前num个字符相等\n");}else{printf("str1 < str2\n");}return 0;
}

10:strstr的使用与模拟实现

char * strstr(const char*,const char *);

strstr函数用户匹配字符串,用于匹配str2是否是str1的子串,如果是,那么则会返回子串的首字符在str1的首字符地址.

10.1:strstr的使用

#define  _CRT_SECURE_NO_WARNINGS
#include <assert.h>
#include <stdio.h>
#include <string.h> int main()
{int num = 0;char str1[200]= "abc";char str2[150]="hello world";printf("请输入源头字符串:>");scanf("%s",str1);printf("请输入子串:>"); scanf("%s",str2);char* result = strstr(str1, str2);if(result != NULL){printf("%s\n", result);}else{printf("无法匹配到\n");}return 0;
}

10.2:strstr的模拟实现

#define  _CRT_SECURE_NO_WARNINGS
#include <assert.h>
#include <stdio.h>
#include <string.h> 
const char * my_strstr(const char * str1,const char * str2)
{assert(str1);assert(str2);//用于遍历字符串const char* begin1 = str1;const char* begin2 = str2;//记录起始位置const char* temp = str1;const char* result = str2;while (*begin1 != '\0'){//相等直接越过,while(*begin1 == *begin2){begin1++;begin2++;if(*begin2 == '\0'){return temp;}}//走到这里说明不匹配,那么起始位置++temp++;//源头字符串++begin1 = temp;//匹配字符串回到起始位置begin2 = str2;}return NULL;
}int main()
{int num = 0;char str1[200]= "abc";char str2[150]="hello world";printf("请输入源头字符串:>");scanf("%s",str1);printf("请输入子串:>"); scanf("%s",str2);const char* result = my_strstr(str1, str2);if(result != NULL){printf("%s\n", result);}else{printf("无法匹配到\n");}return 0;
}

11:strtok函数的使用

char * strtok(char * str,const char * sep);

  •          sep参数指向⼀个字符串,定义了用作分隔符的字符集合.
  •         第⼀个参数指定⼀个字符串,它包含了0个或者多个由sep字符串中⼀个或者多个分隔符分割的标记。
  •         strtok函数找到str中的下⼀个标记,并将其用\0 结尾,返回⼀个指向这个标记的指针.(注:strtok函数会改变被操作的字符串,所以在使用strtok函数切分的字符串⼀般都是临时拷贝的内容并且可修改)
  •         strtok函数的第⼀个参数不为 NULL,函数将找到str中第⼀个标记,strtok函数将保存它在字符串中的位置。
  •         strtok函数的第⼀个参数为 NULL,函数将在同⼀个字符串中被保存的位置开始,查找下⼀个标记。
  •          如果字符串中不存在更多的标记,则返回 NULL 指针。
#define  _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <string.h>
int main()
{char arr[] = "192.168.6.111";const char* sep = ".";char* str = NULL;for (str = strtok(arr, sep); str != NULL; str = strtok(NULL, sep)){printf("%s\n", str);}return 0;
}

12:strerror函数的使用

char * strerror ( int errnum );
strerror函数可以把参数部分错误码对应的错误信息的字符串地址返回来。
在不同的系统和C语言标准库的实现中都规定了⼀些错误码,⼀般是放在 errno.h 这个头⽂件中说明的,C语言程序启动的时候就会使用⼀个全⾯的变量errno来记录程序的当前错误码,只不过程序启动
的时候errno是0,表示没有错误,当我们在使⽤标准库中的函数的时候发⽣了某种错误,就会讲对应
的错误码,存放在errno中,而⼀个错误码的数字是整数很难理解是什么意思,所以每⼀个错误码都是.
有对应的错误信息的。strerror函数就可以将错误对应的错误信息字符串的地址返回.
#include <errno.h>
#include <string.h>
#include <stdio.h>
//我们打印⼀下0~10这些错误码对应的信息
int main()
{int i = 0;for (i = 0; i <= 10; i++) {printf("%s\n", strerror(i));}return 0;
}


好啦,uu们,字符函数与字符串函数这部分滴详细知识博主就讲到这里啦,如果uu们觉得博主讲的不错的话,请动动你们滴小手给博主点点赞,你们滴鼓励将成为博主源源不断滴动力,同时也欢迎大家来指正博主滴错误~.

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/400714.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【C语言篇】C语言常考及易错题整理DAY3

文章目录 选择题整形提升与算术转换左移右移操作符操作符优先级与结合性后置指针变量基本知识 编程题最大连续1的个数完全数计算单词倒排面试题.珠玑妙算两数之和 选择题 整形提升与算术转换 声明以下变量&#xff0c;则表达式: ch/i (f*d – i) 的结果类型为&#xff08; &…

<Qt> 系统 - 网络编程 | 音视频

目录 前言&#xff1a; 一、QUdpSocket &#xff08;一&#xff09;核心 API 概览 &#xff08;二&#xff09;设计一个UDP回显服务器 二、QTCPSocket &#xff08;一&#xff09;核心 API 概览 &#xff08;二&#xff09;设计一个TCP回显服务器 三、HTTP Client 四、…

msgqueue.hpp队列模块

目录 一.MsgQueue模块介绍 二.MsgQueue类的实现 成员变量 构造函数与析构函数 成员函数 参数设置函数 setArgs 参数获取函数 getArgs 三.MsgQueueMapper类的实现 成员变量 构造函数 成员函数 创建表格函数 createTable 删除表格函数 dropTable 插入数据函数 inse…

GPT-4o:开启多模态AI识别新纪元

GPT-4o功能简介 在人工智能的演变历程中&#xff0c;图像识别技术始终占据着核心地位。技术的发展日新月异&#xff0c;使得AI不仅能够识别图像内容&#xff0c;还能将其转化为文字描述。特别值得一提的是&#xff0c;OpenAI在春季发布的GPT-4o模型&#xff0c;将图像识别技术…

微软Detours Hook库编译与使用

Detours 是微软开发的一个强大的Windows API钩子库&#xff0c;用于监视和拦截函数调用。它广泛应用于微软产品团队和众多独立软件开发中&#xff0c;旨在无需修改原始代码的情况下实现函数拦截和修改。Detours 在调试、监控、日志记录和性能分析等方面表现出色&#xff0c;已成…

shell命令行解释器—既陌生有熟悉的东西

今天做一个感性的认识来&#xff0c;用一个生活的例子。 你生活在有一条村子里面&#xff0c;在村的东边就是王婆&#xff0c;王婆呢&#xff1f;她主要做什么呢啊&#xff1f;她在村儿里面呢&#xff0c;也不种地啊&#xff0c;那她干什么呢&#xff1f;他主要做帮别人进行婚嫁…

【TabBar嵌套Navigation案例-发现页面-按钮上的图片旋转 Objective-C语言】

一、接下来,我们来做这个,点击以后,让它出一个蓝色的View 1.就是我们示例程序的这种效果, 一点击,让这个按钮旋转,然后呢,再让它出来一个蓝色的View, 首先,我们要去监听它的点击事件,这是第一,我点击以后,我要做一些什么样的操作,要有点击事件, 所以呢,我要把…

JS基础进阶Webs-API、HTML 、DOM

一、JS中的API 1. 定义 JavaScript API是指为JavaScript提供的一组编程接口和对象&#xff0c;用以允许开发者访问和操作Web浏览器或其他JavaScript环境&#xff08;如Node.js&#xff09;提供的特定功能。这些API使得开发者能够编写更加动态和交互式的Web应用程序。 2. 主要…

服务器数据恢复—raid5阵列热备盘未全部启用导致阵列崩溃的数据恢复案例

服务器存储数据恢复环境&#xff1a; 一台EMC某型号存储中有一组RAID5磁盘阵列。该raid5阵列中有12块硬盘&#xff0c;其中2块硬盘为热备盘。 服务器存储故障&#xff1a; 该存储raid5阵列中有两块硬盘离线&#xff0c;只有1块热备盘启用替换掉其中一块离线盘&#xff0c;另外…

​产品经理-​你如何理解“互联网思维(35)

在产品规划和功能改版中&#xff0c;确实非常重视用户需求和体验。产品需求是互联网产品的核心 用户体验是互联网产品的重点。在互联网新产品规划中&#xff0c;会非常重视用户验证环节 确保做出来的东西确实是用户想要的&#xff1b;而在已经上线的产品中&#xff0c;往往会有…

人工智能与机器学习原理精解【12】

文章目录 分级聚类理论分级聚类的详细说明1. 定义2. 算法3. 计算4. 例子5. 例题 皮尔逊相关系数 julia实现 参考文献 分级聚类 理论 分级聚类的详细说明 1. 定义 分级聚类&#xff08;Hierarchical Clustering&#xff09;&#xff0c;又称为层次聚类&#xff0c;是一种通过…

谷歌反垄断官司败诉后,或又面临被拆分风险?

KlipC报道&#xff1a;上周8月5日&#xff0c;美国法院裁定谷歌的搜索业务违反了美国反垄断法&#xff0c;非法垄断在线搜索和搜索文本广告市场。据悉&#xff0c;胜诉的美国司法部正在考虑拆分谷歌。其他选项包括强制谷歌与竞争对手分享更多数据&#xff0c;以及防止其在人工智…

【二叉树进阶】--- 根据二叉树创建字符串

Welcome to 9ilks Code World (๑•́ ₃ •̀๑) 个人主页: 9ilk (๑•́ ₃ •̀๑) 文章专栏&#xff1a; 数据结构 从本篇文章开始&#xff0c;博主将分享一些结合二叉树的进阶算法题。 &#x1f3e0; 根据二叉树创建字符串 &#x1f4cc; 题目内容 根据二叉…

从行为面试问题(behavioral questions)看中美程序员差异。

中美程序员在职场中的工作状态和职能、福利等有很大区别&#xff0c;从面试中的BQ轮就可见一斑。 中美程序员的面试轮差异&#xff1f; 国内的面试轮在不同公司间差异很大&#xff0c;但总体的问题类型包含笔试面试&#xff08;算法题、概念题、项目深挖、职业目标、职场文化…

FGUI+TS如何实现数字翻滚

FGUITS如何实现数字翻滚 实现效果如下&#xff1a; 实现步骤&#xff1a; fgui制作组件和特效 fgui制作组件&#xff0c;设置一条竖向数字包含1-9或者小数点符号等&#xff0c;可见区域为一个数字大小&#xff0c;最好可见区域紧贴数字&#xff0c;这样滚动的时候滚动区域范围…

深度学习------------------卷积神经网络(LeNet)

目录 LeNet网络手写的数字识别MNIST总结卷积神经网络&#xff08;LeNet&#xff09; 问题 LeNet网络 手写的数字识别 MNIST ①输入的是&#xff1a;3232的image ②放到一个55的卷积层里面&#xff08;为什么是5&#xff1f;因为32-x128&#xff0c;∴x5&#xff09;&#xff0c…

【教程】Ubuntu给pycharm添加侧边栏快捷方式

转载请注明出处&#xff1a;小锋学长生活大爆炸[xfxuezhagn.cn] 如果本文帮助到了你&#xff0c;欢迎[点赞、收藏、关注]哦~ 以下教程不仅限于pycharm&#xff0c;其他软件也是一样操作 1、进入到pycharm的目录&#xff0c;先通过命令行打开pycharm&#xff1a; ./bin/pycharm…

keepalived+haproxy高可用负载均衡集群

简介 使用haproxy制作负载均衡集群&#xff0c;keepalived通过状态检测脚本检测本机haproxy状态&#xff0c;若为离线状态&#xff0c;则会降低该节点的优先级。 实验准备 四台虚拟机&#xff1a;KA1、KA2为keepalivedhaproxy&#xff0c;web1、web2为后端服务器&#xff0c;均…

阿里云-java调用短信服务,第三方接口的开启(傻瓜式教程)

第一步&#xff1a;在浏览器中&#xff0c;搜索阿里云 第二步&#xff1a;打开aly的主页 第三步&#xff1a;在最上方的导航栏中&#xff0c;找到云市场&#xff0c;注意不要点击&#xff0c;会自动有触发悬浮框出现&#xff0c;在悬浮框中找到 短信 第四步&#xff1a;点击 短…

无人机之电池注意事项

1、外场作业时&#xff0c;电池一定要放置在阴凉处&#xff0c;避免太阳直射&#xff1b; 2、刚作业完的电池发热严重时&#xff0c;请降至室温再充电&#xff1b; 3、注意电池状态&#xff0c;一旦发现电池出现鼓包、漏液等现象&#xff0c;必须马上停止使用&#xff1b; 4…