C语言 操作符详解

news2024/11/17 6:40:31

C语言学习

目录

文章目录

前言

一、算术操作符

二、移位操作符

2.1 左移操作符

2.2 右移操作符

三、位操作符

3.1 按位与操作符 &

3.2 按位或操作符 | 

3.3 按位异或操作符 ^

四、赋值操作符

五、单目操作符

5.1 逻辑反操作符!

5.2 正值+、负值-操作符

5.3 取地址操作符&

5.4 计算操作数的类型长度sizeof

5.5 按位取反操作符 ~

5.6 ++和--操作符

5.7 解引用操作符 *

5.8 强制类型转换操作符()

5.9 sizeof和数组

六、关系操作符

总结


前言

        本文介绍C语言操作符,有以下内容:算术操作符、移位操作符、位操作符、赋值操作符、单目操作符、关系操作符。


一、算术操作符

+      -      *       /      %

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

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

  • 整型的除法:

代码示例:

#include <stdio.h>

int main()
{
	int a = 1 / 2;
	printf("a=%d\n", a);
	return 0;
}

运行结果:

a=0
  • 浮点型的除法:

代码示例1:

#include <stdio.h>

int main()
{
	double b = 1.0 / 2;
	printf("b=%f\n", b);
	return 0;
}

运行结果:

b=0.500000

代码示例2:

#include <stdio.h>

int main()
{
	double b = 1 / 2.0;
	printf("b=%f\n", b);
	return 0;
}

运行结果:

b=0.500000

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

代码示例:

#include <stdio.h>

int main()
{
	int c = 7 % 2;
	printf("c=%d\n", c);
	return 0;
}

运行结果:

c=1

二、移位操作符

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

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

        移位操作符移动的是二进制位。

整数的二进制表示有3种:

  • 原码
  • 反码
  • 补码

正的整数的原码、反码、补码相同。

负的整数的原码、反码、补码是要计算的。

  • 由负整数原码计算出反码:原码的符号位不变,其他位按位取反
  • 由负整数反码计算出补码反码+1

示例:

7的原码、反码、补码:

  • 原码:0000 0000 0000 0000 0000 0000 0000 0111
  • 反码:0000 0000 0000 0000 0000 0000 0000 0111
  • 补码:0000 0000 0000 0000 0000 0000 0000 0111

-7的原码、反码、补码:

  • 原码:1000 0000 0000 0000 0000 0000 0000 0111
  • 反码:1111  1111  1111  1111  1111  1111  1111 1000   符号位不变,其他位按位取反
  • 补码:1111  1111  1111  1111  1111  1111  1111 1001   反码+1

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

        移位操作符移动的是存在内存中的补码。

2.1 左移操作符

移位规则: 左边抛弃、右边补0。

正的整数左移示例:

        对7左移

补码:0000 0000 0000 0000 0000 0000 0000 0111

左移:0000 0000 0000 0000 0000 0000 0000 1110     

        左移后内存中存的还是补码,因为正整数的原码和补码相同,所以对7左移后的值十进制为14。

代码验证:

#include <stdio.h>

int main()
{
	int a = 7 ;
	int b = a << 1;
	printf("a=%d\n", a);
	printf("b=%d\n", b);
	return 0;
}

运行结果:

a=7
b=14

        变量b得到了变量a左移1位之后的变化,但变量a自身是不变的。


负的整数左移示例:

        对-7左移

补码:1111  1111  1111  1111  1111  1111  1111 1001

左移:1111  1111  1111  1111  1111  1111  1111 0010

        左移后内存中存的还是补码,因为负整数的原码和补码之间需要计算。

  • 由负整数补码计算出反码补码-1
  • 由负整数反码计算出原码:反码的符号位不变,其他位按位取反

补码:1111  1111  1111  1111  1111  1111  1111 0010  (左移1位后)

反码:1111  1111  1111  1111  1111  1111  1111 0001    补码-1

原码:1000 0000 0000 0000 0000 0000 0000 1110     符号位不变,其他位按位取反。

        计算出-7左移后的值十进制为-14。

代码验证:

#include <stdio.h>

int main()
{
	int a = -7 ;
	int b = a << 1;
	printf("a=%d\n", a);
	printf("b=%d\n", b);
	return 0;
}

运行结果:

a=-7
b=-14

        因为二进制数的每一位都是2的指数幂,所以左移1位后,只要没有发生数据溢出,值就会变为原来的2倍,如果变量为无符号整形或正整数,表达式 a << n 会将a的所有位左移n位,运算结果位a×2^{n}

2.2 右移操作符

移位规则:

  1. 逻辑移位:左边补0,右边丢弃。
  2. 算术移位:左边补原值的符号位,右边丢弃。(绝大多数编译器采用算术移位,所以示例都为算数移位结果)

正的整数右移示例:

        对7右移

补码:0000 0000 0000 0000 0000 0000 0000 0111

左移:0000 0000 0000 0000 0000 0000 0000 0011     

        右移后内存中存的还是补码,因为正整数的原码和补码相同,所以7左移后的值十进制为3。

代码验证:

#include <stdio.h>

int main()
{
	int a = 7 ;
	int b = a >> 1;
	printf("a=%d\n", a);
	printf("b=%d\n", b);
	return 0;
}

运行结果:

a=7
b=3

负的整数右移示例:

        对-7右移

补码:1111  1111  1111  1111  1111  1111  1111 1001

左移:1111  1111  1111  1111  1111  1111  1111 1100

        右移后内存中存的还是补码,因为负整数的原码和补码之间需要计算。

  • 由负整数补码计算出反码补码-1
  • 由负整数反码计算出原码:反码的符号位不变,其他位按位取反

补码:1111  1111  1111  1111  1111  1111  1111 1100  (左移1位后)

反码:1111  1111  1111  1111  1111  1111  1111 1011    补码-1

原码:1000 0000 0000 0000 0000 0000 0000 0100     符号位不变,其他位按位取反。

        计算出-7右移后的值十进制为-4。

代码验证:

#include <stdio.h>

int main()
{
	int a = -7 ;
	int b = a >> 1;
	printf("a=%d\n", a);
	printf("b=%d\n", b);
	return 0;
}

运行结果:

a=-7
b=-4

        因为二进制数的每一位都是2的指数幂,所以右移1位后,只要没有发生数据溢出,值就会变为原来的二分之一,如果变量为无符号整形或正整数,表达式 a >> n 会将a的所有位右移n位,运算结果位a÷2^{n}

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

三、位操作符

  •  &  //按(2进制)位与
  •  |  //按(2进制)位或
  •  ^  //按(2进制)位异或  —— 相同为0,相异为1

注:他们的操作数必须是整数。

3.1 按位与操作符 &

        & :两者都为1时结果为1。

代码示例:

#include <stdio.h>

int main()
{
	int a = -5;
	int b = 3;
	int c = a & b;
	printf("a=%d\n", a);
	printf("b=%d\n", b);
	printf("c=%d\n", c);
	return 0;
}

运行结果:

a=-5
b=3
c=3

        先计算出-5和3的二进制位补码

-5二进制位

原码:1000 0000 0000 0000 0000 0000 0000 0101

反码:1111 1111  1111 1111  1111 1111  1111 1010

补码:1111 1111  1111 1111  1111 1111  1111 1011

3二进制位

补码:0000 0000 0000 0000 0000 0000 0000 0011  

        用补码进行按位与计算:

1111 1111  1111 1111  1111 1111  1111 1011      -5补码

0000 0000 0000 0000 0000 0000 0000 0011    3补码

0000 0000 0000 0000 0000 0000 0000 0011      -5 & 3 的补码

        因为符号位为0,为正整数,所以原码与补码相同,对应十进制值为3。

3.2 按位或操作符 | 

        | :只要有一个为1,结果就为1。

代码示例:

#include <stdio.h>

int main()
{
	int a = -5;
	int b = 3;
	int c = a | b;
	printf("a=%d\n", a);
	printf("b=%d\n", b);
	printf("c=%d\n", c);
	return 0;
}

运行结果:

a=-5
b=3
c=-5

        用补码进行按位或计算:

1111  1111  1111  1111  1111  1111 1111 1011      -5补码

0000 0000 0000 0000 0000 0000 0000 0011    3补码

1111  1111  1111  1111  1111  1111  1111 1011     -5 | 3 的补码

        因为符号位为1,为负整数,所以原码需由补码计算得出。

1111  1111  1111  1111  1111  1111  1111 1011       补码

1111  1111  1111  1111  1111  1111  1111 1010       反码

1000 0000 0000 0000 0000 0000 0000 0101       原码

        计算得出原码的十进制值为-5。

3.3 按位异或操作符 ^

        ^ :相同为0,相异为1。

代码示例:

#include <stdio.h>

int main()
{
	int a = -5;
	int b = 3;
	int c = a ^ b;
	printf("a=%d\n", a);
	printf("b=%d\n", b);
	printf("c=%d\n", c);
	return 0;
}

运行结果:

a=-5
b=3
c=-8

        用补码进行按位异或计算:

1111  1111  1111  1111  1111  1111 1111 1011      -5补码

0000 0000 0000 0000 0000 0000 0000 0011    3补码

1111  1111  1111  1111  1111  1111  1111 1000     -5 ^ 3 的补码

        因为符号位为1,为负整数,所以原码需由补码计算得出。

1111  1111  1111  1111  1111  1111  1111 1000       补码

1111  1111  1111  1111  1111  1111  1111 0111       反码

1000 0000 0000 0000 0000 0000 0000 1000       原码

        计算得出原码的十进制值为-8。


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

方法1代码示例:

#include <stdio.h>

int main()
{
	int a = 5;
	int b = 3;
	printf("a=%d ", a);
	printf("b=%d\n", b);
	a = a + b;//变量a中存了a+b的和
	b = a - b;//a+b的和8减去变量b的值3就是变量a的初值5,
              //把5存在变量b中,此时变量a中的值还是a+b的和8
	a = a - b;//a+b的和8减去此时变量b的值5,就是变量b的初值3,
              //把3存在变量a中,此时变量a中的值是3
	printf("a=%d ", a);
	printf("b=%d\n", b);
    return 0;
}

运行结果:

a=5 b=3
a=3 b=5

        但是这种方法会有溢出的问题。

方法2代码示例:

#include <stdio.h>

int main()
{
	int a = 5;
	int b = 3;
	printf("a=%d ", a);
	printf("b=%d\n", b);
	a = a ^ b;//a = 5 ^ 3
	b = a ^ b;//b = 5 ^ 3 ^ 3   ->   b=5
	a = a ^ b;//a = 5 ^ 3 ^ 5   ->   a=3
	printf("a=%d ", a);
	printf("b=%d\n", b);
    return 0;
}

运行结果:

a=5 b=3
a=3 b=5

        两个相同的数按位异或的结果为0;0和任何整数按位异或的结果为整数本身。

四、赋值操作符

        a = b 就是把b的值赋给a,在 = 左侧必须是变量,不能是常量或表达式。

复合赋值符:+=      -=      *=      /=       %=      >>=      <<=      &=       |=     ^=

        下方每个代码框中的第1句使用复合赋值操作符的代码意思和它下一句代码意思相同。

	a += 3;
	a = a + 3;
	a >>= 3;
	a = a >> 3;
	a &= 3;
	a = a & 3;

五、单目操作符

!                    逻辑反操作

-                    负值

+                   正值

&                   取地址

sizeof            操作数的类型长度(以字节为单位)

~                   对一个数的二进制按位取反

--                   前置、后置--

++                 前置、后置++

*                    间接访问操作符(解引用操作符)

(类型)            强制类型转换

首先来明确一些定义:

  • 操作符(运算符):可以进行运算的符号,如+、-、*、/ 等。
  • 操作数:作为运算对象的变量或常量,如 a+b 中的 a和b。
  • 单目操作(运算)符:只需要有1个操作数,如 +a,-b 。
  • 双目操作(运算)符:需要两个操作数,如 a+b、c-d 。

5.1 逻辑反操作符!

        !作用:把真变假,假变真。

        C语言中0为假,非0为真。

代码示例:

#include <stdio.h>

int main()
{
	int flag = 5;
	//if条件判断:非0为真,0为假
	if(flag)//flag为真,进入if
	{
		printf("真\n");
	}

	if(!flag)//flag为假,进入if
	{
		printf("假\n");
	}
	return 0;
}

5.2 正值+、负值-操作符

代码示例:

#include <stdio.h>

int main()
{
	int a = +8;
	int b = +a;
	int c = -a;
	printf("a=%d\n", a);
	printf("b=%d\n", b);
	printf("c=%d\n", c);

	int e = -9;
	int f = +e;
	int g = -e;
	printf("e=%d\n", e);
	printf("f=%d\n", f);
	printf("g=%d\n", g);

	return 0;
}

运行结果:

a=8
b=8
c=-8
e=-9
f=-9
g=9

5.3 取地址操作符&

        &操作符可以取出变量在内存中的首地址。

代码示例:

#include <stdio.h>

int main()
{
	int a = 6;
	printf("%p\n", &a);
	int* p = &a;//p就是指针变量
	return 0;
}

运行结果:

000000AAD799FA74

5.4 计算操作数的类型长度sizeof

        sizeof是一个操作符。

  • 可以计算变量所占内存空间的大小,单位是字节。
  • 可以计算类型所创建的变量占据空间的大小,单位是字节。
  • 可以计算整个数组所占内存空间的大小,单位是字节。

代码示例:

#include <stdio.h>

int main()
{
	//计算变量所占内存空间的大小,单位是字节。
	int a = 7;
	int n1 = sizeof(a); //计算变量a所占内存空间的大小
	printf("n1=%d\n", n1);

	//计算类型所创建的变量占据空间的大小,单位是字节。
	int n2 = sizeof(int);
	printf("n2=%d\n", n2);

	//计算整个数组所占内存空间的大小,单位是字节。
	int arr[10] = { 0 };
	printf("arr[10]=%d\n", sizeof(arr));

	return 0;
}

运行结果:

n1=4
n2=4
arr[10]=40

sizeof使用细节注意

代码示例:

#include <stdio.h>

int main()
{
	int a = 3;
	printf("%d\n", sizeof(a));
	printf("%d\n", sizeof(int));
	printf("%d\n", sizeof a);//可以这样使用
	printf("%d\n", sizeof int);//不可以这样使用
	return 0;
}

区分:

  • sizeof是操作符,不是函数。
  • strlen是库函数,用来求字符串长度。

5.5 按位取反操作符 ~

 ~0 对0按位取反:

补码:0000 0000 0000 0000 0000 0000 0000 0000      0的原码、反码、补码都相同

取反:1111  1111  1111  1111  1111  1111  1111 1111

        按位取反后内存中存的还是补码,负整数的原码和补码之间需要计算。

  • 由负整数补码计算出反码补码-1
  • 由负整数反码计算出原码:反码的符号位不变,其他位按位取反

补码:1111  1111  1111  1111  1111  1111  1111 1111  (0按位取反后)

反码:1111  1111  1111  1111  1111  1111  1111 1110    补码-1

原码:1000 0000 0000 0000 0000 0000 0000 0001     符号位不变,其他位按位取反。

        计算出0按位取反后的值十进制为-1。

代码验证:

#include <stdio.h>

int main()
{
	int a = 0;
	printf("~a=%d\n", ~a);
	return 0;
}

运行结果:        

~a=-1

~5 对5按位取反

代码示例:

#include <stdio.h>

int main()
{
	int a = 5;
	printf("~a=%d\n", ~a);
	return 0;
}

运行结果:

~a=-6

~5

补码:0000 0000 0000 0000 0000 0000 0000 0101     5的原码、反码、补码都相同

取反:1111  1111  1111  1111  1111  1111 1111 1010

        按位取反后内存中存的还是补码,负整数的原码和补码之间需要计算。

  • 由负整数补码计算出反码补码-1
  • 由负整数反码计算出原码:反码的符号位不变,其他位按位取反

补码:1111  1111  1111  1111  1111  1111 1111 1010  (5按位取反后)

反码:1111  1111  1111  1111  1111  1111  1111 1001    补码-1

原码:1000 0000 0000 0000 0000 0000 0000 0110     符号位不变,其他位按位取反。

        计算出0按位取反后的值十进制为-6。


对某个数的二进制任意一位进行置1或清0的改动:

代码示例:

#include <stdio.h>

int main()
{
	int a = 12;
	a |= (1 << 4);
	printf("a=%d\n", a);

	a &= (~(1 << 4));
	printf("a=%d\n", a);
	return 0;
}

运行结果:

a=28
a=12

对12二进制的第五位置1

0000 0000 0000 0000 0000 0000 0000 1100    12补码

0000 0000 0000 0000 0000 0000 0001 0000     修改第五位的数可由1移位获得

0000 0000 0000 0000 0000 0000 0001 1100      12与上数按位或,得到指定修改位置1

第五位置1后的数十进制为28

对28二进制的第五位清0

0000 0000 0000 0000 0000 0000 0001 1100     28补码

0000 0000 0000 0000 0000 0000 0001 0000     修改第五位的数可由1移位获得

1111  1111  1111  1111  1111  1111  1110 1111     对1移位后的数按位取反

0000 0000 0000 0000 0000 0000 0000 1100      28与上数按位与,得到指定修改位置清0

第五位清0后的数十进制为12

5.6 ++和--操作符

  • 前置++,先++,后使用;
  • 后置++,先使用,再++;
  • 前置--,先--,后使用;
  • 后置--,先使用,再--;

代码示例:

#include <stdio.h>

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

	return 0;
}

运行结果:

a=7
b=7
c=7
d=6

代码示例:

#include <stdio.h>

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

	return 0;
}

运行结果:

a=5
b=5
c=5
d=6

5.7 解引用操作符 *

代码示例:

#include <stdio.h>

int main()
{
	int a = 6;
	int* p = &a;
	*p = 20;
	printf("a=%d\n", a);
	return 0;
}

运行结果:

a=20
  • 取地址操作符&可以通过变量,找到地址;
  • 解引用操作符*可以通过地址,找到变量。

        上面程序中*p就等价于变量a。

5.8 强制类型转换操作符()

        强制类型转换是把变量从一种类型转换为另一种数据类型。

代码示例:

#include <stdio.h>

int main()
{
	int a = (int)3.14;
	printf("a=%d\n", a);
	return 0;
}

运行结果:

a=3

(int)可以强制将带小数点的数转换为整型。

5.9 sizeof和数组

代码示例:

#include <stdio.h>

void test1(int arr[])
{
	printf("test1(arr[])=%d\n", sizeof(arr));
}
void test2(char ch[])
{
	printf("test2(ch[])=%d\n", sizeof(ch));
}
int main()
{
	int arr[10] = { 0 };
	char ch[10] = { 0 };
	printf("arr[10]=%d\n", sizeof(arr));
	printf("ch[10]=%d\n", sizeof(ch));
	test1(arr);
	test2(ch);
	return 0;
}

运行结果:

arr[10]=40
ch[10]=10
test1(arr[])=8
test2(ch[])=8

        sizeof(数组名) 可得出整个数组在内存中的大小。

        数组传参,传递的是数组首元素的地址。所以test1函数和test2函数中sizeof操作符读到的是数组首元素地址在内存中的大小。

六、关系操作符

>
>=
<
<=
!=       用于测试“不相等”
==      用于测试“相等”

        使用过程中注意==和=


总结

        以上就是今天要讲的内容,本文介绍了C语言操作符的使用。

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

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

相关文章

老铺黄金IPO:古法黄金的下半场,从高端走向大众?

当前&#xff0c;国内“掘金热”持续走高。据中国黄金协会统计&#xff0c;2023年前三季度全国黄金消费835.07吨&#xff0c;同比增长7.32%。其中黄金首饰552.04吨&#xff0c;同比增长5.72%。 在市场需求带动下&#xff0c;老铺黄金这家专注古法黄金经营的企业今年上半年业绩…

ubuntu 创建conda 环境失败 HTTP 000 CONNECTION FAILED

如有帮助点赞收藏关注&#xff01; 如需转载&#xff0c;请注明出处&#xff01; 现在内存分配好了&#xff0c;创建一个专门的conda环境处理文件&#xff0c;报错了&#xff0c;创建不成功&#xff01; 什么情况&#xff0c;之前明明可以的。 百度吧。 参照一些博客修改了文档…

java synchronized详解

背景 在多线程环境下同时访问共享资源会出现一些数据问题&#xff0c;此关键字就是用来保证线程安全的解决这一问题。 内存可见的问题 在了解synchronized之前先了解一下java内存模型&#xff0c;如下图&#xff1a; 线程1去主内存获取x的值读入本地内存此时x的值为1&…

Linux(14):进程管理

一个程序被加载到内存当中运作&#xff0c;那么在内存内的那个数据就被称为进程(process)。 进程是操作系统上非常重要的概念&#xff0c;所有系统上面跑的数据都会以进程的型态存在。 进程 在 Linux底下所有的指令与能够进行的动作都与权限有关&#xff0c;而系统如何判定权…

大数据技术学习笔记(四)—— HDFS

目录 1 HDFS 概述1.1 HDFS 背景与定义1.2 HDFS 优缺点1.3 HDFS 组成架构1.4 HDFS 文件块大小 2 HDFS的shell操作2.1 上传2.2 下载2.3 HDFS直接操作 3 HDFS的客户端操作3.1 Windows 环境准备3.2 获取 HDFS 的客户端连接对象3.3 HDFS文件上传3.4 HDFS文件下载3.5 HDFS删除文件和目…

Vue项目解决van-calendar 打开下拉框显示空白(白色),需滑动一下屏幕,才可正常显示

问题描述&#xff0c;如图 ipad(平板&#xff09;或者 H5移动端引入Vant组件的日历组件&#xff08;van-calendar&#xff09;&#xff0c;初始化显示空白&#xff0c;需滚动一下屏幕&#xff0c;才可正常显示 解决方法 需在van-calendar上绑定open"openCalendar"事件…

升辉清洁IPO:广东清洁服务“一哥”还需要讲好全国化的故事

近日&#xff0c;广东物业清洁服务“一哥”升辉清洁第四次冲击IPO成功&#xff0c;拟于12月5日在香港主板挂牌上市。自2021年4月第一次递交招股书&#xff0c;时隔两年半&#xff0c;升辉清洁终于拿到了上市的门票。 天眼查显示&#xff0c;升辉清洁成立于2000年&#xff0c;主…

基于SpringBoot+Vue的前后端分离的房屋租赁系统2

✌全网粉丝20W,csdn特邀作者、博客专家、CSDN新星计划导师、java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取项目下载方式&#x1f345; 一、项目背景介绍&#xff1a; 开发过程中&#xff0…

最强AI之风袭来,你爱了吗?

2017年&#xff0c;柯洁同阿尔法狗人机大战&#xff0c;AlphaGo以3比0大获全胜&#xff0c;一代英才泪洒当场...... 2019年&#xff0c;换脸哥视频“杨幂换朱茵”轰动全网&#xff0c;时至今日AI换脸仍热度只增不减&#xff1b; 2022年&#xff0c;ChatGPT一经发布便轰动全球&a…

聚焦工业生产安全,汉威科技推出最轻最小迷你便携式单气体检测仪

有毒有害气体、可燃气体等是工业生产中常见的危险因素。我国已经出台了多项法律法规、行业标准&#xff0c;在石油、化工、钢铁冶金、危化品、矿业等行业以及有限空间相关场所作业&#xff0c;应当佩戴便携式气体检测仪&#xff0c;以保障作业人员的安全。 然而&#xff0c;近年…

从零开始搭建博客网站-----框架页

实现效果如下 发布的功能还没有实现&#xff0c;仅仅实现了简单的页面显示 关键代码如下 <template><div class"layout"><el-header class"header"><div class"logo">EasyBlog</div></el-header><el-c…

初识动态规划算法(题目加解析)

文章目录 什么是动态规划正文力扣题第 N 个泰波那契数三步问题使用最小花费爬楼梯 总结 什么是动态规划 线性动态规划&#xff1a;是可以用一个dp表来存储内容&#xff0c;并且找到规律存储,按照规律存储。让第i个位置的值等于题目要求的答案 >dp表&#xff1a;dp表就是用一…

Trello软件:从功能、使用技巧到替代软件等,一文弄懂项目管理必备工具!

Trello是什么&#xff1f; Trello是一款基于Web的可视化项目管理工具&#xff0c;它旨在提供一种灵活、易于理解和使用的任务管理系统。Trello将复杂的项目管理流程简化为直观的卡片和列表&#xff0c;使团队成员能轻松看到整个项目的状态&#xff0c;并了解自己的责任和任务。…

【React设计】React企业级设计模式

Image Source : https://bugfender.com React是一个强大的JavaScript库&#xff0c;用于构建用户界面。其基于组件的体系结构和构建可重用组件的能力使其成为许多企业级应用程序的首选。然而&#xff0c;随着应用程序的规模和复杂性的增长&#xff0c;维护和扩展变得更加困难。…

面试官:说说synchronized与ReentrantLock的区别

程序员的公众号&#xff1a;源1024&#xff0c;获取更多资料&#xff0c;无加密无套路&#xff01; 最近整理了一波电子书籍资料&#xff0c;包含《Effective Java中文版 第2版》《深入JAVA虚拟机》&#xff0c;《重构改善既有代码设计》&#xff0c;《MySQL高性能-第3版》&…

python pyaudio 录取语音数据

python pyaudio 录取语音数据 pyaudio安装方法&#xff1a; pip install pyaudio如果这个不行&#xff0c;可以尝试&#xff1a; pip install pipwin pipwin install pyaudio代码如下&#xff1a; import pyaudio import waveRESPEAKER_RATE 44100 # 采样率&#xff0c;每…

LoadBalancer将服务暴露到外部实现负载均衡purelb-layer2模式配置介绍

目录 一.purelb简介 1.简介 2.purelb的layer2工作模式特点 二.layer2的配置演示 1.首先准备ipvs和arp配置环境 2.purelb部署开始 &#xff08;1&#xff09;下载purelb-complete.yaml文件并应用 &#xff08;2&#xff09;查看该有的资源是否创建完成并运行 &#xff…

数字化转型浪潮中,施耐德电气如何用技术革新引领未来?

作为一家187年的老牌企业&#xff0c;施耐德电气不仅见证了科技的演进&#xff0c;也是数字化转型潮流中的先行者。在近日的施耐德电气数字化战略暨软件创新沟通会上&#xff0c;施耐德电气全球执行副总裁&#xff0c;首席数字官Peter Weckesser&#xff1b;施耐德电气副总裁、…

MySQL笔记-第03章_基本的SELECT语句

视频链接&#xff1a;【MySQL数据库入门到大牛&#xff0c;mysql安装到优化&#xff0c;百科全书级&#xff0c;全网天花板】 文章目录 第03章_基本的SELECT语句1. SQL概述1.1 SQL背景知识1.2 SQL语言排行榜1.3 SQL 分类 2. SQL语言的规则与规范2.1 基本规则2.2 SQL大小写规范 …

PoE技术详解

标准的五类网线有四对双绞线&#xff0c;IEEE 802.3af和IEEE 802.3at允许两种用法&#xff1a;通过空闲线对供电或者数据线对供电。IEEE 802.3bt允许通过空闲线对供电、通过数据线对供电或者空闲线对和数据线对一起供电&#xff0c;如图16.1所示。 图 16.1 PoE供电线对 当在一…