C语言进阶之笔试题详解(1)

引言:

对指针知识进行简单的回顾,然后再完成笔试题。

158c3f50b199454985017a51dbef9841.png               ✨ 猪巴戒:个人主页✨

               所属专栏:《C语言进阶》

        🎈跟着猪巴戒,一起学习C语言🎈

目录

引言:

知识简单回顾

指针是什么

指针变量的大小?

指针类型的意义

指针的运算

指针数组

数组名是什么

数组指针

函数指针

函数指针数组

回调函数 

笔试题

一维数组

题目:

解析:

总结:

字符数组

题目1:

解析:

题目2:

解析:

 总结:

题目3:

解析:

总结:

题目4:

解析:

总结:

题目5:

答案:

题目6:

答案:


知识简单回顾

指针是什么

内存 ->内存的单元(1byte)->编号->地址

我们有一块很大的内存空间,内存空间被分为一个一个的单元,一个内存单元的大小是1byte(字节),每个字节都有它的编号,这个编号就是地址,地址又叫做指针

指针就是一个地址。

我们口头语说的指针一般指:指针变量

指针变量就是一个变量,就是一块内存空间,指针变量用来存放地址。

&a就是内存的编号,也是地址.
这个指针变量叫做pa,int*是类型(整形指针),通过这个类型创造的变量叫做pa

*pa就是对pa进行解引用,通过pa存放的地址找到它所指向的对象(a),pa存的是a的地址所以pa指向a,*pa其实就是a

*pa = 20;就相当于 a = 20;将 a 的值改变了。

int main()
{int a = 0;int* pa = &a;*pa = 20;return 0;
}

指针变量的大小?

——4/8个字节,取决于编译器是x86环境还是x64环境


指针类型的意义

两件事情:

1.指针类型进行+1/-1的操作时,它会跳过几个字节。

2.进行解引用操作的时候,决定了解引用操作时候的权限,(访问多少个字节)


指针的运算

1。+-整数

2.指针-指针

3.指针的关系运算


指针数组

本质上就是数组,数组中存放的是指针(地址)。

arr 存放了三个元素,每个元素都是int*类型,也就是指针,那么arr就是指针数组。

int main()
{int *pa;int *pb;int *pc;int* arr = { pa,pb,pc };return 0;
}

0c3c5e59992d496b988dad0d0c445584.png


数组名是什么

1.数组名在大部分情况下表示数组首元素的地址,

但是有两个例外:

a)sizeof(数组名),表示的是整个数组的大小

b)&数组名,取出的是整个数组的地址


数组指针

&数组名,这里的parr ,存放的是数组的地址,parr为数组指针。

数组指针:int (*parr)[10],parr与*结合,代表parr为指针,[10]表示parr指向数组,数组中元素的类型是int。

指针数组:int* parr[10],没有括号,parr与[10]结合,表示parr为数组,数组中元素的类型是int*(整形指针)

数组指针类型的表示:int (*)[10];

int arr[10] = {1,2,3};
int (*parr)[10] = &arr;

函数指针

函数指针就是函数的地址,函数也有地址,我们可以通过函数的地址去使用函数。

函数的地址存放在函数指针变量中,

函数指针类型表示:

int (*)(int,int)

int (*pf)(int ,int)pf*结合,表示pf是指针,指针指向的是(int , int)参数是两个整形的函数,函数的返回类型是int

int Add(int x,int y)
{return x + y;
}int main()
{int (*pf)(int ,int) = &Add;int sum = (*pf)(2,3);//Add 和 &函数名一样,Add也可以直接表示为地址,因此也可以写成这种形式//int (*pf)(int ,int) = Add;//Add传给了pf,pf 等同于 Add ,那么我们也可以这样写。 //int sum = pf(2.3)return 0;
}


函数指针数组

存放函数指针的数组。

我们将函数指针数组命名为arr,arr数组的每个元素的类型是:int (*)(int,int)

函数指针数组的类型表示:

  int (*[4])(int,int)

怎么理解这函数指针数组的形式?

  arr与[4]结合,说明arr是数组,这个数字的每个元素是int(*)(int,int),而这正好是函数指针类型。

int (*arr[4])(int,int) = {Add,Sub,Div,Mul};

7f747b1e3e234bfea78e57b5b34e0ecf.png


回调函数 

通过函数指针调用的函数就是回调函数。

这里的函数指针是pf,pf指向的函数是Add,通过pf调用Add,我们称Add为回调函数。

int Add(int x,int y)
{return x + y;
}int main()
{int (*pf)(int ,int) = Add;int sum = pf(2.3);return 0;
}

笔试题

一维数组

题目:

以下打印的结果分别是什么?

 int a[] = {1,2,3,4};
1|printf("%d\n",sizeof(a));
2|printf("%d\n",sizeof(a+0));
3|printf("%d\n",sizeof(*a));
4|printf("%d\n",sizeof(a+1));
5|printf("%d\n",sizeof(a[1]));
6|printf("%d\n",sizeof(&a));
7|printf("%d\n",sizeof(*&a));
8|printf("%d\n",sizeof(&a+1));
9|printf("%d\n",sizeof(&a[0]));
10|printf("%d\n",sizeof(&a[0]+1));

数组名的理解,指针的运算和指针类型的意义

解析:

1.printf (" %d\n ", sizeof ( a ) );  16

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

2.printf (" %d\n ", sizeof( a+0 ) );  4 / 8

  a不是单独放在sizeof内部,也没有取地址,所以a就是首元素的地址,a+0还是首元素的地址。是地址,大小就是4 / 8个字节。地址的大小和环境有关,32位的系统环境就是4个字节,64位系统环境就是8个字节。

3.printf (" %d\n ", sizeof( *a ) );  4

   *a中的a是数组数组首元素的地址,*a就是对首元素的地址解引用,找到的就是首元素,

   首元素是整形,所占内存大小是4个字节

4.printf (" %d\n ", sizeof( a+1 ) );  4 / 8

  a不是单独放在sizeof的内部,a表示的是首元素的地址,a+1就是数组第二个元素的地址

  地址的大小是4个字节或者8个字节。

5.printf (" %d\n ", sizeof( a[1] ) );  4

 a[1]表示的是数组的第二个元素,作为整形元素的大小为4个字节

6.printf (" %d\n ", sizeof( &a ) );   4 / 8

&a,&数组名,这里的a表示的是整个数组的地址,一共4个元素,地址的大小是4个字节。虽然说是整个数组的地址,但是还是通过首元素的地址来表达。

注意:首元素的地址和数组的地址虽然表现是同一个地址,但是它们的运算的结果是不一样的。

比如:&a+1和a+1,一个表示的是跳过了一个(4个整形元素的)数组的地址,一个表示的是数组第二个元素的地址

28e8fa60560a4df6bef26378a712c082.png

44445ab63d2e4185a4fa0ec1a52a5f48.png

7.printf (" %d\n ", sizeof( *&a ) );  16 

&a取的是整个数组的地址,对&a进行解引用,得到的是整个数组,一共4个元素,一个整形元素的大小为4个字节,一共是16个字节

8.printf (" %d\n ", sizeof( &a+1 ) );  4 / 8

&数组名,取的是整个数组的地址,&a再加上1,就是跳过一个数组的位置,然后再取了一个相同大小数组的地址。&a+1还是地址,地址的大小就是4 / 8个字节。

f4300d1fb13a4d5ca2ce296cc73a35a3.png

9.printf (" %d\n ", sizeof( &a[0] ) );  4 / 8

&a[0]取的是数组第一个元素的地址,大小是4个字节或者8个字节。

10.printf (" %d\n ", sizeof( &a[0]+1 ) );  4 / 8

&a[0],取的是数组第一个元素的地址,&a[0]+1就是数组第二个元素的地址。大小是4个字节或者8个字节。

8576a460e35346ad96f67c087fb32bc7.png

总结:

1.数组名大多数表示首元素的地址,有两个例外:1.sizeof(数组名)2.&数组名。数组名表示的是整个数组 。

2.不同类型地址跳过的字节不一样,&a+1,&a表示的是整个数组,+1就会跳过一个数组的大小。&a[0]+1,&a[0]是数组第一个元素的地址,所以+1跳过的是一个元素的大小。

3.地址意义可能不同,但是地址的大小都是4 / 8个字节。


字符数组

题目1:

以下打印的结果是什么?

char arr[] = {'a','b','c','d','e','f'};
1|printf("%d\n",sizeof(arr));
2|printf("%d\n",sizeof(arr+0));
3|printf("%d\n",sizeof(*arr));
4|printf("%d\n",sizeof(arr[1]));
5|printf("%d\n",sizeof(&arr));
6|printf("%d\n",sizeof(&arr+1));
7|printf("%d\n",sizeof(&arr[0]+1));

解析:

1| printf (" %d\n " , sizeof ( arr ) )  6

sizeof(数组名),取的是整个数组的大小,字符数组arr一共6个元素,所以大小为6个字节。

2|printf (" %d\n ", sizeof( arr+0 ) )  4 / 8 

arr并没有单独放在sizeof内部,所以arr表示首元素的地址,arr+0也表示首元素的地址。是地址,那么大小就为4个字节或者8个字节。

3|printf (" %d\n ",sizeof ( *arr ) )  1

arr是首元素的地址,就是 ‘a’ 的地址,然后解引用,就是‘a’,char类型,大小是1个字节。

*arr 等价于arr [ 0 ]

*(arr+0) 等价于 arr [ 0 ]

4|printf (" %d\n ", sizeof( arr[1] ) )   1

 arr[1]是数组第二个元素,‘b',大小是1个字节。

5|printf (" %d\n ", sizeof( &arr ) )   4 / 8

&arr取的是数组的地址,是地址就是4 / 8 个字节。

6|printf (" %d\n ", sizeof( &arr+1 ) )  4 / 8

&arr取的是arr数组的地址,&arr+1跳过一个(6个字符元素的)数组,下图是&arr+1的地址位置,是地址,大小就是4个字节或者8个字节。

5777d152fa5247048a45c4926bbd3b8a.png

7|printf (" %d\n ", sizeof( &arr[0]+1 ) )   4 / 8

&arr[0]取的是数组第一个元素的地址,&arr[0]+1就是第二个元素的地址,是地址,就是4个字节或者8个字节。


题目2:

以下的打印结果分别是什么?

char arr[] = {'a','b','c','d','e','f'};
1|printf("%d\n",strlen(arr));
2|printf("%d\n",strlen(arr+0));
3|printf("%d\n",strlen(*arr));
4|printf("%d\n",strlen(arr[1]));
5|printf("%d\n",strlen(&arr));
6|printf("%d\n",strlen(&arr+1));
7|printf("%d\n",strlen(&arr[0]+1));

解析:

strlen

用来求字符串长度的库函数,参数是地址,从参数传来的地址开始,直到有' \0 '停止。

4e914baee0124f0c9d149f48f6dc6570.png

1|printf (" %d\n ", strlen ( arr ) )  随机值

arr为数组首元素的地址,字符数组没有' \0 ',strlen会运行完数组,还会继续运行,直到遇到' \0',但是数组外的元素不由数组控制,也就是说,' \0 '什么时候出现是不可知的,所以会打印随机值。

下图遇到' \0 '前一共19个元素,所以打印结果为19。

' \0 '的ASCII的数字就是0.

a930f1a963e84e2daec2a9d866209b2a.png

2|printf (" %d\n ", strlen ( arr+0 ) )  随机值

arr+0也是首元素的地址,其实和前面问题的随机值是一样的。这里也将会在第20个元素遇到 ‘\0’,所以这里的随机值与 1| 一样。 

3|printf (" %d\n ", strlen ( *arr ) )  访问冲突

strlen的参数是地址,而*arr传过去的是 ’a‘ ,’a'的ASCII值为97,,不是一个地址,就会发生访问冲突,也就是野指针问题。

0df30a8d1e5342439772e9eb7465fb73.png

4|printf (" %d\n ", strlen ( arr[1] ) )  访问冲突

和前面一个问题产生的结果一样,既然strlen函数的参数是地址,将值传过去就会产生野指针的问题。

1b2750333260499497d5800b89bfde10.png

5|printf (" %d\n ", strlen ( &arr ) )  随机值

&arr传过去的是整个数组的地址,strlen用const char* str来接收,那么strlen又是怎么运行的呢?这里的地址和1|、2|类型不同,但是地址的位置是相同的,strlen也应该是从首元素开始一个一个筛查,直到遇到 ‘\0’ ,求字符串才算结束。所以这里和1|、2|的结果应该是一样的。

6|printf (" %d\n ", strlen ( &arr+1 ) )  随机值 - 6

&arr+1,&arr取的是整个数组的地址,&arr+1会跳过一个(6个char类型元素的)数组,下图标记&arr+1的地址位置,strlen函数也就是从这里开始运行,直到遇到 ‘\0’ ,那么这里的结果就会比1|、2|、5|的结果少6个元素。结果:随机值 - 6

5777d152fa5247048a45c4926bbd3b8a.png

 c56cefbf1a0d41a4b20ac22e6866bfaa.png

7|printf (" %d\n ", strlen ( &arr[0]+1 ) )  随机值 - 1

&arr[0]取的是数组第一个元素的地址,&arr[0]+1就是数组第二个元素的地址,从第二个元素开始,strlen遇到 '\0' 停止,就会比1|、2|、5|的结果少1个元素。结果:随机值 - 1.

1420b7347ef945ceac46fbf170baa20d.png

 总结:

1.strlen(const char* str)传递的参数是地址,如果传递数值的话,就会产生访问冲突的问题。

2.strlen不管地址的类型,只管地址的位置,从地址的位置开始,逐个去数字符,直到遇到 \0 ,strlen就停止运行,求出字符串的长度。


题目3:

以下打印的结果是什么?

char arr[] = "abcdef";
1|printf("%d\n",sizeof(arr));
2|printf("%d\n",sizeof(arr+0));
3|printf("%d\n",sizeof(*arr));
4|printf("%d\n",sizeof(arr[1]));
5|printf("%d\n",sizeof(&arr));
6|printf("%d\n",sizeof(&arr+1));
7|printf("%d\n",sizeof(&arr[0]+1));

解析:

char arr[] = "abcdef",这个数组的元素为[ a b c d e f \0 ],一共7个元素,字符串默认以 \0 结尾。

1|printf (" %d\n ", sizeof ( arr ) )   7

sizeof(数组名),这里的数组名表示的是整个数组,因为字符串默认为 ‘\0’ 结尾,所以这个数组有7个元素,结果为7个字节。

2|printf (" %d\n ", sizeof ( arr+0 ) )  4 / 8

arr表示的是首元素的地址,arr+0表示首元素的地址,是地址,地址的大小为4个字节或者8个字节。

3|printf (" %d\n ", sizeof ( *arr ) )   1

arr表示首元素的地址,*arr取的是‘a’,大小为1个字节。

4|printf (" %d\n ", sizeof ( arr[1] ) )  1

arr[1]为数组的第二个元素,‘b’,大小为1个字节。

5|printf (" %d\n ", sizeof ( &arr ) )  4 / 8

&arr取的是整个数组的地址,地址的大小为4个字节或者8个字节。

6|printf (" %d\n ", sizeof ( &arr+1 ) )  4 / 8

&arr取的是整个数组的地址,&arr+1跳过1个(7个元素)的数组,跳过一个数组,但是地址的类型是不变的,是还是一个数组的地址,不过既然是地址,地址的大小为4个字节或者8个字节。

7|printf (" %d\n ", sizeof ( &arr[0]+1 ) )  4 / 8

&arr[0]取的是数组第一个元素的地址,&arr+1就是数组第二个元素的地址,地址的大小为4个字节或者8个字节。

总结:

1.不管地址的类型是什么,只要是地址,地址的大小就是4个字节或者8个字节。

2.字符串相当于普通的字符数组,但是字符串通常默认 \0 为结尾。

3.sizeof 只关注占用内存空间的大小,不在乎内存中放的是什么。


题目4:

以下打印的结果是什么?

char arr[] = "abcdef";
1|printf("%d\n",strlen(arr));
2|printf("%d\n",strlen(arr+0));
3|printf("%d\n",strlen(*arr));
4|printf("%d\n",strlen(arr[1]));
5|printf("%d\n",strlen(&arr));
6|printf("%d\n",strlen(&arr+1));
7|printf("%d\n",strlen(&arr[0]+1));

解析:

char arr[] = "abcdef",这个数组的元素为[ a b c d e f \0 ],一共7个元素,字符串默认以 \0 结尾。

strlen是求字符串长度的,关注的是字符串中的 \0 ,计算的是 \0 之前出现的字符的个数。

1|printf (" %d\n" , strlen ( arr ) )   6

arr是首元素的地址,遇到 \0 停止。结果:6

2|printf (" %d\n ", strlen ( arr+0 ) )  6

6cef88ae4add4d9bb256ec7e860278be.png

3|printf (" %d\n ", strlen ( *arr ) )  访问冲突

传递的不是地址。

4|printf (" %d\n ", strlen ( arr[1] ) )  访问冲突

传递的不是地址。

5|printf (" %d\n ", strlen ( &arr ) )  6

取的是整个数组的地址,但是地址位置是首元素的地址。

a6189cc5e1184190a12252cc0e059635.png

6|printf (" %d\n ", strlen ( &arr+1 ) )  随机值

跳过了一个数组,\0也包括在这个数组里面,strlen就会往下去寻找 \0 ,结果会是随机值。

ce5c6a377b0b410d9212e4e7725448c7.png

7|printf (" %d\n ", strlen ( &arr[0]+1 ) )  5

从第二个元素开始,后面遇到 \0,一共是5个元素。 

26bbfc0f3d2e4029af0c6c7168fa0383.png

总结:

1. strlen是求字符串长度的,关注的是字符串中的 \0 ,计算的是 \0 之前出现的字符的个数。

2.sizeof 只关注占用内存空间的大小,不在乎内存中放的是什么。


题目5:

char* p = "abcdef";
1|printf("%d\n",sizeof(p));
2|printf("%d\n",sizeof(p+1));
3|printf("%d\n",sizeof(*p));
4|printf("%d\n",sizeof(p[0]));
5|printf("%d\n",sizeof(&p));
6|printf("%d\n",sizeof(&p+1));
7|printf("%d\n",sizeof(&p[0]+1));

答案:

这里的“abcdef”并不是数组,而是常量字符串,常量字符串在内存中有独立的地址。p接收的是首元素’a‘的地址。 

1|printf (" %d\n ", sizeof ( p ) )  4 / 8

p是 指针变量,存放的是’a‘的地址。地址的大小为4个字节或者8个字节。

2|printf (" %d\n ", sizeof ( p+1 ) )  4 / 8

p+1是地址。

3|printf (" %d\n ", sizeof ( *p ) )  1

*p是 ’a‘,大小是1个字节 

4|printf (" %d\n ", sizeof ( p[0] ) )  1

p[0]是’a‘,大小是1个字节。

5|printf (" %d\n ", sizeof ( &p ) )  随机值

&p是地址,p是指针变量,p存放的是常量字符串首元素’a‘的地址,但是p的地址与常量字符串没有关系,p的地址属于二级指针,一级指针的地址。所以是随机值。

218abad8da964427a1eb6ccacf597e57.png

6|printf (" %d\n ", sizeof ( &p+1 ) )  4 / 8

&p+1是地址。所以大小为4个字节或者8个字节。

41a6ad4d76e74a068636f77aebff53d2.png

7|printf (" %d\n ", sizeof ( &p[0]+1 ) )  4 / 8

&p[0]+1是地址。&p[0]就是‘a’的地址,+1就是‘b’的地址。


题目6:

char* p = "abcdef";
1|printf("%d\n",strlen(p));
2|printf("%d\n",strlen(p+1));
3|printf("%d\n",strlen(*p));
4|printf("%d\n",strlen(p[0]));
5|printf("%d\n",strlen(&p));
6|printf("%d\n",strlen(&p+1));
7|printf("%d\n",strlen(&p[0]+1));

答案:

1|printf (" %d\n ", strlen( p ) )  6

p是首元素‘a’的地址,往后6个元素,到 \0 停止。

53218d81d5c947378c779058678b5e6f.png

2|printf (" %d\n ", strlen( p+1 ) )  5

p+1是第二个元素的地址,往后5个元素,到 \0 停止。

19f9e1612a884cfc85179ef79f1c61ce.png

3|printf (" %d\n ", strlen ( *p ) )  访问冲突

strlen的参数为地址。

4|printf (" %d\n ", strlen ( p[0] ) )  访问冲突

strlen的参数为地址。

5|printf (" %d\n ", strlen ( &p ) )  随机值

p是一级指针,&p就是二级指针。p的地址和常量字符串“abcdef”没有关系。

3ab1a2eb9f5d484daff9fbd688f8d289.png

6|printf (" %d\n ", strlen( &p+1 ) )  随机值 - 1

&p取的是p的地址,&p指向p的下一位。

a00d0a1fcb7240288ce80d832e386aea.png

7|printf (" %d\n ", strlen ( &p[0]+1 ) )  5

p[0]就是’a‘,&p[0]取出了’a‘的地址,&p[0]+1就是’b‘的地址。

strlen从’b‘开始往后数,一直数到 \0为止,一共是5个元素。

28952f72d15d4243bff649cee8d86318.png

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

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

相关文章

vue项目中使用jsonp跨域请求百度联想接口

一. 内容简介 vue项目中使用jsonp跨域请求百度联想接口 二. 软件环境 2.1 Visual Studio Code 1.75.0 2.2 chrome浏览器 2.3 node v18.14.0 三.主要流程 3.1 代码 核心代码 // 这个是请求函数doLeno() {// 挂载回调函数,不挂载,会报不存在window…

React入门使用 (官方文档向 Part1)

文章目录 React组件:万物皆组件 JSX: 将标签引入 JavaScriptJSX 规则1. 只能返回一个根元素2. 标签必须闭合3. 使用驼峰式命名法给 ~~所有~~ 大部分属性命名!高级提示:使用 JSX 转化器 在 JSX 中通过大括号使用 JavaScript使用引号传递字符串使用大括号&…

性能优化中使用Profiler进行内存泄露的排查及解决方式

文章目录 一、前言二、内存泄露的排查方式三、参考链接 一、前言 对于常规意义上的线程使用要及时关闭,数据库用完要及时关闭,数据用完要及时清空等等这里不再赘述,但是在开发中总会有不熟悉的api,开发进度过快,开发人…

【工具】Zotero|使用Zotero向Word中插入引用文献(2023年)

版本:Word 2021,Zotero 6.0.30 前言:两年前我找网上插入文献的方式,网上的博客提示让我去官网下个插件然后才能装,非常麻烦,导致我对Zotero都产生了阴影。最近误打误撞发现Zotero自带了Word插件&#xff0c…

随时随地,打开浏览器即可体验的在线PS编辑器

即时设计 即时设计是国产的专业级 UI 设计工具,不限平台不限系统,在浏览器打开即用,能够具备 Photoshop 的设计功能,钢笔、矢量编辑、矩形工具、布尔运算等设计工具一应俱全,是能够在线使用的 Photoshop 免费永久工具…

DjiTello + YoloV5的无人机的抽烟检测

一、效果展示 注:此项目纯作者自己原创,创作不易,不经同意不给予搬运权限,转发前请联系我,源码较大需要者评论获取,谢谢配合! 1、未启动飞行模型无人机的目标检测。 DjiTello YOLOV5抽烟检测 …

Exchange意外登录日志

最近在审计Exchange邮件系统的时候,发现大量用户半夜登录的日志。而且都是成功的,几乎没有失败的情况。其中Logon Type 8表示用户从网络登录。 Logon type 8: NetworkCleartext. A user logged on to this computer from the network. The user’s pas…

c语言-数据结构-链式二叉树

目录 1、二叉树的概念及结构 2、二叉树的遍历概念 2.1 二叉树的前序遍历 2.2 二叉树的中序遍历 2.3 二叉树的后序遍历 2.4 二叉树的层序遍历 3、创建一颗二叉树 4、递归方法实现二叉树前、中、后遍历 4.1 实现前序遍历 4.2 实现中序遍历 4.3 实现后序遍历 5、…

【服务器能干什么】二十分钟搭建一个属于自己的 RSS 服务

如果大家不想自己捣鼓,只是想尝尝鲜,可以在下面留言,我后台帮大家开几个账号玩一玩。 哔哩哔哩【高清版本可以点击去吐槽到 B 站观看】:【VPS服务器到底能干啥】信息爆炸的年代,如何甄别出优质的内容?你可能需要自建一个RSS服务!_哔哩哔哩_bilibili 前言 RSS 服务 市…

STM32F103C8T6第7天:

1. 智能小车:让小车动起来(360.64) 硬件接线 B-2A – PB0B-1A – PB1A-1B – PB2A-1A – PB10其余接线参考上官一号小车项目。 cubemx配置 代码(28.smartCar_project1/MDK-ARM) 2. 智能小车:串口控制小…

Vue弹窗的使用与传值

使用element-UI中的Dialog 对话框 vue组件结合实现~~~~ 定义html <div click"MyAnalyze()">我的区划</div><el-dialog title"" :visible.sync"dialogBiomeVisible"><NationalBiome :closeValue"TypeBiome" cl…

ruoyi-plus-vue docker 部署

本文以 ruoyi-vue-plus 5.x docker 部署为基础 安装虚拟机 部署文档 安装docker 安装docker 安装docker-compose 配置idea环境 上传 /doicker 文件夹 到服务器&#xff1b;赋值 777权限 chmod -R 777 /docker idea构建 jar 包 利用 idea 构建镜像; 创建基础服务 docker…

Oracle(2-5)Usage and Configuration of the Oracle Shared Server

文章目录 一、基础知识1、 Server Configurations服务器配置2、Dedicated server process专用服务器进程3、Oracle Shared ServerOracle共享服务器4、Benefits of Shared Server 共享服务器的优点5、Processing a Request 处理请求6、Configuring Shared Server 配置共享服务器…

设计模式-创建型模式-工厂方法模式

一、什么是工厂方法模式 工厂模式又称工厂方法模式&#xff0c;是一种创建型设计模式&#xff0c;其在父类中提供一个创建对象的方法&#xff0c; 允许子类决定实例化对象的类型。工厂方法模式是目标是定义一个创建产品对象的工厂接口&#xff0c;将实际创建工作推迟到子类中。…

Redis报错:JedisConnectionException: Could not get a resource from the pool

1、问题描述&#xff1a; redis.clients.jedis.exceptions.JedisConnectionException: Could not get a resource from the pool 2、简要分析&#xff1a; redis.clients.util.Pool.getResource会从JedisPool实例池中返回一个可用的redis连接。分析源码可知JedisPool 继承了 r…

PyQt6把QTDesigner生成的UI文件转成python源码,并运行

锋哥原创的PyQt6视频教程&#xff1a; 2024版 PyQt6 Python桌面开发 视频教程(无废话版) 玩命更新中~_哔哩哔哩_bilibili2024版 PyQt6 Python桌面开发 视频教程(无废话版) 玩命更新中~共计18条视频&#xff0c;包括&#xff1a;2024版 PyQt6 Python桌面开发 视频教程(无废话版…

NSGA-II求解微电网多目标优化调度(MATLAB)

一、NSGA-II简介 NSGA-Ⅱ算法是Kalyanmoy Deb等人于 2002年在 NSGA 的基础上提出的&#xff0c;它比 NSGA算法更加优越&#xff1a;它采用了快速非支配排序算法&#xff0c;计算复杂度比 NSGA 大大的降低&#xff1b;采用了拥挤度和拥挤度比较算子&#xff0c;代替了需要指定的…

python实现自动刷平台学时

背景 前一阵子有个朋友让我帮给小忙&#xff0c;因为他每学期都要看视频刷学时&#xff0c;一门平均需要刷500分钟&#xff0c;一学期有3-4门需要刷的。 如果是手动刷的话&#xff0c;比较麻烦&#xff0c;能否帮他做成自动化的。搞成功的话请我吃饭。为了这顿饭&#xff0c;咱…

Python语言学习笔记之三(字符编码)

本课程对于有其它语言基础的开发人员可以参考和学习&#xff0c;同时也是记录下来&#xff0c;为个人学习使用&#xff0c;文档中有此不当之处&#xff0c;请谅解。 什么是字符编码 计算机从本质上来说只认识二进制中的0和1&#xff0c;字符编码(Character Encoding) 是一种将…

Android Bitmap 模糊效果实现 (二)

文章目录 Android Bitmap 模糊效果实现 (二)使用 Vukan 模糊使用 RenderEffect 模糊使用 GLSL 模糊RS、Vukan、RenderEffect、GLSL 效率对比 Android Bitmap 模糊效果实现 (二) 本文首发地址 https://blog.csdn.net/CSqingchen/article/details/134656140 最新更新地址 https:/…