C语言基础--数组

news2025/1/21 8:50:32

文章目录

  • 一维数组
    • 一、一维数组的创建和初始化
      • (1)一维数组的创建
      • (2)一维数组的初始化
        • 1)整形数组初始化
        • 2)字符数组初始化
        • 3)sizeof与strlen
        • 4)总结
    • 二、一维数组的使用
    • 三、一维数组在内存中的存储
  • 二维数组
    • 一、二维数组的创建和初始化
      • (1)二维数组的创建
      • (2)二维数组初始化
    • 二、二维数组的使用
    • 三、二维数组在内存中的存储
  • 数组作为函数参数
    • 一、引子
    • 二、案例
      • (1)主要思想
      • (2)实操
        • 1)整体架构
        • 2)函数设计
        • 3)遍历输出
        • 4)运行
        • 5)优化
  • 数组名是什么

一维数组

一、一维数组的创建和初始化

(1)一维数组的创建

数组是一组相同类型元素的集合。数组创建方式:

Type_t arr_name [const_n]

// type_t 	是指数组的元素类型
// arr_name	是指数组名
// const_n	是一个常量表达式,用来指定数组的大小

数组创建实例:

//代码1

int arr1[10];
//int表示数组元素类型,arr1表示数组类型,10表述数组内元素个数

来看一个错误案例。

//代码2

int count=10;

int arr[count]; 数组可以正常创建?---> 不可以

当我们运行之后,会出现这样的错误应输入常量表达式

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-wcNEMyu3-1672043983319)(D:\Typora图片\image-20220815185429650.png)]

//代码3

char arr3[10];

float arr4[1];

double arr5[20];

:数组创建,【】里面要给一个常量才可以,不能使用变量。

(2)一维数组的初始化

在数组创建的同时给数组的内容一些合理的初始值(初始化)

1)整形数组初始化

int arr3[10]={1,2,3};

我们调试(按F11)看一下,可以发现,数组里面前三个是存的数字,后面都是0。

在这里插入图片描述

不完全初始化,剩下元素默认初始化为0。

2)字符数组初始化

①常规书写

char arr4[5]={‘a’,’b’};

调试看一下。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ZovAGXFw-1672043983321)(D:\Typora图片\image-20220815191002148.png)]

②字符串书写

char arr5[5]=”abc”;

真正放入数组的有: a b c \0

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-b54Mhzmq-1672043983321)(D:\Typora图片\image-20220815191339224.png)]

注意,第三个0是放进去的\0,而不是默认给的0。和第一个例子的0不一样。存储结果一致,但方式不一样。

③混合书写

char arr6[5]={‘a’,98};

98被解析成了字符‘b’。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-jrfiRsal-1672043983322)(D:\Typora图片\image-20220815191849745.png)]

④不指定数组元素个数

char arr7[]=”abcdef”;

当我们并没有指定它的大小的时候,他会根据初始化的内容来确定数组有几个元素。

比如这里,有六个字符,加一个\0,共有7个元素。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-MiWqgcHf-1672043983323)(D:\Typora图片\image-20220815192514473.png)]

3)sizeof与strlen

说一下常见的误区。

	printf("%d\n", sizeof(arr7));
	printf("%d\n",strlen(arr7));

先来输出看一下结果。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-mPIYoElH-1672043983323)(D:\Typora图片\image-20220815192958713.png)]

sizeof是计算arr7所占空间的大小,刚才说了,arr7里面放了7个元素(6个字母,1个\0)。

7个字符,每个字符大小是1 —> 7*1=7

strlen是在求字符串长度,到**\0就停止了,并且\0**不算字符串的内容。

虽然放进去了abcdef\0,但是求字符串长度的时候,遇到\0就停止计算了,就是只算了6个字符。

strlen求的是**\0**之前的字符个数。

👉 对比strlen sizeof

1>strlen sizeof 并没有什么关联

2>strlen是库函数,使用时要引用头文件;sizeof只是操作符。

3>strlen是求字符串长度的,只能针对字符串来求长度;sizeof是计算变量、数组、类型的大小,单位是字节。

4)总结

当我们看到以下写法,都是正确的(上面演示过,这里总结一下):

int arr1[10]={1,2,3};		//	不完全初始化
int arr2[]={1,2,3,4};		//	没有指定大小,是根据后边元素内容,确定数组大小
int arr3[5]={1,2,3,4,5};	//	完全初始化
char arr4[3]={'a',98,'c'};
char arr5[]={'a','b','c'};
char arr6[]="abcdef";

数组在创建的时候,如果想不指定数组的确定的大小就得初始化。

数组的元素个数根据初始化的内容来确定。

对于下面的代码要区分,内存中如何分配。

	char arr8[] = "abc";
	char arr9[] = { 'a','b','c' };

❓分别用sizeofstrlen计算,结果分别是多少?

来分析一下。

arr8数组里面的元素有:abc\0

arr9数组里面的元素有:abc

sizeof只关注所占空间的大小

arr8占了4个字节的空间。

arr9占了3个字节的空间。

strlen是求字符串长度的。(“\0”之前的字符个数)

arr8在“\0”之前有3个字符。(不包括“\0”)

arr9在“\0”之前有多少个字符是未知的,所以结果是个随机值

来看一下运行结果:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-cuK4FsM7-1672043983324)(D:\Typora图片\image-20220816092731312.png)]

二、一维数组的使用

对于数组的使用,之前介绍了一个操作符:[],下标引用操作符。它其实就是数组访问的操作符。

我们先写一个数组:

char arr[]="abcdef";

这个数组里面,有这样几个元素:[a][b][c][d][e][f][\0]

现在想拿出字符d

就要用到下标。d是第4个元素,下标是3。(下标从0开始)

如果想要打印出它的内容,就要这样打印:

printf("%c\n",arr[3]);

看一下输出结果:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-vkXRcnbv-1672043983324)(D:\Typora图片\image-20220816093711623.png)]

现在想将所有的元素输出。

该怎么办呢?

一个一个地输出是可以的,但是太麻烦。这里咱们用循环来做。

	int i = 0;
	for (i = 0; i < 6;i++) {
		printf("%c\n",arr[i]);
	}

看一下输出结果:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ZWf8oBZ1-1672043983325)(D:\Typora图片\image-20220816094201739.png)]

这里循环里边的6可以计算吗?

当然可以,可以用之前说过strlen来计算。

那么,这里的6,就可以用strlen(arr)来替代。

	int i = 0;
	for (i = 0; i < strlen(arr);i++) {
		printf("%c\n",arr[i]);
	}

同样,可以输出数组内元素。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-tq3bWpAt-1672043983325)(D:\Typora图片\image-20220816094659442.png)]

⚠️注意,这里可能会出一个警告。

有符号/无符号不匹配问题。

因为strlen函数返回的是一个无符号整型

有警告的话可以强制类型转换一下。即把for循环第二个改为:i < (int)strlen(arr)

或者可以这样写:

	int len = strlen(arr);
	for (i = 0; i < len; i++) {
		printf("%c\n", arr[i]);
	}

看一下运行结果:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-4LTZcGX3-1672043983325)(D:\Typora图片\image-20220816095157950.png)]


如果是个整型数组,也是可以算的。

我们不妨再来看个例子。

来写个数组:

int arr2[]={1,2,3,4,5,6,7,8,9,0};

要把每个元素打印出来。

先要知道元素个数:(用sizeof计算)

int sz=sizeof(arr2)/sizeof(arr2[0]);
//用总大小除以每个元素的大小,就是元素的个数

整形数组,可以用sizeof来算。

上面字符数组,并不是不能用sizeof来算,而是用sizeof来算的话,包含了\0,不想要\0,就用strlen来算。

然后再用一个循环遍历一下数组,输出即可。

int i=0;
for(i=0;i<sz;i++){
    printf("%d ",arr2[i]);
}

来看一下输出结果:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-nZnzjSX0-1672043983326)(D:\Typora图片\image-20220816100319133.png)]


🍰总结

1.数组是使用下标来访问的,下标是从0开始。

2.数组的大小可以通过计算得到。

三、一维数组在内存中的存储

先来写一个数组:

int arr[]={1,2,3,4,5,6,7,8,9,10};

现在想研究一下数组在内存中的布局,可以把每个元素的地址打印出来看一下。

int sz=sizeof(arr)/sizeof(arr[0]);	//计算数组内有多少个元素
int i=0;
for(i=0;i<sz;i++){
    printf("&arr[%d]=%p\n",i,&arr[i]);	//取出地址
}

看一下结果:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-sbYu0GP9-1672043983326)(D:\Typora图片\clip_image028.jpg)]

来看一下地址的规律,这里抽出最后两位,可以看到地址之间相隔4。

注意:下边有点小错误,是逢16进1,下边演示写错了,忘记改了。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-PTnhcWkH-1672043983327)(D:\Typora图片\clip_image030.jpg)]

为什么会相差4?

因为每个元素都是整型,整型是4个字节。

数组在内存中是连续存放的。

随着下标的增长,元素的地址,也有规律地递增。一维数组在内存中连续存放。

二维数组

一、二维数组的创建和初始化

(1)二维数组的创建

int arr[3][4];
char arr[3][5];
double arr[2][4];

二维数组表现形式(假想):

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-c6uKFX66-1672043983327)(D:\Typora图片\clip_image032.jpg)]

(2)二维数组初始化

刚才的数组,咱们给它初始化一下。

int arr[3][4]={1,2,3,4,5};

看一下内存如何存储的:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-gM0h7une-1672043983327)(D:\Typora图片\clip_image034.jpg)]

⭐️ 我们可以看到:

当二维数组进行不完全初始化的时候,后面的值也默认初始化为0。

一行放满之后,才会放第二行。

问:能否将123放在第一行,45放在第二行?

看内存图,我们可以发现:

第一行可以当成一维数组;第二行也可以当成一维数组;第三行也可以当成一维数组。

我们可以把它当做一维数组来初始化!

即:

int arr2[3][4]={{1,2,3},{4,5}};

看一下内存如何存储的:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-lIgWXJLM-1672043983328)(D:\Typora图片\clip_image036.jpg)]

之前说过一维数组的初始化,可以不写元素个数,就像这样:

int arr[]={1,2,3,4};	//靠数组元素的个数,来确定数组大小

那二维数组呢?可以省略吗?

二维数组行可以省略,列不能省略!(可以自己试一试,列省略的话编译出错,因为省略列就无法唯一确定数组存储方式)

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-xI55ZwSu-1672043983328)(D:\Typora图片\clip_image038.jpg)]

二、二维数组的使用

二维数组的使用依然通过下标来实现。

举个例子。

先写个二维数组:

int arr2[3][4]={{1,2,3},{4,5}};

我们要将它元素输出。

因为要访问行和列,就要用到循环嵌套。

int i=0;
for(i=0;i<3;i++){	//遍历了行
    int j=0;
    for(j=0;j<4;j++){	//遍历了列
        printf("%d",arr2[i][j]);	//打印输出
    }
    printf("\n");	//换行
}

看一下输出结果:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-CetoqDST-1672043983328)(D:\Typora图片\clip_image040.jpg)]

三、二维数组在内存中的存储

想要知道,二维数组在内存中如何存储的。我们就可以将它们的地址全部打印出来看看。

打印输出地址:

printf("&arr[%d][%d]=%p",i,j,arr2[i][j]);	//打印输出地址

加上循环的完整代码:

int arr2[3][4]={{1,2,3},{4,5}};
int i=0;
for(i=0;i<3;i++){	//遍历了行
    int j=0;
    for(j=0;j<4;j++){	//遍历了列
        printf("&arr[%d][%d]=%p\n",i,j,&arr2[i][j]);	//打印输出地址
    }
}

可以发现,

二维数组在内存中是一块连续的空间,可以看成由一维数组组成的数组

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-0rQoUYWq-1672043983329)(D:\Typora图片\clip_image042.jpg)]

这里作图解释一下具体的内存结构。

之前说过假想的二维数组内存存储结构,这里其实存储的更加简单。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-rXmk69iE-1672043983329)(D:\Typora图片\clip_image044.jpg)]

arr[0]可以当作二维数组第一行的数组名。

arr[1] 可以当作二维数组第二行的数组名。

arr[2] 可以当作二维数组第三行的数组名。

整个二维数组,就可以当作是三个一维数组组合而来的。

数组作为函数参数

一、引子

往往我们在写代码的时候,会将数组作为参数传个函数,比如:

我要实现一个冒泡排序(这里要讲算法思想)函数将一个整型数组排序。那我们将会这样使用函数:

【 写一个函数,函数的参数部分是一个数组。】

二、案例

(1)主要思想

案例:(冒泡排序)

先说一下冒泡排序的方法思想,这里要将下边的一行数升序排列。

拿第一项(10)与后边一项(9)比较,若后边的那一项小于前面的一项,就互换位置。然后再继续比较后一项(8),以此类推。

简单来说,就是两两相邻的元素进行比较。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-2oYpFqqE-1672043983329)(D:\Typora图片\clip_image046.jpg)]

通过分析:

10个元素—> 9趟冒泡排序

第1趟 —> 10个元素,要进行9次比较

第2趟 —> 9个元素(最后一个已经不用动了),要进行8次比较

第3趟 —> 8个元素,要进行7次比较

(2)实操

1)整体架构

了解完冒泡排序的基本思想之后,我们来做个小案例。

这里给出一个数组:

int arr[]={9,8,7,6,5,4,3,2,1,0};

现在对这个数组进行排序,排成升序

这里写一个新的函数bubble_sort(),即冒泡排序函数。

既然是对数组arr进行排序,那么就需要将这个数组传递过去:bubble_sort(arr),然后对这个函数进行设计。

还需要什么参数呢?不知道,先来设计一下函数吧。

2)函数设计

这个函数的参数是什么?既然传过来是一个数组,那么可以拿一个数组(int arr[])来接收,数组元素个数可以不指定。

函数排完序就行,不需要返回什么值,那么函数类型就是void。如下:

void bubble_sort(int arr[]){
    
}

然后写函数内容,上面对冒泡排序已经解释的很清楚了,接下来来写代码。

先确定冒泡排序趟数,趟数和元素有关系。

上面举例中,10个元素要跑9趟,那么n个元素就要跑(n-1)趟。

那么我们就需要知道元素个数,元素个数怎么算?讲一维数组的时候说过,这样算:

int sz=sizeof(arr)/sizeof(arr[0]);

这样算可以吗???不妨试一下。

传参的时候,只传递了一个数组上来,函数只拿了一个数组接收。

int i=0;
int sz=sizeof(arr)/sizeof(arr[0]);	//10个元素
for(i=0;i<sz-1;i++){	//趟数(9)
    
}

这个for循环是趟数,接下来我们要在这个for循环里面,写每一趟的过程。

每一趟,就是拿相邻元素比较。

这里是升序排列,如果第一个元素比第二个元素大,就交换。

那么,循环条件是什么?上面分析的时候说过:

10个元素—> 9趟冒泡排序

第1趟(i=0) —> 10个元素,要进行9次(sz-1)比较

第2趟(i=1) —> 9个元素(最后一个已经不用动了),要进行8次(sz-2)比较

第3趟(i=2) —> 8个元素,要进行7次(sz-3)比较

​ i —> 要进行(sz-1-i)比较

由此可见,每一趟需要比较的次数是sz-1-i

int j=0;
for(j=0;j<sz-1-i;j++){	//每一趟做的事(相邻元素比较次数)
    if(arr[j]>arr[j+1]){	//比较相邻元素大小,若满足条件就交换
        int tmp=arr[j];
        arr[j]=arr[j+1];
        arr[j+1]=tmp;
    }
}

3)遍历输出

函数部分就写完了,接下来在主函数中遍历输出一下排序之后的数组。

int i=0;
int sz=sizeof(arr)/sizeof(arr[0]);
for(i=0;i<sz;i++){
    printf("%d ",arr[i]);
}

4)运行

整体代码如下:

#include<stdio.h>
void bubble_sort(int arr[]){
    int i=0;
	int sz=sizeof(arr)/sizeof(arr[0]);	//10个元素
	for(i=0;i<sz-1;i++){	//趟数(9)
	    int j=0;
		for(j=0;j<sz-1-i;j++){	//每一趟做的事(相邻元素比较次数)
   			if(arr[j]>arr[j+1]){	//比较相邻元素大小,若满足条件就交换
        		int tmp=arr[j];
        		arr[j]=arr[j+1];
        		arr[j+1]=tmp;
    		}
		}
	}
}
int main(){
    int arr[]={9,8,7,6,5,4,3,2,1,0};
    int i=0;
	int sz=sizeof(arr)/sizeof(arr[0]);
	for(i=0;i<sz;i++){
   	 	printf("%d ",arr[i]);
	}
}

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-9RsBwU2O-1672043983330)(D:\Typora图片\clip_image049.jpg)]

哎呀,并没有达到预想效果啊?

哪儿出错了?

我们来调试看一看:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-tfXgHXy5-1672043983330)(D:\Typora图片\clip_image051.jpg)]

arr是数组,我们对数组arr进行传参的时候。按照之前说的,实参传给形参的时候,形参是实参的一份临时拷贝。会产生空间浪费!传递数组的时候,传递的不是数组本身,而是数组首元素地址。

数组元素个数sz我们可以在外面算好,再传进去。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-mbtG42hz-1672043983331)(D:\Typora图片\clip_image053.jpg)]

5)优化

如果刚开始整个数据就是顺序排列,我们就不需要再继续了。

这里可以增加一个flag变量来实现。

若要排的数组是这样的:912345678

第1趟: 192345678

flag=0

123456789

第2趟: 123456789

flag=1

结束

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-xASkJyRD-1672043983332)(D:\Typora图片\clip_image057.jpg)]

#define _CRT_SECURE_NO_WARNINGS 

   #include<stdio.h> 

   

   void bubble_sort(int arr[],int sz) { //排序即可,不需要返回什么值,用“void” 

     //确定冒泡排序的趟数 

     int flag = 1;//假设这一趟要排序的数据已经有序 

    

     int i = 0; 

     //int sz = sizeof(arr) / sizeof(arr[0]); //算元素个数?---> 不行 

   for (i=0;i<sz-1;i++) { //"sz-1"趟 

     int j = 0; 

     for (j = 0; j < sz-1-i; j++) { //每一趟冒泡排序有多少对比较 

       if (arr[j] > arr[j + 1]) { 

         int tmp = arr[j]; 

         arr[j] = arr[j + 1]; 

         arr[j + 1] = tmp; 

         flag = 0;//本趟排序的数据其实不完全有序 

       } 

     } 

     if (flag == 1) { 

       break; 

     } 

   } 

 } 

 int main() { 

   int arr[] = { 9,8,7,6,5,4,3,2,1,0 }; 

   int i = 0; 

   int sz = sizeof(arr)/sizeof(arr[0]); 

  

   //对arr进行排序,排成升序 

   bubble_sort(arr,sz);//冒泡排序函数,传递过去的是首元素地址:&arr[0] 

  

   for (i = 0; i < sz; i++) { 

     printf("%d ", arr[i]); 

   } 

  return 0; 

 } 

 

传递数组的时候,传递的不是数组本身,而是数组首元素地址。当我们在函数内部需要元素个数的时候,必须在外面求好,以参数方式传进来。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-JFUdlu3t-1672043983332)(D:\Typora图片\clip_image059.jpg)]

break语句只用于for和switch,在if语句中不能使用。因为if是循环语句,所以不能用break来结束。

但我们用的if语句是放在循环里面的,break是用在:当条件满足的时候,跳出外层for循环。

数组名是什么

数组名就是首元素地址

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-KDs6eJUY-1672043983333)(D:\Typora图片\clip_image061.jpg)]

再来看看解引用之后的结果:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-wIvsCrj4-1672043983333)(D:\Typora图片\clip_image063.jpg)]

两个例外:(数组名代表的不是首元素地址)

1、sizeof(数组名)

此时,数组名表示整个数组。

sizeof(数组名) 计算的是整个数组的大小,单位是字节。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-s2n2fOpw-1672043983333)(D:\Typora图片\clip_image065.jpg)]

2、**&**数组名

数组名代表整个数组。**&**数组名,取出的是整个数组的地址。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-N9rMuXYv-1672043983334)(D:\Typora图片\clip_image067.jpg)]

三个的结果一样,但是意义却不一样!

&arr是整个数组的地址(所有元素都包含了),而arr&arr[0]是数组的首元素地址。

问:数组首元素地址与整个数组地址有什么区别?

不妨来看一下下面的小案例:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-jPldiN1A-1672043983334)(D:\Typora图片\clip_image069.jpg)]

74–>90,怎么就加了16啊?(有待考究,可能是编辑器的问题)

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-tx39dVWZ-1672043983335)(D:\Typora图片\clip_image071.jpg)]

用DEV C++编译器却是对的:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-uQWlPrJh-1672043983335)(D:\Typora图片\clip_image073.jpg)]

代码:

#define _CRT_SECURE_NO_WARNINGS 

   #include<stdio.h> 

   int main() { 

     int arr[] = { 1,2,3,4,5,6,7 }; 

     int sz = sizeof(arr) / sizeof(arr[0]); 

     printf("sizeof(arr)=%d\n", sizeof(arr)); 

     printf("sizeof(arr[0])=%d\n", sizeof(arr[0])); 

     printf("sz=%d\n", sz); 
    

   printf("%p\n", &arr);//整个数组的地址 

   printf("%p\n", &arr + 1); 

  

   printf("%p\n", arr);//首元素地址 

   printf("%p\n", arr + 1); 

  

   printf("%p\n", &arr[0]);//首元素地址 

   printf("%p\n", &arr[0] + 1); 

  

   printf("%d\n", *arr); 

   return 0; 

 } 

 

总结:

1.sizeof(数组名),计算整个数组的大小,sizeof内部单独放一个数组名,数组名表示整个数组。

2.&数组名,取出的是数组的地址。&数组名,数组名表示整个数组。

除此两种情况之外,所有的数组名都表示数组首元素的地址。

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

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

相关文章

基于C++实现(控制台)职工信息管理系统【100010060】

职工信息管理系统 一、实验内容 ​ 设计一个职工信息管理案例&#xff0c;实现不同类别职工的工资数据。职工的种类包括&#xff1a;正式职工和临时工。定义一个基本的职工类&#xff0c;基本信息包括&#xff1a;编号、姓名、性别、年龄、家庭住址、基本职务工资。派生出正式…

Quarkus实现第一个Hello World

Quarkus介绍 Quarkus 是一个为 Java 虚拟机&#xff08;JVM&#xff09;和原生编译而设计的全堆栈 Kubernetes 原生 Java 框架&#xff0c;用于专门针对容器优化 Java&#xff0c;并使其成为无服务器、云和 Kubernetes 环境的高效平台。 Quarkus 可与常用 Java 标准、框架和库…

php正则匹配反斜杠问题

php正则匹配反斜杠问题&#xff1a; 之前做了一道题&#xff0c;发现php中正则匹配反斜杠好像有点问题。 我们先看下面代码&#xff1a; <?php$cmd "\\";echo $cmd.PHP_EOL;if(preg_match("/\\\\|\\/",$cmd)) {echo "yes";} else {echo …

springdata-jpa-hibernate-03

springdata-jpa-hibernate-03 多表关联操作 首先加上这个lombok依赖,可以使代码更加简洁 一对一 account类 customerRepository接口 测试 一对多 message类 测试 多对一 在上面一对多的基础上加上这句代码就行 MessageRepository接口 测试&#xff1a; 多对多…

Mybatis-Plus快速入门

入门案例 MyBatisPlus(简称MP)是基于MyBatis框架基础上开发的增强型工具&#xff0c;旨在简化开发、提高效率开发方式基于MyBatis使用MyBatisPlus基于Spring使用MyBatisPlus基于SpringBoot使用MyBatisPlusSpringBoot整合MyBatis开发过程&#xff08;复习&#xff09;创建Spring…

DSP-Z变换

目录 Z变换的定义: Z变换的收敛域: 收敛域的定义: 收敛条件&#xff1a; Z变换收敛域的形状&#xff1a; 阿贝尔定理&#xff1a; 对于有限长序列的收敛域&#xff1a; Z变换的性质: 线性&#xff1a; 收敛域取交集&#xff1a; 时移&#xff1a; 指数相乘&#xf…

Java和Web前端哪个有发展前景?

Java和Web前端都是当今技术行业里的热门岗位&#xff0c;岗位招聘需求量大&#xff0c;人才竞争度高&#xff0c;同学们掌握这两个岗位里其中任何一个的相关主流技术&#xff0c;都可以找到一份不错的职位。下面请允许笔者做一个简要的分析阐述&#xff1a; 一、Web前端 Web前…

5 Redis

5.1 Redis 5.1.1 前言 前面使用到的mysql数据库会出现以下问题 由于用户量增大&#xff0c;请求数量也随之增大&#xff0c;数据压力过大 多台服务器之间数据不同步 多台服务器之间的锁&#xff0c;已经不存在互斥性了。 5.1.2 Redis 5.1.2.1 什么是Redis Redis&#x…

GO语言基础-05-循环和语句-select语句

文章目录1. 概述1.1 作用1.2 和switch比较1.3 执行过程2. 语法示例3. 完整示例1. 概述 1.1 作用 监听channel的数据流动 1.2 和switch比较 相同 开始的一个新的选择块&#xff0c;每个选择条件由case语句来描述。 不同 switch语句&#xff1a;可以选择任何使用相等比较的…

SpringCloud 协同开发方案

相比Springboot开发&#xff0c;SpringCloud开发要复杂的多&#xff0c;因为涉及服务的注册发现&#xff0c;多个微服务模块间的调用等。 最简单的解决方案是每个开发者都在本地启动一套完整的开发环境&#xff0c;包括网关、nacos等各个组成微服务的模块&#xff0c;如果系统…

Hive 学习Demo

背景介绍 陌陌作为聊天平台每天都会有大量用户在线&#xff0c;会出现大量的聊天数据&#xff0c;通过对聊天数据分析&#xff0c;可以更好的构建精确的用户画像&#xff0c;为用户提供更好的服务以及实现高ROI(投资回报率)的平台运营推广&#xff0c;给公司的发展决策提供精确…

智能网联汽车渗透率变化图显示预计

IDC 于 2020 年最新发布的《全球智能网 联汽车预测报告&#xff08;2020-2024&#xff09;》数据显示&#xff0c;尽管受新冠肺炎疫情冲击&#xff0c;2020 年全球智能网联汽车出货量预计较上一年下滑 10.6%&#xff0c;约为 4440 万辆&#xff0c;但到 2024 年全球智能网联汽车…

广播机制基础知识

广播机制 1.广播机制 1.1概述 1.1.1引入 1.广播的生活案例 记得以前读书的时候&#xff0c;每个班级都会有一个挂在墙上的大喇叭&#xff0c;用来广播一些通知&#xff0c;比如&#xff0c;开学要去搬书&#xff0c;广播&#xff1a; "每个班级找几个同学教务处拿书"…

商业智能BI与业务结构分析

做商业智能BI还必须熟悉行业和业务知识&#xff0c;不结合行业业务知识&#xff0c;商业智能BI的项目是很难落地的。商业智能BI的本质其实是企业的业务和管理思维的落地。企业的高层、业务部门的管理人员为什么要通过商业智能BI去看报表&#xff0c;他们看的是什么&#xff0c;…

深度学习-吴恩达(C3)结构化你的机器学习工程

结构化你的机器学习工程改变了深度学习的错误 比如你分割数据的方法&#xff0c;分割成train&#xff0c;development(dev)或叫valid&#xff0c;test&#xff0c;所以最好的实践方法是什么&#xff1f;了解更多端对端的深度学习&#xff0c;进而了解到你是否需要使用它&#…

Elasticsearch 核心技术(三):Kibana 安装、配置、运行(Windows 版)

❤️ 个人主页&#xff1a;水滴技术 &#x1f680; 支持水滴&#xff1a;点赞&#x1f44d; 收藏⭐ 留言&#x1f4ac; &#x1f338; 订阅专栏&#xff1a;大数据核心技术从入门到精通 文章目录一、下载 Kibana二、安装 Kibana三、配置 Kibana1. 主机名2. 端口3. Elasticsea…

Spark基础入门----框架概述

Spark Spark 框架概述 Spark 诞生背景 Apache Spark是用于大规模数据处理的统一分析引擎 Spark 最早源于一片论文&#xff0c;该论文是由加州大学柏克莱分校的Matei Zaharia等人发表。论文中提出了一种弹性分布式数据集(RDD)的概念。 总的说&#xff0c;Spark借鉴了Map Red…

Android进阶——sdk开发和apk开发有什么区别?

sdk SDK 就是 Software Development Kit 的缩写&#xff0c;中文意思就是“软件开发工具包”。即辅助开发某一类软件的相关文档、范例和工具的集合都可以叫做“SDK”。 apk APK&#xff08;全称&#xff1a;Android application package&#xff0c;Android应用程序包&#…

【重学Javase】—— 数组(从头剖析一维数组,二维数组,array常用工具类以及数组的两种常见异常)

目录 数组的概述 1、数组的理解&#xff1a; 2、数组的特点&#xff1a; 3、数组的分类&#xff1a; 一维数组 1、一维数组的声明与初始化 2、一维数组元素的引用&#xff1a;通过角标的方式调用 3、数组的属性&#xff1a;length 4、一维数组的遍历&#xff08;for循…

mysql 备份还原数据库,java使用Runtime对象执行mysqldump备份数据库

为了提高系统可用性,通过java写定时任务每天晚上定时备份mysql数据库,然后把备份的.sql文件(建议在压缩一次上传,减少文件体积提高传输效率)调用文件上传服务器提供的文件上传接口上传到文件服务器,达到数据库服务器损坏后快速还原数据库的目的。以windows系统为例。linux注…