C语言——详解字符函数和字符串函数(一)

在这里插入图片描述

Hi,铁子们好呀!今天博主来给大家更一篇C语言的字符函数和字符串函数~
具体讲的内容如下:
在这里插入图片描述

在这里插入图片描述

文章目录

  • 🎆1.字符分类函数💯💯
    • ⏩1.1 什么是字符分类函数的?💯💯
    • ⏩1.2 字符函数的类型有哪些?💯💯
    • ⏩1.3 字符函数`islower`介绍及模拟实现💯💯
      • ⏩1.3.1`islower`函数具体介绍💯💯
      • ⏩1.3.2`islower`函数代码实现及效果💯💯
    • ⏩1.4字符分类函数练习💯💯
  • 🎆2.字符转换函数💯💯
    • ⏩2.1代码实现💯💯
  • 🎆 3.strlen的使用和模拟实现💯💯
    • ⏩3.1strlen函数的使用💯💯
      • ⏩3.1.1 strlen函数相关练习💯💯
    • ⏩3.2 strlen函数三种模拟实现💯💯
      • ⏩3.2.1 创建临时变量count💯💯
      • ⏩ 3.2.2 指针-指针💯💯
      • ⏩ 3.2.3 递归法求字符串长度💯💯
  • 🎆4.strcpy的使用和模拟实现💯💯
    • ⏩4.1 strcpy的使用规则💯💯
    • ⏩4.2 strcpy函数的基本使用💯💯
    • ⏩4.3 strcpy函数的模拟实现💯💯
      • ⏩4.3.1 strcpy函数的模拟实现方法1💯💯
  • 🎆5.strcat的使用和模拟实现💯💯
    • ⏩5.0.1 strcat函数简单介绍💯💯
      • ⏩5.0.1.1什么是strcat函数呢?函数原型是什么?💯💯
    • ⏩5.1 strcat的使用规则💯💯
    • ⏩5.2 strcat的使用和模拟实现💯💯
      • ⏩ 5.2.1strcat的使用💯💯
      • ⏩ 5.2.2 strcat的模拟实现💯💯

前言: 在编程的过程中,我们经常要处理字符和字符串,C语言标准库中提供了一系列库函数,接下来我们就学习一下这些函数。

🎆1.字符分类函数💯💯

⏩1.1 什么是字符分类函数的?💯💯

众所周知,C语言中提供了一系列的字符函数,这些字符函数专门做字符分类的。
通俗点来讲: 这些函数就是判断这个字符是属于什么类型的字符的。
需要注意的是: 这些字符函数都需要包含头文件#include<ctype.h>

⏩1.2 字符函数的类型有哪些?💯💯

如下图所示:

在这里插入图片描述从图中,我们发现这些函数的使用方法其实非常类似,我们这里就讲一个字符函数islower吧,其他函数的实现方法也是跟这个比较类似~

⏩1.3 字符函数islower介绍及模拟实现💯💯

islower函数原型如下:

int islower(int c);

⏩1.3.1islower函数具体介绍💯💯

如下两图所示:
在这里插入图片描述
在这里插入图片描述
分析: 从这两幅图,我们可以看出islower是判断它的函数参数部分的c是否为小写字母的。
我们可以通过返回值来说明是否是小写字母,如果是小写字母就返回非0的整数,如果不是小写字母,则返回0

⏩1.3.2islower函数代码实现及效果💯💯

在这里插入图片描述
代码如下:

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

在这里插入图片描述
从动图中: 我们直观地看出如果islower函数的参数部分是小写字母,返回的是非0的数字。如果参数部分是大写字母或者其他类型的字符,则返回0

好,讲到这里,相信同学们就知道字符分类函数怎么用了,大家可以下去尝试一下,多实践~

⏩1.4字符分类函数练习💯💯

练习:

写一个代码,将字符串中的小写字母转大写,其他字符不变。

那这道题我们应该怎么思考呢?
我们来看下图:
在这里插入图片描述
我们来看下面的Ascll码值,可以看出大写字母'A''B'Ascll码值分别为65和66,小写字母'a''b'Ascll码值分别为97和98。
所以我们可以得出一个结论: 大写和小写的Ascll码值分别相差32
当我们知道这个结论,这题就很好做了,我们可以先创建一个字符数组,用islower函数遍历每一个字符,如果是小写字母,就让它的ASCLL码值-32即可。

当我们把题目分析成这样,代码自然可以顺理成章地写出来。

#include <stdio.h>
#include <ctype.h>
int main() {int i = 0;char str[] = "Test String.";while (str[i]) {if (islower(str[i])) {str[i] -= 32;}i++;}printf("%s\n", str);return 0;
}

这里我们要提醒一下:我们知道\0是字符串的结束标志,所以当while循环中的str[i]\0时,也就是为假,这是为什么呢?
如下图:
在这里插入图片描述
我么可以看出\0对应的ASCLL码值为0,那0为假,便跳出while循环,然后我们再来看printf部分,它这里是以%s的形式打印,那以%s本质上就是从那个地址开始,往后打印字符串,直到遇到\0为止。而这里的str恰好是数组名,我们之前就在这篇文章:C语言-指针讲解(2)讲过数组名是数组首元素的地址。所以这里本质上就是从arr首字符地址开始打印,直到遇到\0为止。

🎆2.字符转换函数💯💯

C语言提供了2个字符转换函数
它们的函数原型如下:

1 int tolower ( int c ); //将参数传进去的大写字母转小写
2 int toupper ( int c ); //将参数传进去的小写字母转大写

上面我们写的代码将小写字母转换为大写,是ASCLL码值-32完成的效果。但有了转换函数,就可以直接使用tolower函数。

⏩2.1代码实现💯💯

在这里插入图片描述

#include <stdio.h>
#include <ctype.h>
int main() {int i = 0;char str[] = "Test String.";while (str[i]) {if (islower(str[i])) //判断该字符是否为小写字母{str[i] = toupper(str[i]);//将对应字符的小写字母转换为大写字母}i++;}printf("%s\n",str);//从str的首元素地址开始打印字符串,直到遇到'\0'为止。return 0;
}

vs运行效果图:在这里插入图片描述

🎆 3.strlen的使用和模拟实现💯💯

它的函数原型如下:

size_t strlen( const char*str)

strlen函数使用规则如下:

  • 字符串以'\0'作为结束标志,strlen函数返回到是在字符串中'\0'前面出现的字符个数(不包含'\0')。
  • 参数指向的字符串必须要以'\0'结束。
  • 注意函数的返回值为size_t,是无符号的(易错)
  • strlen的使用需要包含头文件#include<string.h>

⏩3.1strlen函数的使用💯💯

好,这里首先讲一下strlen函数的基本使用
代码如下:

#include<stdio.h>
#include<string.h>
int main() {char arr[] = "abcdef";//字符串是以'\0'为结束标志的printf("%zd\n", strlen(arr));//这里因为strlen函数是size_t类型,所以最好用%zd打印,以防vs弹出警告//需要注意的是:strlen函数计算的是'\0'之前的字符个数return 0;
}

相信同学们看了上面的代码以及注释,应该能够理解代码的逻辑。

VS运行效果:
在这里插入图片描述

⏩3.1.1 strlen函数相关练习💯💯

刚刚我们讲到了要注意strlen函数的返回值为size_t,这是为什么呢?下面我们来看一下这个代码案例。

代码如下:

#include <stdio.h>
#include <string.h>
int main() {const char* str1 = "abcdef";const char* str2 = "bbb";if (strlen(str2) - strlen(str1) > 0) {printf("str2>str1\n");}else {printf("str1>str2\n");}return 0;
}

这道题想必很多同学是这么想: 由于那个str1str2数组存放的是字符串首字符的地址,那strlen函数就是计算\0之前的字符个数。
那他们肯定觉得strlen函数计算str2数组的字符个数为3个,str1数组的字符个数为6个。所以肯定会认为strlen(str2)-strlen(str1)那个语句就是3-6=-3,是<0
那肯定会打印str1>str2这句话。那这是不对的。
我们不妨先用VS测试这个代码,看看运行效果是怎么样先~
在这里插入图片描述
我们发现它确实执行else语句那句话,为什么呢?别急,接下来博主给你娓娓道来!

在这里插入图片描述

因为本质上那个strlen函数计算字符串的相加相减都本质上都是无符号的整数的减法
那它们相减,得出的数也是无符号整数的,肯定也会大于0。这是为什么呢?
看下图:
在这里插入图片描述
相信同学们看了这个图,也能够理解更加理解这个无符号整数的意思。
因为无符号整数就是不会考虑符号位,只是关注数值位。并且无符号整数是使用该数的二进制补码来存储。因此它的数肯定是大于0的。

好,相信同学们听到这里,也会理解这个代码的逻辑了~

那如果说我们真想让代码执行>str1>str2\n那句话,该怎么做呢?
我们可以这么做,将strlen这个函数无符号size_t类型强制转换为int整型,那这样就可以打印"str2>str1\n"那句话。
VS代码运行效果:
在这里插入图片描述
通过执行结果,我们发现程序的确执行str1>str2那句话。

好,相信讲到这里,同学们应该就理解了。那我们接着就讲三种模拟实现strlen函数~

⏩3.2 strlen函数三种模拟实现💯💯

⏩3.2.1 创建临时变量count💯💯

代码如下:

#include <stdio.h>
#include <stdio.h>
size_t my_strlen(char* s)//这里我们函数my_strlen类型写成size_t,这是因为字符串的长度绝对是大于0等于0的,因此我们直接就写成size_t类型就行{int count = 0;//创建临时变量count,初始化为0while (*s)//当*s=='\0','\0'对应的ASCLL码值为0,0为假,便跳出while循环。{count++;//随着变量字符指针s往后遍历,count变量的值不断自增s++;//字符指针往后遍历}return count;
}int main() {char str[] = "abcdef";size_t ret = my_strlen(str);//这里我们是将str首元素地址传过去printf("%zd\n", ret);//因为这是用size_t数据类型创建的变量ret,所以我们使用%zd来格式化输出。return 0;
}

相信同学们看了这个代码,以及这个注释,是能够理解这个代码逻辑的。

VS运行效果如下:在这里插入图片描述

⏩ 3.2.2 指针-指针💯💯

代码如下:

#include <stdio.h>
#include <stdio.h>
size_t my_strlen(char* s)//这里我们函数my_strlen类型写成size_t,这是因为字符串的长度绝对是大于0等于0的,因此我们直接就写成size_t类型就行
{char* ptr = s;//这里是将字符串首元素地址赋给指针变量ptrwhile (*s)s++;//只要*s不是'\0',*s都往后遍历return s - ptr;//这里本质上把字符指针s最后的地址-ptr首元素的地址,这样就能得到两个指针相差的元素个数。
}
int main() {char str[] = "abcdef";size_t ret = my_strlen(str);//这里我们是将str首元素地址传过去printf("%zd\n", ret);//因为这是用size_t数据类型创建的变量ret,所以我们使用%zd来格式化输出。return 0;
}

相信同学们看了这个代码,以及这个注释,是能够理解这个代码逻辑的。

VS运行效果如下:
在这里插入图片描述

⏩ 3.2.3 递归法求字符串长度💯💯

这里的递归法求字符串长度估计很多同学比较懵,我们先画个图分析先:
如下:
在这里插入图片描述
相信同学们看了这个图,自己应该能够很好地理解递归这个方法,大家可以自己尝试自己用递归法实现这个算法~

要是还想不出来,博主这里直接上代码~
在这里插入图片描述
代码如下:

#include <stdio.h>
#include <stdio.h>
size_t my_strlen(char* s)//这里我们函数my_strlen类型写成size_t,这是因为字符串的长度绝对是大于0等于0的,因此我们直接就写成size_t类型就行
{if (*s == '\0') {return 0;//当*s指向的元素为'\0',直接返回0,用作递归的结束条件}else {return 1 + my_strlen(s + 1);//如果*s指向的元素不是'\0',那么说明字符串里面的字符最少都有1个,因此我们就返回1+后面字符串中字符的长度。}}int main() {char str[] = "abcdef";size_t ret = my_strlen(str);//这里我们是将str首元素地址传过去printf("%zd\n", ret);//因为这是用size_t数据类型创建的变量ret,所以我们使用%zd来格式化输出。return 0;
}

这里博主这里简单画了递归调用图,大家可以看一下理解理解~
在这里插入图片描述

VS运行效果图如下:
在这里插入图片描述
我们发现,用递归法实现的算法,它的结果也是6。

🎆4.strcpy的使用和模拟实现💯💯

strcpy它的函数原型如下:

char* strcpy(char * destination, const char * source );

这里我们来解读一下,这里destination指的是目标位置的起始地址,source指的是所要拷贝那个字符串内容的起始地址。

好,我们就细细地讲一下它的规则吧~

⏩4.1 strcpy的使用规则💯💯

  • 源字符串必须以’\0’结束。
  • 会将源字符串中的’\0’拷贝到目标空间。
  • 目标空间必须足够大,以确保能存放源字符串
  • 目标空间必须可修改

好,当我们介绍了strcpy的规则后,接下来博主将给大家讲解strcpy的模拟实现。

⏩4.2 strcpy函数的基本使用💯💯

好,接下来博主给大家演示一下strcpy函数的基本使用。

代码如下:

#include<stdio.h>
#include<string.h>
int main() {char arr1[] = "abcdef";//这里的arr1数组是默认有'\0'的,因为字符串是以'\0'为结束标志的。char arr2[20];//这里初始化arr2数组的长度务必要确保目标内存区域足够大以容纳源字符串,否则会造成数组越界strcpy(arr2, arr1);//这里的strcpy库函数拷贝会顺便拷贝'\0'printf("%s\n", arr2);//这里打印是从arr2的首元素地址开始逐一打印字符串,直到遇到'\0'才停止。return 0;
}

相信大家看了博主写的代码以及注释,自己应该能够理解这个代码的逻辑。

VS运行效果如下:
在这里插入图片描述

⏩4.3 strcpy函数的模拟实现💯💯

这里可能很多同学是有点没思路的,没事,博主这里会提供思路,让大家能够深刻地理解strcpy是怎么模拟实现的~

⏩4.3.1 strcpy函数的模拟实现方法1💯💯

首先,来看下图:
在这里插入图片描述
分析: 这里我们主要是通过数组遍历的方式来逐一拷贝,因为'\0'作为字符串的结束标志。所以只要arr1数组的内容不是'\0',就在while循环内部逐一进行拷贝,每拷贝一个字符,两个指针都向后偏移一个元素。
直到遇到'\0'为止。最后当arr1指向的内容为'\0',条件为假,便跳出while循环。最后我们再把arr1的内容拷到arr2中就行。

好,当我们分析成这样,代码也能顺理成章地写出来。
代码如下:

//}#include<stdio.h>
void my_strcpy(const char* src, char* dest)//*src指向的是arr1数组首元素的地址,*dest指向的是arr2数组首元素的地址
{while (*src)//当*src指向的元素是'\0',则表达式为假,便跳出while循环{*dest = *src;//将src字符串的内容一个一个地拷贝到dest中。dest++;//指针往后遍历src++;//指针往后遍历}*dest = *src;//由于之前因为*src指向的元素是'\0',所以跳出while循环,那因为\0是字符串的结束标志,之前我们没有把\0拷贝到指针变量dest中,所以这里就要把\0拷到dest。
}int main() {char arr1[] = "abcdef";char arr2[20];my_strcpy(arr1,arr2);//调用my_strcpy函数,把arr1作为源地址,将arr2作为作为目标地址printf("%s\n", arr2);//这里以%s打印实质上是拿到arr2首元素的地址,逐一往后打印字符串,直到遇到'\0'为止return 0;
}

相信同学们看了这个代码,应该是能够理解这个代码的逻辑

vs运行效果:
在这里插入图片描述

但是我们认为这个代码还是有待改进的,接下来博主将细细讲一下。

首先,我们先打开官网查一下这个函数先。
如图:
在这里插入图片描述
从图中,我们可以看出函数返回值是char*类型的,并且我们发现它返回的是目标字符指针的起始地址,属于我们要创建个指针变量来充当destinmation的起始地址,到时直接返回这个指针变量即可。
如下:

题目分析:
//------1.参数顺序------
//函数的功能,停止条件
//3.assert判断字符串是否为空指针,assert函数头文件为:#include<assert.h>
//4.用const修饰源指针,使其内容不得修改
//5.函数返回值 char* 

那同学们可以根据博主上面的改进代码分析,可以自己尝试改进上面的代码。一会我们会进行讲解~
好,如果大家看了上面的改进代码分析,还是想不到思路的话,可以看一下博主的代码以及注释,自己尝试理解消化一下。
在这里插入图片描述
代码如下:

#include<stdio.h>
#incldue<assert.h>
char* my_strcpy(const char* src, char* dest) //arr1,arr2
{assert(src!=NULL);//用assert断言一下,分别判断src和dest是否都为空指针assert(dest!=NULL);char* ret = dest;//创建个指针变量ret,将src字符指针首元素的地址赋给指针变量retwhile (*dest++=*src++)//这里首先是先对dest字符指针和src字符指针解引用,将src字符赋给dest,然后两个字符指针++,意思是说两个字符指针统一向后偏移一个元素,直到src字符指针指向的元素为'\0',那也就是整个表达式结果就为'\0',即为假,则跳出while循环。{;}return ret;//这里返回的是dest首元素的地址
}int main() {char arr1[] = "abcdef";char arr2[20];//创建这个arr2数组要比arr1数组空间要大,创建小了,如果源字符串的长度还比arr2数组还大,拷贝会造成数组越界my_strcpy(arr1, arr2);//调用my_strcpy函数,把arr1作为源地址,将arr2作为作为目标地址printf("%s\n", arr2);//这里以%s打印实质上是拿到arr2首元素的地址,逐一往后打印字符串,直到遇到'\0'为止return 0;
}

这个代码有个地方写得很好,就是while (*dest++=*src++)这句话,为什么呢? 因为这里既能做到把arr1数组的内容全部拷贝到数组arr2,同时也能做到当*src='\0'的时候,表达式为假,便跳出while循环。
顺便提一下: 这个题目是出自<<高质量C/C++编程》书籍最后的试题部分。
对了,如果同学们想要这本书的电子版,可以私信博主领取,我私发给大家!

🎆5.strcat的使用和模拟实现💯💯

⏩5.0.1 strcat函数简单介绍💯💯

⏩5.0.1.1什么是strcat函数呢?函数原型是什么?💯💯

strcat函数是C语言中的一个字符串拼接函数,它的功能是在一个字符串后面追加上另外一个字符串。
它的函数原型如下:

char * strcat ( char * destination, const char * source );

具体函数介绍如下:
在这里插入图片描述
从图中: 和我们之前介绍的strcpy函数一样,返回的类型都是char*,然后它返回到也是字符指针destination的地址。
同时,我们需要注意的是: strcat函数在拼接字符串的时候会自动在合成字符串的末尾添加'\0'

⏩5.1 strcat的使用规则💯💯

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

⏩5.2 strcat的使用和模拟实现💯💯

⏩ 5.2.1strcat的使用💯💯

好,接下来给大家演示一下strcat是怎么用的,大家可以看一下下面的代码~
代码如下:

#include<stdio.h>
#include<string.h>
int main() {char arr1[20] = "hello ";char arr2[] = "world";strcat(arr1,arr2);//这里实质上是将arr2数组里面的内容拼接到arr1数组中,顺便带上'\0'。printf("%s\n", arr1);return 0;
}

这里如果同学们看了代码还是不太理解它strcat函数的如何进行拼接的话,不要紧~
博主刚刚对那个代码进行调试了一下,动图如下所示:
在这里插入图片描述
细心的话: 我们从动图可以看出,原本数组arr1的内容中的空格字符后面是跟着一个'\0'的,但是经过strcat函数的拷贝后,那个'\0'就给覆盖掉了。
另外,当strcpy函数把arr2全部内容都拷到arr1数组中,会自动在arr1合成字符串中添加一个'\0'字符。
那我们根据这个动图分析 ,自然也能将这个图给画出来,如下:
在这里插入图片描述
所以,它本质上还是用arr2数组中的'w'字符将'\0'给覆盖掉,在拼接后的字符串完的后面添加一个'\0',以此作为字符串的结束标志。
相信同学们看了这个图应该是能够大彻大悟的~

那博主接下来再用VS执行一下这个代码,看看分析得是否正确吧~
在这里插入图片描述

VS运行效果:
在这里插入图片描述
从运行结果来: 我们的分析是正确的,确实是把hellow world这个字符串给打印出来。

接下来,我们就讲一下那个strcat函数的模大家拟实现吧~

⏩ 5.2.2 strcat的模拟实现💯💯

这里可能也会有同学对于strcat不知道如何自己模拟实现,别急,博主分析一下你们就懂啦~
这里是我们实现strcat函数的步骤
如下图所示:
在这里插入图片描述
相信同学们看了这幅图,自己也许有点思路了,但是有些同学可能还是不太懂怎么实现这个算法。

那么博主这里就自己动手实践写了这个代码,并且写了详细的注释,希望同学们能够理解~
代码如下:

#include<stdio.h>
#include<string.h>
#include<assert.h>
char* my_strcat(const char*src,char*dest) //用const修饰源字符串src,以免被修改
{assert(src != NULL);assert(dest != NULL);//判断两个字符串是否为空指针//assert(src && dest);//assert断言写成这样也行,因为NULL的值就为0,&&只要左右两边任意一个表达式0,都是为假的char* ret = dest;//创建临时指针变量ret来接收dest的起始地址while (*dest) //找到dest字符串的'\0'的位置{dest++;//逐一开始往后遍历字符串dest}while (*dest++=*src++);//将src字符串的内容逐一拷贝到,直到遇到'\0'时,拷贝完成后,整个表达式为假,直接跳出while语句return ret;
}int main() {char arr1[20] = "hello ";char arr2[] = "world";char*tmp=my_strcat(arr2,arr1);//这里我们用tmp字符指针变量来接受返回的dest起始地址printf("%s\n", tmp);//这里的话主要是用arr1首元素的地址开始打印字符串,直到遇到'\0'才停止。return 0;
}

代码分析: 相信同学们看了博主写的代码以及注释,应该能够理解这个代码逻辑的,那接下来我们提一下有个代码是有改进之处的,我们发现那个my_strcat函数中的assert断言是可以改写成assert(src && dest)
或许有同学不理解,我们来解释一下~
如图:
在这里插入图片描述
我们发现那个空指针NULL是为0的。而因为之前我们讲&&逻辑与操作符的时候,但凡&&左右一侧为0,那整个表达式都为假。

好,解释了那么多,我们不妨用VS测试一下我们的代码,看看它的运行结果是否符合我们的预期把~
VS运行效果如下:
在这里插入图片描述
我们发现,VS运行结果确实是符合我们预期的,就说明我们这个模拟实现strcat函数的代码逻辑上是没错的。

好,今天的内容我们暂时就讲到这里,希望大家好好吸收这篇博客中介绍的函数,下去多去用这些函数,这样才能学会的~

当然博主这次讲的字符函数和字符串函数(一)仅仅只是一小部分,后续博主会更深层地介绍其他C语言字符和字符串函数,大家就敬请期待吧~

**好,讲到这里,如果大家觉得这篇博客有哪些内容讲得还不太懂,可以私信一下博主,我会给你讲明白。 **

https://img-blog.csdnimg.cn/direct/4df59a6f3b224651851eb00ecb8736db.gif#pic_center

** 如果觉得博主不错的话,欢迎一键三连支持一下博主,谢谢大家!!!**

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

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

相关文章

基于Python的中医药知识问答系统设计与实现

[简介] 这篇文章主要介绍了基于Python的中医药知识问答系统的设计与实现。该系统利用Python编程语言&#xff0c;结合中医药领域的知识和技术&#xff0c;实现了一个功能强大的问答系统。文章首先介绍了中医药知识的特点和传统问答系统的局限性&#xff0c;然后提出了设计思路…

【Java探索之旅】运算符解析 算术运算符,关系运算符

&#x1f3a5; 屿小夏 &#xff1a; 个人主页 &#x1f525;个人专栏 &#xff1a; Java编程秘籍 &#x1f304; 莫道桑榆晚&#xff0c;为霞尚满天&#xff01; 文章目录 &#x1f4d1;前言一、什么是运算符二、算术运算符2.1 基本四则运算&#xff08;-*/%&#xff09;2.2 增…

ThreadLocal基本原理

ThreadLocal基本原理 一、定义 ThreadLocal是java中所提供的线程本地存储机制&#xff0c;可以利用改机制将数据缓存在线程内部&#xff0c;该线程可以在任意时刻、任意方法中获取数据 二、底层原理 ThreadLocal底层是通过ThreadLocalMap来实现的&#xff0c;每个Thread对象中…

Java代码基础算法练习---2024.3.14

其实这就是从我学校的资源&#xff0c;都比较基础的算法题&#xff0c;先尽量每天都做1-2题&#xff0c;练手感。毕竟离我真正去尝试入职好的公司&#xff08;我指的就是中大厂&#xff0c;但是任重道远啊&#xff09;&#xff0c;仍有一定的时间&#xff0c;至少要等我升本之后…

安装nginx

Nginx ("engine x") 是一个高性能的HTTP和反向代理服务器&#xff0c;特点是占有内存少&#xff0c;并发能力强&#xff0c;事实上nginx的并发能力确实在同类型的网页服务器中表现较好&#xff0c;中国大陆使用nginx网站用户有&#xff1a;百度、京东、新浪、网易、腾…

Sui技术帮助Studio Mirai成功实现创意愿景

Brian和Ben Li兄弟对艺术充满热情&#xff0c;通过共同创立的研发工作室Studio Mirai&#xff0c;他们正在探索Web3技术与创意产业的交集。 Studio Mirai的第一个头像类项目&#xff08;profile picture&#xff0c;PFP&#xff09;Tamashi存在于Nozomi World中&#xff0c;这…

备战蓝桥杯Day25 - 二叉搜索树

一、基本概念 二叉搜索树&#xff08;Binary Search Tree&#xff09;&#xff0c;又称为二叉查找树或二叉排序树&#xff0c;是一种具有特定性质的二叉树。 定义&#xff1a;二叉搜索树可以是一棵空树&#xff0c;也可以是具有以下特性的非空二叉树&#xff1a; 若其左子树不…

【Memcached】

memcached 有一个很大的缺陷不能持久化&#xff0c;不能存储在硬盘里 1.NoSQL介绍 NoSQL是对 Not Only SQL、非传统关系型数据库的统称。 NoSQL一词诞生于1998年&#xff0c;2009年这个词汇被再次提出指非关系型、分布式、不提供ACID的数据库设计模式。 随着互联网时代的到…

基于springboot+vue实现电子商务平台管理系统项目【项目源码+论文说明】计算机毕业设计

基于springboot实现电子商务平台管理系统演示 研究的目的和意义 据我国IT行业发布的报告表明&#xff0c;近年来&#xff0c;我国互联网发展呈快速增长趋势&#xff0c;网民的数量已达8700万&#xff0c;逼近世界第一&#xff0c;并且随着宽带的实施及降价&#xff0c;每天约有…

Day63:WEB攻防-JS应用算法逆向三重断点调试调用堆栈BP插件发包安全结合

目录 前置知识 JS调试分析 JS分析调试结合Burp JS分析调试知识点&#xff1a; 1、JavaScript-作用域&调用堆栈 2、JavaScript-断点调试&全局搜索 3、JavaScript-Burp算法模块使用 前置知识 JS加密数据走向 浏览器调试 1、作用域&#xff1a;&#xff08;本地&全…

代码随想录算法训练营第四十七天|动态规划|198.打家劫舍、213.打家劫舍II、337.打家劫舍III

198.打家劫舍 文章 你是一个专业的小偷&#xff0c;计划偷窃沿街的房屋。每间房内都藏有一定的现金&#xff0c;影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统&#xff0c;如果两间相邻的房屋在同一晚上被小偷闯入&#xff0c;系统会自动报警。 给定一个代…

决策树 | 分裂算法:ID3,C4.5,CART

这里写目录标题 一. ID3算法1. 信息增益2. ID3算法特点 二. C4.5算法1. 信息增益率2. C4.5算法特点 三. CART算法1. Gini系数公式2. CART算法特点3. CART回归树的分裂评价指标 小节 在决策树算法逻辑篇中&#xff0c;我们讲解了决策树的构建方式&#xff0c;下面我们来聊一聊决…

Day16 面向对象进阶——接Day15

Day16 面向对象进阶——接Day15 文章目录 Day16 面向对象进阶——接Day15一、抽象类及抽象方法二、接口三、多态四、对象转型五、内部类 一、抽象类及抽象方法 //抽象类 public abstract class 类名{//抽象方法public abstract void method(); }1、抽象方法交给非抽象的子类去…

FreeRtos自学笔记4----参考正点原子视频

静态创建任务函数 TaskHandle_t xTaskCreateStatic { TaskFunction_t pxTaskCode, /* 指向任务函数的指针 / const char * const pcName, / 任务函数名 / const uint32_t ulStackDepth, / 任务堆栈大小注意字为单位 / void * const pvParameters, / 传递的任务函数参数 / UBase…

爬虫需要什么类型的代理ip?代理ip是必备的吗?

在信息时代&#xff0c;网络爬虫作为一种重要的数据采集工具&#xff0c;被广泛应用于各行各业。在这个过程中&#xff0c;代理IP成为了一个备受关注的话题。那么&#xff0c;爬虫需要什么类型的代理IP?代理IP是否是必不可少的呢? 今天我们就一起来看看~ 首先&#xff0c;我…

GPU服务器为什么需要DPU?

随着AI模型的复杂度增加以及数据量爆炸性增长&#xff0c;GPU服务器在执行训练和推理任务时&#xff0c;不仅面临计算密集型问题&#xff0c;还必须处理大量的数据移动、网络通信、存储I/O以及安全防护等非计算密集型任务。这些问题往往会成为性能瓶颈&#xff0c;消耗宝贵的CP…

【教学类-34-11】20240314 动物拼图(Midjounery生成线描图,8*8格拼图块 A4整张)(AI对话大师)

作品展示&#xff1a;——A4整页&#xff08;一人2张纸&#xff09; 背景需求&#xff1a; 通过春天拼图的个别化实验&#xff0c;我发现&#xff1a; 【教学类-34-10】20240313 春天拼图&#xff08;Midjounery生成线描图&#xff0c;4*4格拼图块&#xff09;&#xff08;AI…

在Docker上传我们自己的镜像(以springboot项目为例)

首先确定好在我们的centOS服务器上已经安装并配置好docker 配置自己的springboot镜像并运行 获取springboot的jar包 maven clean--》mavenue package --》复制target目录下生成的jar包 在服务器选择一个文件夹上传jar包&#xff0c;我这里选用的文件夹叫做/opt/dockertest…

【数据结构】树与堆 (向上/下调整算法和复杂度的分析、堆排序以及topk问题)

文章目录 1.树的概念1.1树的相关概念1.2树的表示 2.二叉树2.1概念2.2特殊二叉树2.3二叉树的存储 3.堆3.1堆的插入&#xff08;向上调整&#xff09;3.2堆的删除&#xff08;向下调整&#xff09;3.3堆的创建3.3.1使用向上调整3.3.2使用向下调整3.3.3两种建堆方式的比较 3.4堆排…

河南大学数据分析可视化实验-数据分析基础

计算机与信息工程学院实验报告 姓名&#xff1a; 杨馥瑞 学号&#xff1a;2212080042专业&#xff1a;数据科学与大数据分析技术 年级&#xff1a; 2022 课程&#xff1a; 数据分析和可视化 主讲教师&#xff1a; 周黎鸣 辅导教师&#xff1a; 周黎鸣 …