【C语言】9000字长文操作符详解

news2024/11/15 12:26:45

简单不先于复杂,而是在复杂之后。89efcc89ac61428db4d5b6639b2bd948.jpeg

目录

1. 操作符分类 

2. 算数操作符 

3. 移位操作符 

3.1 左移操作符 

 3.2 右移操作符

4. 位操作符 

4.1 按位与 & 

4.2 按位或 | 

4.3 按位异或 ^ 

4.4 一道变态的面试题 

4.5 练习 

5. 赋值操作符 

5.1 复合赋值符 

6. 单目操作符 

6.1 单目操作符介绍

6.2  sizeof 和数组

6.3 ~ 

6.4 ++  -- 

 6.5 *

 6.6 ( )

7. 关系操作符 

8. 逻辑操作符 

一道360笔试题

9. 条件操作符(三目操作符) 

10.  逗号表达式

11. 下标引用、函数调用和结构成员 

 11.1 [ ]下标引用操作符

11.2 ( )函数调用操作符 

11.3  结构成员访问操作符 

12. 表达式求值

 12.1 隐式类型转换

12.2 算数转换 

12.3 操作符的属性 


1. 操作符分类 

  • 算数操作符
  • 移位操作符
  • 位操作符
  • 赋值操作符
  • 单目操作符
  • 关系操作符
  • 逻辑操作符
  • 条件操作符
  • 逗号表达式
  • 下标引用、函数调用和结构成员 

2. 算数操作符 

+ - * / %

1.除了%操作符之外,其他几个操作符可以用于整数和浮点数

2.对于/操作符如果两个操作数都为整数,执行整数乘法。而只要有浮点数执行的就是浮点数除法。

3.%操作符的两个操作数必须为整数,返回的是整除之后的余数。  

3. 移位操作符 

<< 左移操作符
>> 右移操作符

注:移位的操作数只能是整数。

二进制 

整数的二进制有三种:

1. 原码

2. 反码

3. 补码

正整数的原码,补码,反码相同

负整数的原码,反码,补码需要计算

举个例子:

7

00000000000000000000000000000111 - 原码(最高位是符号位,0表示正数,1表示负数)

00000000000000000000000000000111 - 反码

00000000000000000000000000000111 - 补码

-7

10000000000000000000000000000111 - 原码

111111111111111111111111111111111000 - 反码(原码符号位不变,其他位按位取反)

111111111111111111111111111111111001 - 补码(反码+1就是补码)

整数在内存中存储的是补码。

3.1 左移操作符 

移位规则

 左边抛弃,右边补0

 

 

 

左移有乘2的效果。

 3.2 右移操作符

移位规则

首先右移运算分两种:

1. 逻辑移位: 左边用 0 填充,右边丢弃

2. 算数移位: 左边用该值的符号位填充,右边丢弃

 

 上面这是逻辑移位。

 

 

 上面这是算术移位

VS2019编译器采用算术右移(是哪种移位规则取决于编译器)

警告:对于移位操作符,不要移动负数位,这个是标准未定义的。

例如:

int num= 10;
num>>-1;//error

4. 位操作符 

& //按位与
| //按位或
^ //按位异或

 注:它们的操作数必须是整数

4.1 按位与 & 

只有两个数的二进制同时为1,结果才为1,否则为0.

 

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>

int main()
{
	int a = 3;
	int b = -5;
	int c = a & b;
	//00000000000000000000000000000011 - 3的补码
	//10000000000000000000000000000101 - -5的原码
	//11111111111111111111111111111010 - -5的反码
	//11111111111111111111111111111011 - -5的补码

	//00000000000000000000000000000011 - 3的补码
	//11111111111111111111111111111011 - -5的补码
	//00000000000000000000000000000011  - 补码(原码)

	//%d意味着打印一个有符号的整数
	printf("%d\n", c);//3

	return 0;
}

4.2 按位或 | 

参加运算的两个数只要两个数中的一个为1,结果就为1。

 

 

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>

int main()
{
	int a = 3;
	int b = -5;
	int c = a | b;
	//00000000000000000000000000000011 - 3的补码
	//10000000000000000000000000000101 - -5的原码
	//11111111111111111111111111111010 - -5的反码
	//11111111111111111111111111111011 - -5的补码

	//00000000000000000000000000000011 - 3的补码
	//11111111111111111111111111111011 - -5的补码
	//11111111111111111111111111111011 - 补码
	//11111111111111111111111111111010 - 反码
	//10000000000000000000000000000101 - 原码

	printf("%d\n", c);

	return 0;
}

4.3 按位异或 ^ 

相同为0,相异为1。 

0 ^ a = a;

a ^ a = 0;

//异或操作符支持交换律
a ^ b ^ a = b;

 

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>

int main()
{
	int a = 3;
	int b = -5;
	int c = a ^ b;
	//00000000000000000000000000000011 - 3的补码
	//10000000000000000000000000000101 - -5的原码
	//11111111111111111111111111111010 - -5的反码
	//11111111111111111111111111111011 - -5的补码

	//00000000000000000000000000000011 - 3的补码
	//11111111111111111111111111111011 - -5的补码
	//11111111111111111111111111111000 - 补码
	//11111111111111111111111111110111 - 反码
	//10000000000000000000000000001000 - 原码

	printf("%d\n", c);

	return 0;
}

4.4 一道变态的面试题 

 不能创建临时变量(第三个变量),实现两个数的交换。

 

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>

int main()
{
    int a = 3;
    int b = 5;
    printf("交换前:a = %d,b = %d\n", a, b);
    a = a ^ b;//3 ^ 5
    b = a ^ b;//3 ^ 5 ^ 5
    a = a ^ b;//3 ^ 5 ^ 3
    printf("交换后:a = %d,b = %d\n", a, b);

    return 0;
}

4.5 练习 

编写代码实现:求一个整数存储在内存中二进制中1的个数。

(求补码的二进制中1的个数)

 

 

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>

//编写代码实现:求一个整数存储在内存中二进制中1的个数。
//(求补码的二进制中1的个数)

int main()
{
	int a = 0;
	int count = 0;
	scanf("%d", &a);

	int i = 0;
	for (i = 0; i < 32; i++)
	{
		if (a & 1)
		{
			count++;
		}
		a = a >> 1;
	}
	printf("这个整数存储在内存中二进制中1的个数为%d",  count);

	return 0;
}

我在编写代码的时候写了个bug,即在循环中 a >> 1 操作虽然把 a 右移了一位,但是没有将右移后的值赋给 a,导致循环中的 a 始终没有变化,最终会导致死循环。

所以大家写程序的时候要注意一下,避免写出bug。

5. 赋值操作符 

int weight= 120;//体重 
weight = 89;//不满意就赋值 
double salary = 10000.0;
salary = 20000.0;//使用赋值操作符赋值

//赋值操作符可以连续使用
int a = 10;
且int x = 0; 
int y = 20;
a = x = y + 1;//连续赋值
//这样的代码感觉怎么样?

//同样的语义:
x = y + 1;
a = x;
//这样的写法清新爽朗易于调试。

5.1 复合赋值符 

+=

-=

*=

/=

%=

>>=

&=

|=

^=

//这些运算符都可以写作复合的效果。
//比如:
int x = 0;
x = x + 10;
x += 10;//复合赋值
//其他运算符一样的道理,这样更简洁。

6. 单目操作符 

6.1 单目操作符介绍

 

 在C语言中,0表示假,非0表示真。

&取出的是变量在内存中的起始地址。

6.2  sizeof 和数组

sizeof 计算类型所创建变量占据空间的大小,还可以计算整个数组的大小。

sizeof 是操作符,不是函数。

strlen 是库函数,用来求字符串长度。 

下面做一道练习题

请问:

(1)、(2)两个地方分别输出多少?
(3)、(4)两个地方分别输出多少?

 

 

 

(1)、(2)40 4\8

(3)、(4)10 4\8

注:32位环境下(2)(4)为4, 64位环境下为8

6.3 ~ 

 

6.4 ++  -- 

 前置++

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>

int main()
{
	int a = 3;
	int b = ++a;//前置++,先++,后使用
	//a = a + 1,b = a;
	printf("%d\n", a);
	printf("%d\n", b);

	return 0;
}

后置++

 

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>

int main()
{
	int a = 3;
	int b = a++;//后置++,先使用,后++
	//b = a, a = a + 1;
	printf("%d\n", a);
	printf("%d\n", b);

	return 0;
}

-- 同理

 6.5 *

* 是解引用操作符 ,它通常用于指针变量的操作中,用于获取指针所指向的变量的值。

 

 6.6 ( )

强制类型转换可以将一个表达式的值转换为指定的类型。强制类型转换使用圆括号和所需类型的名称来指定。例如,(float) 5将整数5转换为浮点数类型。

 

7. 关系操作符 

 

 

//err
if("abc" == "abcdef")//这样写是在比较2个字符串首字符的地址
{
    
}

两个字符串比较i应该用库函数 strcmp

8. 逻辑操作符 

 

 逻辑与和逻辑或只关注真假。

一道360笔试题

 

#include <stdio.h>

int main()
{
    int i = 0, a = 0, b = 2, c = 3, d = 4;
    i = a++ && ++b && d++;
    //i= a++||++b||d++;
    printf("a= %d\nb = %d\nc = %d\nd = %d\n", a, b, c, d);
    return 0;
}
//程序输出的结果是什么?

 

int main()
{
    int i = 0, a = 1, b = 2, c = 3, d = 4;
    //i = a++ && ++b && d++;
    i= a++||++b||d++;
    printf("a= %d\nb = %d\nc = %d\nd = %d\n", a, b, c, d);
    return 0;
}

 

&& 左边为假,右边就不计算了

||    左边为真,右边就不计算了

9. 条件操作符(三目操作符) 

 表达式1?表达式2:表达式3;

它的含义是,如果expression1的值为真(非零),则整个表达式的值为expression2的值,否则为expression3的值。

1.
if (a > 5)
     b =3;
else
     b =-3;
转换成条件表达式,是什么样?

2.使用条件表达式实现找两个数中较大值。

 

10.  逗号表达式

 

 

int x = 1, y = 2, z;
z = (++x, ++y);

在上面的代码中,逗号运算符的左边是++x,其将x的值增加1并返回结果(即2)。逗号运算符的右边是++y,其将y的值增加1并返回结果(即3)。最终的结果是3,这个结果被赋值给变量z。

逗号表达式的优先级是最低的,因此在使用逗号表达式时应该使用括号来明确表达式的执行顺序。

11. 下标引用、函数调用和结构成员 

 11.1 [ ]下标引用操作符

操作数:一个数组名+一个索引值 

int arr[10] = {0};//创建数组
arr[9] = 10;//实用下标引用操作符。
[ ]的两个操作数是arr和9。
int main()
{
int arr[10] = { 0 };
//arr[7] --> *(arr+7) -->  (7+arr) -->7[arr]
//arr是数组首元素的地址
//arr+7就是跳过7个元素,指向了第8个元素
//*arr+7就是第8个元素

arr[7] = 8;
7[arr] = 8;//印证了[]是操作符


return 0;
}

11.2 ( )函数调用操作符 

接收一个或多个操作数:第一个操作数是函数名,剩余的操作数就是传递给函数的参数。

int Add(int x, int y)
{
return x = y;
}
int main()
{

int a = 0;
int b = 20;
//函数调用
int c = Add(a, b);//() 就是函数调用操作符

return 0;
}

 

11.3  结构成员访问操作符 

.     结构体对象.成员名

->   结构体指针->成员名 ‘

 

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>

struct Stu
{
	char name[20];
	int age;
	double score;
};

void set_Stu(struct Stu ss)
{
	strcpy(ss.name, "zhangsan");
	ss.age = 20;
	ss.score = 100.0;

}

void print_Stu(struct Stu ss)
{
	printf("%s %d %lf\n", ss.name, ss.age, ss.score);
}

int main()
{
	struct Stu s = { 0 };
	set_Stu(s);
	print_Stu(s);

	return 0;
}

这段代码的问题在于,set_Stu函数的参数是按值传递的,因此在函数内部对结构体的修改

不会影响调用函数的主函数中的结构体。因此,当在 set_Stu 函数中修改结构体的值后,

print_Stu 函数中输出的结果仍然是初始值。

要解决这个问题,可以将 set_Stu 函数的参数改为指向结构体的指针,这样就可以在函数内

部修改结构体的值,并且这些修改也会反映在调用函数的主函数中的结构体上。修改后的代

码如下:

 
 

 

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>

struct Stu
{
	char name[20];
	int age;
	double score;
};

void set_Stu(struct Stu* ps)
{
	strcpy((*ps).name, "zhangsan");
	(*ps).age = 20;
	(*ps).score = 100.0;

}

void print_Stu(struct Stu ss)
{
	printf("%s %d %lf\n", ss.name, ss.age, ss.score);
}

int main()
{
	struct Stu s = { 0 };
	set_Stu(&s);
	print_Stu(s);

	return 0;
}

当然,也可以写成下面这种形式:

 

 ps->age
 等价于
 (*ps).age

 如果把两个函数整合到一起,就节省了拷贝一份实参的空间。

12. 表达式求值

表达式求值的一部分是由操作符的优先级和结合性决定。

同样,有些表达式的操作数在求值的过程中可能需要转换成其他类型。 

 12.1 隐式类型转换

C语言的整型算数运算总是至少以缺省(默认)整形的类型的精度来进行的。

为了获得这个精度,表达式中的字符和短整型操作数在使用前被转换为普通整型,这种转换

称为整型提升。 

整型提升的意义:

表达式的整型运算要在CPU的相应运算器件内执行,CPU内整型运算器(ALU)的操作数的字节长度 一般就是int的字节长度,同时也是CPU的通用寄存器的长度

因此,即使两个char类型的相加,在CPU执行时实际上也要先转换为CPU内整型操作数的标准长度。

通用CPU(general-purpose CPU)是难以直接实现两个8比特字节直接相加运算(虽然机器指令 中可能有这种字节相加指令)。

所以,表达式中各种长度可能小于int长度的整型值,都必须先转换为int或unsigned int,然后才能送入CPU去执行运算。

char a,b,c;
...
a= b + c;

b和c的值被提升为普通整型,然后再执行加法运算。

加法运算完成之后,结果将被截断,然后存储于a中。

如何来进行整型提升呢?

整型提升是按照变量的数据类型的符号位来提升的。

 

 

int main()
{
char a = 5;
//00000000000000000000000000000101
//00000101 - a
char b = 126;
//00000000000000000000000001111110
//01111110 - b

char c = a + b;
//00000000000000000000000000000101 - a
//00000000000000000000000001111110 - b
//00000000000000000000000010000011
//10000011 - c
//11111111111111111111111110000011 - 补码
//11111111111111111111111110000010
//10000000000000000000000001111101
//
printf("%d", c);

return 0;
}
int main()
{
char a = 0xb6;
short b = 0xb600;
int c = 0xb6000000;

if (a == 0xb6)
printf("a");  

if (b == 0xb600)
printf("b");  
// a 和 b 整型提升,值发生改变,所以不打印
//放到表达式中的 char 和 short ,在使用时就会发生整型提升
if (c == 0xb6000000)
printf("c");  
// c 不会发生整型提升 
return 0;
}

//a,b整形提升之后,值发生了改变,所以表达式 a==0xb6 , b==0xb600 的结果是假

//但是c不发生整形提升,则表 达式 c==0xb6000000 的结果是真.
int main()
{
    char c = 1;
    printf("%u\n", sizeof(c));//1
    printf("%u\n", sizeof(+c));//4
    printf("%u\n", sizeof(-c));//4  
    // c 只要参与表达式运算,就会发生整型提升
    return 0;
}

12.2 算数转换 

如果某个操作符的各个操作数属于不同的类型,那么除非其中一个操作数转换为另一个操作数的类型,否则操作就无法进行。下面的层次体系称为寻常算数转换。

 

寻常算术转换会将操作数转换为最宽的类型,并保留所有操作数中最大的精度和范围。

 警告:

但是算数转换要合理,要不然就会有潜在的问题。

 

float f= 3.14;
int num = f;//隐式转换,会有精度丢失

12.3 操作符的属性 

复杂表达式的求值有三个影响的因素: 

 1. 操作符的优先级

 2. 操作符的结合性

 3. 是否控制求值顺序

两个相邻的操作符先执行哪个?取决于它们的优先级。

如果两者的优先级相同,取决于它们的结合性。

下面附上操作符的优先级和结合性的表格:

操作 符

描述

用法示例

结果类

结合 性

是否控制求值 顺序

()

聚组

(表达式)

与表达 式同

N/A

()

函数调用

rexp(rexp,...,rexp)

rexp

L-R

[ ]

下标引用

rexp[rexp]

lexp

L-R

.

访问结构成员

lexp.member_name

lexp

L-R

->

访问结构指针成员

rexp->member_name

lexp

L-R

++

后缀自增

lexp ++

rexp

L-R

--

后缀自减

lexp --

rexp

L-R

!

逻辑反

! rexp

rexp

R-L

~

按位取反

~ rexp

rexp

R-L

+

单目,表示正值

+ rexp

rexp

R-L

-

单目,表示负值

- rexp

rexp

R-L

++

前缀自增

++ lexp

rexp

R-L

--

前缀自减

-- lexp

rexp

R-L

*

间接访问

* rexp

lexp

R-L

&

取地址

& lexp

rexp

R-L

sizeof

取其长度,以字节 表示

sizeof rexp sizeof(类 型)

rexp

R-L

(类 型)

类型转换

(类型) rexp

rexp

R-L

*

乘法

rexp * rexp

rexp

L-R

/

除法

rexp / rexp

rexp

L-R

%

整数取余

rexp % rexp

rexp

L-R

+

加法

rexp + rexp

rexp

L-R

-

减法

rexp - rexp

rexp

L-R

<<

左移位

rexp

rexp

L-R

>>

右移位

rexp >> rexp

rexp

L-R

>

大于

rexp > rexp

rexp

L-R

>=

大于等于

rexp >= rexp

rexp

L-R

<

小于

rexp < rexp

rexp

L-R

<=

小于等于

rexp

rexp

L-R

 

操作 符

描述

用法示例

结果类

结合 性

是否控制求值 顺序

==

等于

rexp == rexp

rexp

L-R

!=

不等于

rexp != rexp

rexp

L-R

&

位与

rexp & rexp

rexp

L-R

^

位异或

rexp ^ rexp

rexp

L-R

|

位或

rexp | rexp

rexp

L-R

&&

逻辑与

rexp && rexp

rexp

L-R

||

逻辑或

rexp || rexp

rexp

L-R

? :

条件操作符

rexp ? rexp : rexp

rexp

N/A

=

赋值

lexp = rexp

rexp

R-L

+=

以...加

lexp += rexp

rexp

R-L

-=

以...减

lexp -= rexp

rexp

R-L

*=

以...乘

lexp *= rexp

rexp

R-L

/=

以...除

lexp /= rexp

rexp

R-L

%=

以...取模

lexp %= rexp

rexp

R-L

<<=

以...左移

lexp

rexp

R-L

>>=

以...右移

lexp >>= rexp

rexp

R-L

&=

以...与

lexp &= rexp

rexp

R-L

^=

以...异或

lexp ^= rexp

rexp

R-L

|=

以...或

lexp |= rexp

rexp

R-L

逗号

rexp,rexp

rexp

L-R

我最近在读一本经典的书:《C陷阱与缺陷》,我针对里面对优先级的总结画了一张图。

 

 图中从上到下,从左到右优先级逐层递减。

接下来看一些问题表达式: 

 

 

 

 

总结:

我们写出的表达式如果不能通过操作符的属性确定唯一的计算路径,那么这个表达式就是存在问题的。 

 

 

 

 

 

 

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

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

相关文章

主流接口测试框架对比,究竟哪个更好用

公司计划系统的开展接口自动化测试&#xff0c;需要我这边调研一下主流的接口测试框架给后端测试&#xff08;主要测试接口&#xff09;的同事介绍一下每个框架的特定和使用方式。后端同事根据他们接口的特点提出一下需求&#xff0c;看哪个框架更适合我们。 需求 1、接口编写…

项目工作分解工具WBS

WBS工作分解结构&#xff08;Work Breakdown Structure&#xff09;&#xff0c;是一个描述思路的规划和设计工具&#xff0c;它可以清晰地表示各项目之间相互联系的结构&#xff0c;详细说明为完成项目所必须完成的各项工作&#xff0c;也可以向高层管理者和客户报告项目完成的…

【Redis】高可用架构之Cluster集群和分⽚

高可用架构之Cluster集群和分⽚1. 前言2. Cluster 模式介绍2.1 什么是Cluster模式&#xff1f;2.2 为什么需要Cluster模式&#xff1f;2.2.1 垂直拓展&#xff08;scale up&#xff09;和水平拓展&#xff08;scale out&#xff09;2.2.2 Redis Cluster 提供的好处2.2.3 Redis …

学术期刊《广西物理》简介及投稿要求

学术期刊《广西物理》简介及投稿要求 《广西物理》&#xff08;季刊&#xff09;创刊于1980年&#xff0c;是由广西师范大学&#xff1b;广西物理学会主办的物理杂志。本刊报道与物理有关的基础研究、应用研究以及与此有关的交叉学科研究领域的最新重要研究成果和发展趋势&…

编码与加密基础笔记

文章目录&#x1f449;1、ASCII 编码&#x1f449;2、了解Base64&#x1f449;3、MD5消息摘要算法&#x1f449;4、对称加密与 AES&#x1f449;5、非对称加密与 RSA参考书籍《Python 3 反爬虫原理与绕过实战》&#x1f449;1、ASCII 编码 ASCII编码实际上约定了字符串和二进制…

Python中使用matplotlib时显示中文乱码_(或更改字体)

一、问题描述 在使用matplotlib绘制可视化图表时&#xff0c;图表的中文显示乱码&#xff0c;只能正常显示英文内容&#xff0c;如下图所示&#xff1a; 二、问题分析 一般显示乱码是由于编码问题导致的&#xff0c;而matplotlib 默认使用ASCII 编码&#xff0c;但是当使用pypl…

全语言通用的ASCIL表讲解,这一篇就够了

目录 ASCII码诞生背景 ASCII码特性 可显示字符 大佬们可以看这个 小白们看这个更详细 对控制字符的解释 ASCII码诞生背景 在计算机中&#xff0c;所有的数据在存储和运算时都要使用二进制表示。例如&#xff0c;像a、b、c、d这样的52个字母&#xff08;包括大写&#xf…

Winnolin 绘制药时曲线图C-T

文章目录前言一、各受试者C-T图1.导入数据2.设置-运行2.查看结果&#xff0c;修改参数二、各制剂C-T图1.导入数据2.设置-运行2.查看结果&#xff0c;修改参数三、平均C-T图1.计算统计量2.设置统计量计算参数&#xff08;Set Up&#xff09;3.绘图XY Plot4.查看结果&#xff0c;…

Java多线程基础面试总结(三)

线程的生命周期和状态 Java 线程在运行的生命周期中的指定时刻只可能处于下面 6 种不同状态的其中一个状态&#xff1a; NEW&#xff1a;初始状态&#xff0c;线程被创建出来&#xff0c;但是还没有调用start()方法。RUNABLE&#xff1a;运行中状态&#xff0c;调用了start()…

Java设计模式 11-代理模式

代理模式 一、 代理模式(Proxy) 1、代理模式的基本介绍 代理模式&#xff1a;为一个对象提供一个替身&#xff0c;以控制对这个对象的访问。即通过代理对象访问目标对象.这样做的好处是: 可以在目标对象实现的基础上,增强额外的功能操作,即扩展目标对象的功能。被代理的对象…

时间序列的平稳性

如何检查时间序列是否平稳&#xff0c;如果它是非平稳的&#xff0c;我们可以怎么处理 当未来的数据与现在相似时&#xff0c;它更容易建模。平稳性描述了时间序列的统计特征不随时间变化的概念。因此一些时间序列预测模型&#xff0c;如自回归模型&#xff0c;依赖于时间序列…

IoC 之 Spring 统一资源加载策略【Spring源码】

《JavaPub源码》 文末是系列文章 IoC 之 Spring 统一资源加载策略 Spring 框架的核心是 IoC&#xff08;Inversion of Control&#xff09;&#xff0c;它将应用程序的对象依赖关系管理和控制反转到容器中。在 Spring IoC 容器中&#xff0c;组件的创建和配置是通过外部配置…

IDEA 运行启动 pulsar-manager项目

IDEA 运行 pulsar-manager项目&#xff08;gradle&#xff09; 1、下载pulsar-manager源码 giithub地址 smn-manager 2、将项目导入IDEA并初始化项目 问题&#xff1a;SSL peer shut down incorrectly 将https改成http之后又会出现 Server returned HTTP response code: …

服务(第四篇)Apache的网页优化

一、网页压缩 ①首先检查是否安装 mod_deflate 模块 ②如果没有安装mod_deflate 模块&#xff0c;重新编译安装 Apache 添加 mod_deflate 模块 yum -y install gcc gcc-c pcre pcre-devel zlib-devel cd /opt/httpd-2.4.29/ ./configure \ --prefix/usr/local/httpd \ --enabl…

HDFS学习笔记 【Namenode/DN管理】

说明 DN管理管理了什么&#xff1f; NN上如何表示DN DN存储和块的关系 梳理DatanodeManager存储类 DatanodeDescriptor DN的抽象&#xff0c;依次继承。每一层增加一点额外的信息。 DatanodeId 基本的DN信息&#xff0c;hostname&#xff0c;数据传输接口&#xff0c;info服…

QTableView 设置selection-background-color和border不同时生效问题记录

问题&#xff1a; qtableview在使用过程种设置qss样式&#xff0c;设置选中时的背景色&#xff0c;以及边框颜色&#xff0c;不能同时生效。 解决&#xff1a; 在qss中设置QTableView的样式时&#xff0c;对于item项&#xff0c;selection-background-color的参数设置应该分…

在将公司“一拆六”后,阿里巴巴未来将释放出哪些投资价值?

来源&#xff1a;猛兽财经 作者&#xff1a;猛兽财经 阿里巴巴为何要将公司拆分为六大业务集团 3月28日&#xff0c;阿里巴巴集团董事会主席兼首席执行官张勇发布全员信&#xff0c;宣布启动“16N”组织变革&#xff0c;将公司拆分为六大业务集团和多家业务分公司。 在阿里巴巴…

关于FPGA(Vivado)后仿真相关问题的探讨

FPGA后仿真时&#xff0c;相比于功能仿真增加了门延时和布线延时&#xff0c;相对于门级仿真增加了布线延时&#xff0c;因此后仿真相比于功能仿真具有不同的特点。 下面所示的代码在功能仿真时是正确的的&#xff0c;但在后仿真时&#xff0c;似乎是有问题的。功能很简…

大数据项目组-月度考核汇报0102

目录 01-2023年02月-月度考核汇报 2月份完成项目情况 2月份学习情况 3月份学习计划 老师点评 02-2023年03月-月度考核汇报 项目完成情况 本月学习内容 下月学习计划 老师点评 01-2023年02月-月度考核汇报 2月份完成项目情况 MySQL数据同步到ElasticSearch任务进展&a…

linux shell 操作二进制文件(xxd、dd)

1&#xff0c;生成一个二进制文件 dd 工具 # 全零 二进制文件 dd if/dev/zero of1.bin bs1 count1024#全0xff tr \000 \377 < /dev/zero | dd ofall_0xff.bin bs1 count1024 > /dev/null xxd 工具&#xff1a;只能改单个地址 # echo "0x123" | xxd -r – xx…