golong基础相关操作--一

news2025/1/24 2:10:18

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

package main

//go语言以包作为管理单位,每个文件必须先声明包
//程序必须有一个main包
// 导入包,必须要要使用
// 变量声明了,必须要使用
import (
	"fmt"
)

/*
*
包内部的变量
*/
var aa = 3

var ss = "kkk"

var bb = true

var (
	aaa = 3
	sss = "kkk"
	bbb = true
)

/*
*
定义变量 必须有值
*/
func variableZeroValue() {
	var a int
	var s string
	fmt.Printf("%d %q\n", a, s)
}

/**
变量赋值
*/

func variableInitialValue() {
	var a, b int = 3, 4
	var s string = "abc"
	fmt.Println(a, b, s)
}

func variableTypeDeduction() {
	var a, b, c, s = 3, 4, true, "def"
	fmt.Println(a, b, c, s)
}

func variableShorter() {
	a, b, c, s := 3, 4, true, "def" //自动推到类型,必须初始化,%T打印变量所属的类型
	b = 5
	fmt.Println(a, b, c, s)
}

func test() (a, b, c int) {
	return 1, 2, 3
}

/**
数据类型作用:告诉编译器这个变量应该以多大的内存存储
*/
// 一个文件夹里面只有一个main文件
func main() {
	//fmt.Println("hello world")
	//variableZeroValue()
	//variableInitialValue()
	//variableTypeDeduction()
	//variableShorter()
	//fmt.Println(aa, ss, bb)
	//fmt.Println(aaa, sss, bbb)
	//
	交换2个变量
	//
	//a, b := 10, 20
	//a, b = b, a
	//fmt.Println(a, b)
	//var (
	//	e int
	//	c int
	//	d int
	//)
	匿名变量,丢弃数据不处理,_匿名变量配合函数返回值使用,才有优势
	//e, c, d = test()
	//fmt.Println(e, c, d)
	 常量:程序运行期间,不可以改变的量,常量声明需要const
	//
	//const f int = 10
	//
	f = 20; 常量不允许赋值,不允许修改
	//fmt.Println("f= ", f)
	//
	//const g = 10 //没有使用:= 不允许使用
	//fmt.Println("g= ", g)
	//
	多个变量或常量定义
	var a1 int
	var b1 float64
	
	a1, b1 = 10, 3.14
	//
	//var (
	//	a1 int
	//	b1 float64
	//)
	//a1, b1 = 10, 3.14
	//fmt.Println(a1, b1)
	//
	const i int = 10
	const j float64 = 3.14
	//
	const (
		i int = 10
		j float64 = 3.14
	)
	//
	//const (
	//	i = 10
	//	j = 3.14 // 可以自动推导类型
	//)
	//fmt.Println(i, j)
	//
	 iota常量自动生成器,每个一行,自动累加1
	 iota给常量赋值使用
	//const (
	//	a2 = iota
	//	b2 = iota
	//	c2 = iota
	//)
	//
	//fmt.Printf("a2 = %d, b2 = %d, c2 = %d\n", a2, b2, c2)
	3 iota遇到const,重置为0
	//const d2 = iota
	//fmt.Printf("d2 = %d\n", d2)
	//
	 可以只写一个iota
	//const (
	//	a3 = iota
	//	b3
	//	c3
	//)
	//fmt.Printf("a3 = %d, b3 = %d, c3 = %d\n", a3, b3, c3)
	//
	如果是同一行,值都一样
	//const (
	//	a4         = iota
	//	b4, b5, b6 = iota, iota, iota
	//	c4         = iota
	//)
	//fmt.Printf("a4 = %d, b4 = %d, b5 = %d, b6 = %d, c4 = %d\n", a3, b4, b5, b6, c4)
	//
	/类型分类
	 bool 类型 int8 这里的8代表8位
	//var boolean1 bool
	//boolean1 = true
	//fmt.Println("boolean1 = ", boolean1)
	//
	//var float3 float32
	//float3 = 3.14
	//fmt.Println("float = ", float3)
	//float4 := 3.124
	//fmt.Printf("float4 = %T\n", float4)
	//
	 float64存储小数比float32更准确,15小数点,7为小数点
	//
	字符类型
	//var ch byte //声明字符类型
	//ch = 97
	格式化输出,%d以字符方式打印
	//fmt.Printf("ch = %c, %d\n", ch, ch)
	//
	//ch = 'a' //字符单引号
	//fmt.Printf("ch = %c, %d\n", ch, ch)
	//
	大写转小写,小写转大写
	//str := "mike"
	//
	内建函数,len可以测字符串的长度,有多少个字符 len(str) =  4
	//fmt.Println("len(str) = ", len(str))
	//
	复数类型
	//var t complex128
	//t = 2.1 + 3.14i
	//fmt.Println("t = ", t) //t =  (2.1+3.14i)
	//
	内建函数,取实数和虚数
	//fmt.Println("readl(t)=", real(t), "imag(t)=", imag(t)) //readl(t)= 2.1 imag(t)= 3.14

	//var inta int
	//fmt.Println("请输入变量a: ")
	阻塞等待用户的输入
	//fmt.Scanf("%d", &inta) //或者fmt.Scan(&a)
	//fmt.Println("a = ", inta)

	//类型转换
	var flag bool
	flag = true
	//bool 类型不能转换为int
	//fmt.Printf("flag = %d\n", int(flag)) //%!d(bool=true)
	fmt.Printf("flag = %t\n", flag) //%!d(bool=true)

	// 0就是假 非0就是真
	// 整型也不能转换为bool 这种不能转换的类型,叫不兼容类型
	//flag = 1

	//类型转换,把ch的值取出来后转出int再给t赋值
	var ch byte
	ch = 'a' //字符类型本质上就是整型
	var t int
	t = int(ch)
	fmt.Println("t = ", t)

	// 类型别名 给int64起一个别名叫bigint
	type bigint int64
	var a1 bigint
	fmt.Printf("a1 = %T\n", a1) //a1 = main.bigint

	type (
		long int64
		char byte
	)

	//运算符
	fmt.Println("f>3", 4 > 3)

	//if语句
	s := "王思聪"

	//if和{就是条件,条件通常就是关系运算符
	if s == "王思聪" {
		fmt.Println("左手一个妹子,右手一个校花")
	}

	//if支持1个初始化语句 初始化语句和判断条件以分号分隔
	if a := 10; a == 10 {
		fmt.Println("a==10")
	}

	//多个分支 if else
	s1 := 11

	if s1 == 0 {
		fmt.Println("a==10")
	} else {
		fmt.Println("a!=10")
	}

	//var num int
	//fmt.Printf("请按下楼层:")
	//fmt.Scan(&num)
	//
	//switch num { //switch后面写的是变量本身
	//case 1:
	//	fmt.Println("按下的是1楼\n")
	//	//fallthrough //不跳出switch语句,后面的无条件执行
	//	//break //go语言保留break字,跳出switch语句,不写,默认就包含了
	//case 2:
	//	fmt.Println("按下的是2楼\n")
	//	//fallthrough
	//	//break
	//case 3:
	//	fmt.Println("按下的是3楼\n")
	//	//fallthrough
	//	//break
	//case 4:
	//	fmt.Println("按下的是4楼\n")
	//	//fallthrough
	//	//break
	//default:
	//	fmt.Println("按下的是xxx楼")
	//}

	//score := 85
	//switch {
	//case score > 90:
	//	fmt.Println("优秀")
	//case score > 80:
	//	fmt.Println("优秀")
	//case score > 70:
	//	fmt.Println("优秀")
	//}
	//
	//sum := 0
	for循环使用 1 初始化条件,2 判断是否为真,如果为真,执行循环体,如果为假跳出循环 3 条件变化i++ 4 重复2,3 4
	//for i := 1; i <= 100; i++ {
	//	fmt.Println("i=", i)
	//	sum = sum + i
	//}
	//fmt.Println("sum = ", sum)
	//
	//strr := "abc"
	range 迭代打印每个元素,默认返回2个值 一个是元素的位置,一个是元素本身
	//for i, data := range strr {
	//	fmt.Printf("str[%d] = %c\n", i, data)
	//}
	//
	range 第二个返回值,默认丢弃,返回元素的位置(下标)
	//for i, _ := range strr {
	//	fmt.Printf("str[%d] = %c\n", i, strr[i])
	//}
	//
	//i1 := 0
	//for { //for后面不写任何东西,这个循环条件永远为真,死循环
	//	i1++
	//	time.Sleep(time.Second) //延时1s
	//	if i1 == 5 {
	//		break //跳出循环,如果嵌套多个循环,跳出最近的那个内循环
	//		//continue //跳过本次循环,下一次继续
	//	}
	//	fmt.Println("i= ", i1)
	//}

	//goto可以用在任何地方,但是不能跨函数使用
	fmt.Println("111111111111")

	goto End //goto是关键字,End是用户起的名字,他叫标签

	fmt.Println("222222222222")
End:
	fmt.Println("33333333333333")
}

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

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

相关文章

在CentOS7上使用Docker安装和部署RabbitMQ

&#x1f680; 1 拉取RabbitMQ Docker镜像 首先&#xff0c;使用Docker命令从Docker Hub拉取RabbitMQ官方镜像。打开终端并运行以下命令&#xff1a; docker pull rabbitmq&#x1f680; 2 创建RabbitMQ容器 一旦镜像下载完成&#xff0c;使用以下命令创建RabbitMQ容器&…

SpringBoot整合Websocket(Java websocket怎么使用)

目录 1 Websocket是什么2 Websocket可以做什么3 Springboot整合Websocket3.1 服务端3.2 客户端 1 Websocket是什么 WebSocket 是一种基于 TCP 协议的全双工通信协议&#xff0c;可以在浏览器和服务器之间建立实时、双向的数据通信。可以用于在线聊天、在线游戏、实时数据展示等…

【Stable Diffusion安装】支持python3.11 window版

前言 主要的安装步骤是参考B站播放量第一的视频&#xff0c;但是那位阿婆主应该是没有编程经验&#xff0c;只强调使用3.10&#xff0c;而python最新版本是3.11。 理论上来说&#xff0c;只是一个小版本的不同&#xff0c;应该是可以安装成功了。自己摸索了下&#xff0c;挺费…

springboot使用logback配置彩色日志

springboot使用logback配置彩色日志 前言一、logback文件二、效果 前言 应该有很多同学发现&#xff0c;使用了logback以后&#xff0c;我们的控制台日志都变成灰色了&#xff0c;网络上搜到的logback配置大多数没有进行配色&#xff0c;所以会把springboot的默认配色方案给覆盖…

Unity中Shader的帧缓存区Clear(color+Z+stencil)

文章目录 前言一、什么是帧缓冲区二、片段运算三、随机扫描显示器&#xff08;可以按照自定义路径绘制帧&#xff09;四、光栅扫描显示器&#xff08;从左到右&#xff0c;从上到下&#xff0c;依次绘制&#xff09;五、缓冲的方式&#xff1a;单缓冲 和 双缓冲1、单缓冲2、双缓…

认识JVM的内存模型

从上一节了解到整个JVM大的内存区域&#xff0c;分为线程共享的heap&#xff08;堆&#xff09;&#xff0c;MethodArea&#xff08;方法区&#xff09;&#xff0c;和线程独享的 The pc Register&#xff08;程序计数器&#xff09;、Java Virtual Machine Stacks&#xff08;…

2. postgresql并行扫描(1)——pg强制走并行扫描建表及参数配置

转载自&#xff1a;https://developer.aliyun.com/article/700370 1. 参数设置 1.1 postgresql.conf中修改 # 1、总的可开启的WORKER足够大 max_worker_processes 128# 2、所有会话同时执行并行计算的并行度足够大 max_parallel_workers64# 3、单个QUERY中并行计算NODE开…

测试验证平台

测试验证平台 1.功能说明&#xff1a; 模拟智能终端车端数据采集及上报的功能&#xff0c;提供数据管理平台的模拟和验证功能。 2.系统组成&#xff1a; 系统示意图 功能要求&#xff1a; 本地电脑实现Imx6配置功能&#xff0c;能够通过运行不同的脚本&#xff0c;模拟不…

C语言记录程序日志

我们写程序&#xff0c;不可能一次就写的一个bug都没有&#xff0c;必须要不停地修改&#xff0c;有可能自己调试已经没有问题了&#xff0c;发给客户后还是问题很多&#xff0c;这个时候跑到客户处解决问题就不现实了&#xff0c;自己不在还要找到问题的所在&#xff0c;最好的…

质谱技术对蛋白质进行鉴定

参考B站教学视频: 质谱如何鉴定蛋白质_哔哩哔哩_bilibili 针对该视频&#xff0c;别人的 笔记 质谱是一台体重秤&#xff0c;称的不是人&#xff0c;而是分子、原子的体重 不同分子有不同分子量是质谱仪工作的底层逻辑 图片来自&#xff1a;【蛋白组】蛋白质组定量技术的原理和…

如何设计一个好的游戏剧情(Part 1:主题的设定)

提醒&#xff1a;此教程仅仅为作者的一些经验和感悟&#xff0c;非专业教程&#xff0c;若介意请前往网上搜集或者书本查阅相关资料&#xff01; 前言&#xff1a;游戏为什么要有剧情——游戏剧情的重要性 游戏剧情的重要性难以低估。一个精彩的剧情可以让玩家感受到强烈的情感…

ZigBee案例笔记 -- RFID卡片读写(模拟饭卡)

RFID模拟饭卡应用 RFID&#xff08;射频识别技术&#xff09;RFID通讯协议RFID发展历史RFID操作流程说明RFID卡片读写流程RFID寻卡RFID防碰撞RFID选卡RFID卡密验证RFID读卡RFID写卡读写数据流程 RFID饭卡模拟案例驱动代码串口协议饭卡操作案例结果优化建议 RFID&#xff08;射频…

QUdpSocket Class

继承自 QAbstractSocket 类 QUdpSocket类提供UDP套接字。 UDP(用户数据报协议)是一种轻量级、不可靠、面向数据报、无连接的协议。它可以在可靠性不重要的情况下使用。QUdpSocket是QAbstractSocket的一个子类&#xff0c;它允许您发送和接收UDP数据报。 使用这个类最常见的方法…

Laravel 模型1对1关联 1对多关联 多对多关联 ⑩①

作者 : SYFStrive 博客首页 : HomePage &#x1f4dc;&#xff1a; THINK PHP &#x1f4cc;&#xff1a;个人社区&#xff08;欢迎大佬们加入&#xff09; &#x1f449;&#xff1a;社区链接&#x1f517; &#x1f4cc;&#xff1a;觉得文章不错可以点点关注 &#x1f44…

说说CDN和负载均衡具体是怎么实现的

分析&回答 什么是 CDN CDN (全称 Content Delivery Network)&#xff0c;即内容分发网络。 构建在现有网络基础之上的智能虚拟网络&#xff0c;依靠部署在各地的边缘服务器&#xff0c;通过中心平台的负载均衡、内容分发、调度等功能模块&#xff0c;使用户就近获取所需…

如何让你的jupyter notebook 排版得像Word(Markdown和网页文件写法)

案例背景 很多时候我们在jupyter notebook里面的写代码&#xff0c;画图&#xff0c;但是文字分析什么的写在里面纯文本不好看&#xff0c;需要进行排版&#xff0c;那么就得用markdown的写法&#xff0c;如何还想居中或者更花里胡哨的字体&#xff0c;那就得要网页文件的一些…

【MATLAB第70期】基于MATLAB的LightGbm(LGBM)梯度增强决策树多输入单输出回归预测及多分类预测模型(全网首发)

【MATLAB第70期】基于MATLAB的LightGbm(LGBM)梯度增强决策树多输入单输出回归预测及多分类预测模型&#xff08;全网首发&#xff09; 一、学习资料 (LGBM)是一种基于梯度增强决策树(GBDT)算法。 本次研究三个内容&#xff0c;分别是回归预测&#xff0c;二分类预测和多分类预…

终端安全与端点保护:讨论保护终端设备免受恶意软件、恶意链接和其他威胁的方法,包括终端保护工具和实践

第一章&#xff1a;引言 在当今数字化世界中&#xff0c;终端设备如电脑、手机和平板成为我们生活与工作的不可或缺的一部分。然而&#xff0c;随着技术的进步&#xff0c;恶意软件、网络攻击和数据泄露等威胁也不断增加&#xff0c;对终端设备的安全提出了更高的要求。本文将…

面试官:说一下 MyBatis 的一级缓存和二级缓存 ?

目录 1. MyBatis 的缓存机制 2. 为什么不默认开启 MyBatis 的二级缓存 3. MyBatis 如何开启二级缓存 1. MyBatis 的缓存机制 MyBayis 中包含两级缓存&#xff1a;一级缓存和二级缓存 1. 一级缓存是 SqlSession 级别的&#xff0c;是 MyBatis 自带的缓存功能&#xff0c;默认…

用正则清除标记符号

定义方法 clearHtml(str){return str.replace(/<[^>]>/g,) }