go学习-指针 标识符

news2024/9/22 1:13:00

指针,以及标识符

1.指针

(1).基本介绍

1)基本数据类型,变量存的值,也叫值类型

2)获取变量的地址用&,比如 var num int ,获取num的地址:&num

3)指针类型,变量存的是一个地址,这个地址指向的空间存的才是真正值,比如: var ptr *int =&num

4)获取指针类型所指的值,使用*,比如:var *ptr int,使用 *ptr获取p指向的值

5)举例说明

package main

import(
	"fmt"
)
//演示golang中的指针类型
func main(){


	//基本数据在内存的布局
	var i int = 10 
	// i的地址是多少 &i
	fmt.Println("i的地址=",&i)  //结果为:i的地址= 0xc04205e058
	//1.a是一个指针变量
	//2. a的类型是 *int
	//3.a 本身就是 &i
	var a *int =&i
	fmt.Println("i的值是",i) //10
	fmt.Println("a存放的值是",a)//0xc04205e058
	fmt.Println("a指向的值是",*a)//10
    fmt.Println("指针本身的地址是",&a)//0xc04207c020
    或者可以使用printf()进行格式化输出

}

内存布局图:

在这里插入图片描述

关于指针的内存布局操作

在这里插入图片描述

练习,通过指针修改所存变量地址中存放的值

package main

import(
	"fmt"
)

func main(){
var a int =999
fmt.Println("a的地址是",&a)
fmt.Println("指针修改之前a的值是",a)
var prt *int = &a
fmt.Println("prt的值是",*prt)
*prt = 23  //通过指针去修改a变量的值
fmt.Println("prt的值是",*prt)
fmt.Println("通过指针修改后这个a的值是",a)

}

判断对错

func main(){
var a int = 300
var ptr *int =a //错误应该是 &a
}

func main(){
var a int = 300
var prt *float32 = &a //错误,类型不一致,不应该是float
}


func main(){
var a int =300
var b int =400

var ptr *int =&a
*ptr = 100 //a=100
ptr = &b  //存放b的地址
*ptr = 200  //b=200
fmt.Printf("a=%d, b=%d,*ptr=%d",a,b,*ptr)


}

(2)指针的细节说明

1)值类型,都有对应的指针类型,形式为:“数据类型”,比如int 的对应的指针就是 * int,而float32对应的指针类型就是 *float32 ,以此类推

2)值类型:基本数据类型int系列,float系列,bool string \数组和结构体struct

2.值类型和引用类型

(1)说明:

1)值类型:基本数据类型int系列,float系列,bootl,string、数组和结构体struct

2)引用类型:指针,slice切片、map、管道chan,interface等都是引用类型

(2)值类型和引用类型的区别

1)值类型:变量直接存储,内存通常在栈中分配

在这里插入图片描述

2)引用类型:变量存储的是一个地址,这个地址对应的空间才真正存储数据(值),内存通常在堆中分配,当没有任何变量引用这个地址时,该地址对应的数据空间就成为一个垃圾由GC来回收

在这里插入图片描述

3.标识符的命名规范

(1).标识符概念

1)golang对各种变量、方法等命名时使用的字符序列称为标识符

2)凡是自己可以起名字的地方都叫标识符

(2).标识符的命名规则(6点)

1)由26个英文字母大小写,0~9,下划线—组成

2)数字不可以开头

3)Golang中严格区分大小写

4)标识符不能包含空格

5)下划线"—"本身在go中是一个特殊字符,称为空标识符,可以代表任何其他的标识符,但是它对应的值会忽略(比如,忽略某个返回值),所以仅能被作为占位符使用不能作为标识符使用

6)不能以系统保留关键字作为标识符,比如break、if等等…

package main

import "fmt"

//演示golang中标识符的使用
func main() {
	//严格区分大小写
   var num int = 10
   var Num int = 20
   fmt.Printf("num=%v,Num=%v",num,Num) //10 20
   //标识符中不能含有空格
//    var ab c int = 30  //会报错

//_是空标识符,用于占用
// var _ int =40  // erro

} 

(3)go中的保留字

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Cm24KPYQ-1693040914579)(D:\myfile\后端\go语言学习\pic\关键字.jpg)]

标识符的案例

hello  //OK
hello12 //OK
1hello //erro 不能以数字开头
h-b  //erro 不能使用-
x h   //erro 不能有空格
h_4   //ok
_ab   //ok
int    //ok 不推荐,甚至不要去用,语法通过不推荐使用
var int int =10
fmt.Println("int的值",int)//10success
float32  //ok
_  //erro
Abc  //ok


(4)标识符命名注意事项

1)包名:保持package的名字和目录保持一致,尽量采取有意义的包名,简短,有意义不要和标准库冲突

2)变量名、函数名、常量名,采用驼峰法

var stuName string ="Tom"
var goodPrice int32 =124//第一个单词字母小写往后的单词采用大写的形式

3)如果使用变量名、函数名、常量名首字母大写,则可以被其他的包访问;如果首字母小写,则只能在本包中使用(可以简单理解成,首字母大写是公有的,首字母小写是私有的

在这里插入图片描述

预定标识符

在这里插入图片描述

保留关键字的介绍:

在这里插入图片描述

(5)运算符:

运算符是一种特殊的符号,用以表示数据的运算,赋值和比较等

1)算术运算符

主要是对数值型的变量进行运算,比如加减乘除,在Go程序中使用最多

在这里插入图片描述

package main

import(
	"fmt"
)

func main() {
//重点讲解 /,%
//如果参与运算的数都是整数,那么除后,去掉小数部分,保留整数部分。不会四舍五入
fmt.Println(10/4) //是2不是2.5
var n1 float32 = 10 /4  //?结果也是2
fmt.Println(n1)

//如果我们需要保留小数部分,则需要有浮点数参与运算
var n2 float32 = 10.0 /4
fmt.Println(n2) //2.5
}
//演示%的用法
//演示 % 的使用
//看一个公式 a%b=a - (a/b) *b
fmt.Println("10%3=",10 % 3) //结果余数是1
fmt.Println("-10%3=",-10 % 3) //结果余数是-1 : -10 - [(-10)/3]*3 =-10 -(-9)=-1
fmt.Println("10%-3=",10 % -3) //结果余数是 1
fmt.Println("-10%-3=",-10 % -3) //结果余数是 -1
//演示 ++ --
var i int = 10
i++  //等价 i = i+1
fmt. Println("i的值是",i)  //11
i-- //等价i = i -1
fmt. Println("i的值是",i)  //10

(6)细节说明:

1)对于除号 ”/“,他的整数和小数除是有区别的,整数之间做除法时,只保留整数部分而舍弃小数部分,例如 x := 19/5 结果是3

2)当对一个数取模式时,可以等价 a%b =a- a/b *b,这样我们就可以看到取模的本质运算

3)Golang的自增自减只能作为一个独立语言时,不能这样使用 b :=a++或者b :=a–

4)Golang的++和–只能写在变量的后面,不能写在变量的前面,既:a++ a–没有++a 或者–a

5)Golang的设计者去掉c/java中的自增自减的容易混淆的写法让Golang的语法更加简洁统一

在这里插入图片描述

练习:

(1)假如还有97天放假 问 xx个星期零xx天

(2)定义一个变量保存华氏温度,华氏温度转换为摄氏温度的公式是:5/9*(华氏温度-100)求出华氏温度对应的摄氏温度

package main

import (
	"fmt"
)

func main(){
	//题1
 var day int  =97
 var week int = day/7
 var mo int = day%7
fmt.Printf("还有%d天放假,是%d个星期%d天",day,week,mo)
 
var huashi float32 = 134.2
var sheshi float32 = 5.0 / 9 * (huashi - 100)
fmt.Printf("%v对应的摄氏温度=%v",huashi,sheshi) 19 
}

2)赋值运算符

介绍

赋值运算符就是将某个运算后的值,赋给指定的变量

赋值运算符的分类:

在这里插入图片描述

在这里插入图片描述

案例演示

(1)赋值基本案例

(2)有两个变量,a和b ,要求将其交换,最终打印结果

(3)+=的使用案例

package main
	
	import (
		"fmt"
	)

	func main() {
		//赋值运算符的使用演示
		// var i int 
		// i = 10   //基本赋值

		//有两个变量,a和b要求将其进行交换,最终打印结果
		//a =9 b=2 ==>a =2 b =9
		a := 9
		b := 2
        //定义一个临时变量
		t :=a
		a =b
		b =t
    fmt.Printf("交换后的情况如下 a=%v,b=%v",a,b)
 
	//复和赋值的操作
	a +=7  //等价 a = a+7
	fmt.Println("a+=7的值为",a)


	}

赋值运算符的特点

(1)运算顺序从右往左

(2)赋值运算符的左边只能是变量 ,右边 可以是变量、表达式、常量值

(3)复合运算符等价于下面的效果

a+=3 a=a+3

3)比较运算符/关系运算符

(1)关系运算符的结果都是bool型,也就是要么为true,要么为false

(2)关系表达式经常用字在if结构中或者循环条件中

关系运算符一览表

在这里插入图片描述

细节说明

  • 关系运算符的结果都是bool型,也就是要么为true,要么为false
  • 关系运算符组成的表达式,我们称为关系表达式 a>b
  • 比较运算符”==“不能写成 “=”

面试题

package main

import(
	"fmt"
)
func main(){
	//有两个变量a和b,要求将其进行交换,但是不允许使用中间变量,最终打印效果
	var a int = 10
	var b int = 20
	a = a + b  //30 
	b = a - b  // 10
	a = a -b  //30-10 =20

	fmt.Printf("a=%v和b=%v",a,b) //20 和 10
}

4)逻辑运算符

介绍

用于连接多个条件(一般来讲就是关系表达式),最终的结果也是一个bool值

逻辑运算一览表:

在这里插入图片描述

案例演示

package main
import (
	"fmt"
)

func main() {
  //演示如何使用逻辑运算符
  var age int =40
  if  age > 30 && age < 50{
	fmt.Println("ok1")
  }

  if  age > 30 && age < 40{
	fmt.Println("ok2")
  }

  //演示逻辑或的使用  ||
  if  age > 30 || age < 50{
	fmt.Println("ok3")
  }

  if  age > 30 || age < 40{
	fmt.Println("ok4")
  }
 //演示逻辑非的使用 !
 if  !(age > 30) {
	fmt.Println("ok5") //不输出
  }
}

注意事项和使用细节

  • &&也叫短路与,如果第一个条件为false,则第二个条件不会判断,最终结果为false
  • ||也叫短路或,如果第一个条件为true,则第二个条件不会判断,最终结果为true

案例演示:

//声明一个测试函数(测试)
func test() bool {
	fmt.Println("test....")
return true
}

func main() {
	var i  int = 10
	//短路与的
	//说明:i<9 这个为false 第二条件根本不会去判断不会调用test函数
   if i < 9 && test(){
	fmt.Println("ok")
   }
   //短路或
   //说明:i>9 这个为true 第二条件根本不会去判断不会调用test函数
   if i > 9 || test(){
	fmt.Println("ok")
   }

    

运算符的优先级

(1)运算符有着不同的优先级,所谓优先级就是表达式运算中的运算顺序,如下表,上一行运算符总优先于下一行

在这里插入图片描述

(2)只有单目运算符、赋值运算符是从右往左运算的

(3)大致的顺序整理

  1. 括号,++.–
  2. 单目运算
  3. 算术运算符
  4. 移位运算
  5. 关系运算
  6. 位运算
  7. 逻辑运算符
  8. 赋值运算符
  9. 逗号

6)其他运算符

位运算符

在这里插入图片描述

在这里插入图片描述

课堂练习

(1)两个数的最大值

(2)求三个数的最大值

func main() {
	//求两个数的最大值
	var n1 int =10
	var n2 int =40
	var max int
	if n1 > n2{
		max =n1
	}else{
		max =n2
	}
	fmt.Println("两个数的最大值为:",max)

	//求出三个数的最大值
	//先求出两个数的最大值然后让第三个数取比较

	var n3 int =45
    if n3 > max {
		max =n3
	}
	fmt.Println("三个数中的最大值是=",max)
}

键盘输入语句

介绍

在编程中,需要接收用户输入的数据,就可以使用键盘输入语句来获取’

步骤:

1)导入fmt包

2)调用fmt包的fmt.Scanln()或者fmt.Scanf()

案例演示:

要求:可以从控制台上接受用户信息。[姓名,年龄,薪水,是否通过考试]

1)使用fmt.Scanln()获取

fmt.Println("请输入姓名")
   //当程序执行到fmt.Scanln(name)是,程序会停止运行,并等待用户的输入
   fmt.Scanln(&name)

   fmt.Println("请输入年龄")
   fmt.Scanln(&age)

   fmt.Println("请输入薪水")
   fmt.Scanln(&sal)

   fmt.Println("是否通过考试")
   fmt.Scanln(&isPass)

fmt.Printf("名字是%v \n 年龄是%v \n 薪水是 %v \n 是否通过考试 %v ",name,age,sal,isPass)

2)使用fmt.Scanf()获取

/方式2.一次性输入这些信息 fmt.Scanf()可以按指定的格式输入信息
fmt.Println("姓名,年龄,薪水,是否通过考试,输入时采用空格隔开")
fmt.Scanf("%s %d %f %t ",&name,&age,&sal,&isPass)
fmt.Printf("名字是%v \n 年龄是%v \n 薪水是 %v \n 是否通过考试 %v ",name,age,sal,isPass)

4.go语言机制转换

1)进制介绍

  • 二进制 : 0,1 满2进1在golang中不能直接使用二进制表示一个整数,因为他沿袭了C语言的风格要输出就%b

  • 十进制:0~9满10进1

  • 八进制:0~7满8进1,以数字0开头表示

  • 十六进制:0~9A-F满16进1以0x或0x开头表示

    此处A~F不区分大小写

    如:0x21AF+1=02x21B0

2)案例使用

func main(){
	var i int =5;

	fmt.Printf("%d的二进制是%b\n",i,i) //输出的结果是:5的二进制是101
    //八进制:0~7,满8进1,以数字0开头进行表示
    var j int = 011
	fmt.Println("j=",j) //9
   //0~9及A-F以0x或0X表示
    var k int = 0x11
	fmt.Println("k=",k) //17

}

进制转换的介绍

第一组(其他进制转换为十进制)

在这里插入图片描述

1)二进制转十进制

规则:从最低位开始(右边的),将每个位上的数提取出来,乘以2的(位数-1)次方然后求和

案例:请将二进制:1011转成十进制的数
1011=1*1+1*2+0*2*2+1*2*2*2=1+2+0+8=11


2)八进制转十进制

规则:从最低位开始(右边的),将每个位上的数提取出来,乘以8的(位数-1)次方然后求和

请将0123转成十进制的数
3+2*8+1*8*8=83

3)十六进制转十进制

规则:从最低位开始(右边的),将每个位上的数提取出来,乘以8的(位数-1)次方然后求和

请将0x34A转成十进制的数
10+4*16+3*16*16=842

第二组(十进制转其他进制)

1)十进制转二进制

规则:将该数不断除于2,直到商为0为止,然后将得到的余数倒过来就是对应的二进制

案例;请将56转成2进制

在这里插入图片描述

2)十进制转八进制

规则:将该数不断除于8,直到商为0为止,然后将得到的余数倒过来就是对应的二进制

3)十进制转十六进制

规则:将该数不断除于16,直到商为0为止,然后将得到的余数倒过来就是对应的二进制

第三组

1)二进制转八进制

规则:将二进制数每三位一组(从低位开始组合),转成对应的八进制数即可

案例将二进制 11010101转成八进制

11010101=0325

2)二进制转十六进制

规则:将二进制每四位数一组(从低位开始组合),转换对应的十六进制数即可

案例:请将二进制:11010101转成16进制数为:0XD5

11100101 转化为八进制:0345

1110010110转化为十六进制:0x396

第四组

1)将八进制数每1位转成对应的一个3位的二进制数即可

案例:请将0237转成二进制

0237=10011111

2)将十六进制每1位转成1个4位的二进制数

0x3D=0x111101

原码 补码反码

在这里插入图片描述

在这里插入图片描述

golang有三个位运算

在这里插入图片描述

2的补码:00000010

3的补码 00000011

2&3=00000010 =2

2|3=00000011=3

2^3=00000001

-2^2=-4

-2的原码为:10000010

-2的反码为:11111101

-2的补码:11111110

2的补码 00000010

故-2^2=11111100 的原码是先求出他的反码然后进行取反操作

反码=补码-1:11111011==》原码(符号位不变其他取反):10000100=-4

-1:10000001=》反码=》11111110补码:11111111 +00000001=全是0

func main(){
	
	//位运算的知识演示
	fmt.Println(2&3) //2
	fmt.Println(2|3)//3
	fmt.Println(2^3)//1
	//下面是带有负数的二进制
	fmt.Println(-2^2)//-4

}

golang有两个移位运算符

>> 右移、 <<左移
右移运算符 >>:低位溢出,符号位不,并用符号位补溢出的高位
左移运算符<< 符号位不变,低位补0

案例演示:

都要将原来的数变成补码进行运算
a:=1>>2//00000001=>00000000=0 右移即补码左边补0
c:=1<<2 //00000001=>00000100=4左移即补码右边补0
fmt.Println(1>>2)//0
fmt.Println(1<<2)//4

…(img-EvonRpVt-1693040914591)]

2的补码:00000010

3的补码 00000011

2&3=00000010 =2

2|3=00000011=3

2^3=00000001

-2^2=-4

-2的原码为:10000010

-2的反码为:11111101

-2的补码:11111110

2的补码 00000010

故-2^2=11111100 的原码是先求出他的反码然后进行取反操作

反码=补码-1:11111011==》原码(符号位不变其他取反):10000100=-4

-1:10000001=》反码=》11111110补码:11111111 +00000001=全是0

func main(){
	
	//位运算的知识演示
	fmt.Println(2&3) //2
	fmt.Println(2|3)//3
	fmt.Println(2^3)//1
	//下面是带有负数的二进制
	fmt.Println(-2^2)//-4

}

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

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

相关文章

Java-Lambda表达式

引入 Lambda表达式是在JAVA 8 中引入的&#xff0c;初衷是进一步简化匿名类的语法&#xff08;匿名类还需要在类中实现函数&#xff09;&#xff0c;并使JAVA走向函数式编程。 语法 (parameters) -> expression 或 (parameters) -> { statements; } 可选类型声明。…

手把手教你安装jdk8

前提 我们口中说的Java8、JDK8、JDK1.8都是一个东西 下载 官方下载链接&#xff1a;&#xff08;非翻墙可访问&#xff09; https://www.oracle.com/java/technologies/javase/jdk18-archive-downloads.html 选择如图链接下载&#xff1a;&#xff08;win11,其他系统版本选择…

【C++】C/C++内存管理-new、delete

文章目录 一、C/C内存分布二、C/C中动态内存管理方式2.1 C语言中动态内存管理方式2.2 C内存管理方式 三、operator new和operator delete函数3.1 operator new和operator delete函数3.2 operator new与operator delete的类专属重载&#xff08;了解&#xff09; 四、new和delet…

elementui table 在浏览器分辨率变化的时候界面异常

异常点&#xff1a; 界面显示不完整&#xff0c;表格卡顿&#xff0c;界面已经刷新完成&#xff0c;但是表格的宽度还在一点一点变化&#xff0c;甚至有无线延伸的情况 思路&#xff1a; 1. 使用doLayout 这里官方文档有说明&#xff0c; 所以我的想法是&#xff0c;监听浏览…

Vue2项目练手——通用后台管理项目第一节

Vue2项目练手——通用后台管理项目 知识补充yarn和npm区别npm的缺点&#xff1a;yarn的优点 npm查看镜像和设置镜像 项目介绍项目的技术栈 项目搭建文件目录 创建路由&#xff0c;引入element-uirouter/index.jsmain.jspages/Users.vuepages/Main.vuepages/Home.vuepages/Login…

vue脚手架的安装并创建项目

在之前的练习中我们都是采用引入jquery、vue文件的形式&#xff0c;很多es6的新特性都是无法使用的&#xff0c;因此现在我们采用脚手架进行安装相关的配置。 1、下载node.js&#xff0c;使用其中内置的npm来下载安装包。 直接在官网中下载长期支持版本即可。点击进入node.js官…

建模杂谈系列234 基于图的程序改造

说明 为了进一步提升程序设计与运维的可靠性&#xff0c;我觉得&#xff08;目前看来&#xff09;只有依赖图的结构。 提升主要包含如下方面&#xff1a; 1 程序结构的简洁性&#xff1a;节点和边2 程序执行的可视化&#xff1a;交通图(红、黄、绿)3 程序支持的逻辑复杂性。…

Multisim软件安装包分享(附安装教程)

目录 一、软件简介 二、软件下载 一、软件简介 Multisim软件是一款电路仿真和设计软件&#xff0c;由美国国家仪器公司&#xff08;National Instruments&#xff09;开发。它提供了一个交互式的图形界面&#xff0c;使用户能够轻松地构建和仿真电路。以下是Multisim软件的详…

什么是devos勒索病毒,中招之后该怎么办?勒索病毒解密,数据恢复

Devos勒索病毒是一种比较常见的勒索病毒病毒&#xff0c;它利用加密技术来锁定用户的文件&#xff0c;并要求支付赎金才能解锁。这种病毒已经引起了全球范围内的关注&#xff0c;也给众多的企业主和个人造成了不可估量的损失。 Devos勒索病毒的起源尚不清楚&#xff0c;但它的攻…

无涯教程-分类算法 - 逻辑回归

逻辑回归是一种监督学习分类算法&#xff0c;用于预测目标变量的概率&#xff0c;目标或因变量的性质是二分法&#xff0c;这意味着将只有两种可能的类。 简而言之&#xff0c;因变量本质上是二进制的&#xff0c;其数据编码为1(代表成功/是)或0(代表失败/否)。 在数学上&…

Linux保存退出和不保存退出命令

Vim编辑器 vim 要编辑的文件输入i进入编辑模式保存退出&#xff1a; 按Esc键退出insert模式&#xff0c;然后输入冒号(:)&#xff0c;输入wq!可以保存并退出. 不保存退出&#xff1a; 按Esc键退出insert模式&#xff0c;然后输入冒号(:)&#xff0c;输入q!可以不保存并退出。…

Autosar存储入门系列03_Autosar中NVM状态机及存储调用逻辑

本文框架 0.前言1. NVM状态机介绍2. NVM读/写基本逻辑2.1 NVM读操作2.2 NVM写操作2.2.1 实时写2.2.2 下电写 2.3 NVM写入注意事项 0.前言 本系列是Autosar存储入门系列&#xff0c;希望能从学习者的角度把存储相关的知识点梳理一遍&#xff0c;这个过程中如果大家觉得有讲得不…

图文并茂:Python Tkinter从入门到高级实战全解析

目录 介绍什么是Tkinter&#xff1f;准备工作第一个Tkinter程序界面布局事件处理补充知识点 文本输入框复选框和单选框列表框弹出对话框 综合案例&#xff1a;待办事项列表总结 介绍 欢迎来到本篇文章&#xff0c;我们将带您深入了解如何在Python中使用Tkinter库来创建图形用…

弯道超车必做好题集锦二(C语言选择题)

前言&#xff1a; 编程想要学的好&#xff0c;刷题少不了&#xff0c;我们不仅要多刷题&#xff0c;还要刷好题&#xff01;为此我开启了一个弯道超车必做好题锦集的系列&#xff0c;每篇大约10题左右。此为第二篇选择题篇&#xff0c;该系列会不定期更新&#xff0c;后续还会…

【网络云盘客户端】——项目简介

项目简介 网络云盘客户端时基于QT/C框架实现了一个网络云盘客户端软件&#xff0c;主要功能包括用户的注册&#xff0c;登录&#xff0c;显示用户的个人文件列表&#xff0c;以及文件的上传&#xff0c;下载&#xff0c;删除&#xff0c;共享文件。 登录界面 主窗口界面 文件…

Postman中参数区别及使用说明

一、Params与Body 二者区别在于请求参数在http协议中位置不一样。Params 它会将参数放入url中以&#xff1f;区分以&拼接Body则是将请求参数放在请求体中 后端接受数据: 二、body中不同格式 2.1 multipart/form-data key - value 格式输入&#xff0c;主要特点是可以上…

Proteus软件安装包分享(附安装教程)

目录 一、软件简介 二、软件下载 一、软件简介 Proteus软件是一款电路设计和仿真的综合性软件&#xff0c;由Labcenter公司开发。它提供了一个交互式的图形界面&#xff0c;用户可以在其中构建电路、仿真结果并实时观察仿真结果。 1、Proteus的历史和演变 Proteus软件最初于…

Matlab图像处理-加法运算

加法运算 图像加法运算的一个应用是将一幅图像的内容叠加到另一幅图像上&#xff0c;生成叠加图像效果&#xff0c;或给图像中每个像素叠加常数改变图像的亮度。 在MATLAB图像处理工具箱中提供的函数imadd()可实现两幅图像的相加或者一幅图像和常量的相加。 程序代码 I1 i…

C++学习记录——이십유 C++11(2)

文章目录 1、类的新功能1、移动构造和移动赋值2、default、delete 2、可变参数模板3、STL容器的emplace 1、类的新功能 1、移动构造和移动赋值 逐成员按字节拷贝就是浅拷贝。一个类中&#xff0c;如果达成默认移动构造的要求&#xff0c;那么传右值就会使用移动构造了&#xf…

022-从零搭建微服务-短信服务(二)

写在最前 如果这个项目让你有所收获&#xff0c;记得 Star 关注哦&#xff0c;这对我是非常不错的鼓励与支持。 源码地址&#xff08;后端&#xff09;&#xff1a;https://gitee.com/csps/mingyue 源码地址&#xff08;前端&#xff09;&#xff1a;https://gitee.com/csps…