Golang基础-5
Go语言基础
介绍
基础
介绍
- 本文介绍Go语言中切片(slice)(切片声明、切片初始化、切片基础操作、多维切片)等相关知识。
基础
切片
- 切片(slice)是对数组的一个连续片段的引用,切片是一个引用类型。
- 切片是长度可变的数组,由三部分组成:
- 指针:指向的数组元素的地址
- 长度:元素的数量
- 容量:切片可容纳多少元素
切片声明
- 需要指定组成元素的类型,不需要指定存储元素的个数。
- 声明后,默认初始化为 nil,意思是不存在此切片引用。
package mainimport "fmt"func main() {// 声明一个切片var slice1 []intfmt.Printf("slice1 type: %T, value: %v\n", slice1, slice1)// 自动类型推导slice2 := []int{}fmt.Printf("slice2 type: %T, value: %v\n", slice2, slice2)
}
输出结果
slice1 type: []int, value: []
slice2 type: []int, value: []
切片初始化
- 切片初始化方式较多,具体如下
package mainimport "fmt"func main() {// 字面量初始化var slice1 []int = []int{1, 2, 3, 4, 5}fmt.Println("slice1: ", slice1, ", cap: ", cap(slice1))// 字面量初始化空切片var slice2 []int = []int{}fmt.Println("slice2: ", slice2, ", cap: ", cap(slice2))// 从数组创建并初始化切片var arr [5]int = [5]int{1, 2, 3, 4, 5}slice3 := arr[0:3]fmt.Println("slice3: ", slice3, ", cap: ", cap(slice3))slice4 := arr[0:2:2]fmt.Println("slice4: ", slice4, ", cap: ", cap(slice4))// 从切片创建并初始化切片slice5 := slice4[:1]fmt.Println("slice5: ", slice5, ", cap: ", cap(slice5))slice6 := slice4[1:]fmt.Println("slice6: ", slice6, ", cap: ", cap(slice6))slice7 := slice4[:]fmt.Println("slice7: ", slice7, ", cap: ", cap(slice7))slice8 := slice4[0:0]fmt.Println("slice8: ", slice8, ", cap: ", cap(slice8))// 指定长度和容量字面量初始化slice9 := []int{0: 20, 4: 60}fmt.Println("slice9: ", slice9, ", cap: ", cap(slice9))// 使用 make 函数初始化slice10 := make([]int, 3)fmt.Println("slice10: ", slice10, ", cap: ", cap(slice10))slice11 := make([]int, 3, 6)fmt.Println("slice11: ", slice11, ", cap: ", cap(slice11))
}
输出结果
slice1: [1 2 3 4 5] , cap: 5
slice2: [] , cap: 0
slice3: [1 2 3] , cap: 5
slice4: [1 2] , cap: 2
slice5: [1] , cap: 2
slice6: [2] , cap: 1
slice7: [1 2] , cap: 2
slice8: [] , cap: 2
slice9: [20 0 0 0 60] , cap: 5
slice10: [0 0 0] , cap: 3
slice11: [0 0 0] , cap: 6
切片基础操作
- 获取切片长度和容量
package mainimport "fmt"func main() {var slice1 []int = []int{1, 2, 3, 4, 5}fmt.Printf("slice1 len: %v, cap: %v\n", len(slice1), cap(slice1))
}
输出结果
slice1 len: 5, cap: 5
- 切片的访问和修改(通过索引对切片元素进行访问和修改,元素的索引从左到右依次为:0 ~ n(n为切片长度-1))
- 切片共享底层数组,任何变化都会导致其它切片及底层共享数组变化
package mainimport "fmt"func main() {// 以数组方式创建切片var arr [5]int = [5]int{1, 2, 3, 4, 5}fmt.Printf("arr : %v\n", arr)var slice1 []int = arr[0:3]fmt.Printf("slice1 : %v\n", slice1)// 索引方式访问fmt.Printf("slice1[0] : %v\n", slice1[0])fmt.Printf("slice1[1] : %v\n", slice1[1])fmt.Printf("slice1[2] : %v\n", slice1[2])// 修改值slice1[0] = 100slice1[2] = 200fmt.Printf("slice1 : %v\n", slice1)fmt.Printf("arr : %v\n", arr)// 切片创建新切片slice2 := slice1[:] fmt.Printf("slice2 : %v\n", slice2)slice2[0] = 150slice2[1] = 230fmt.Printf("slice2 : %v\n", slice2)fmt.Printf("slice1 : %v\n", slice1)fmt.Printf("arr : %v\n", arr)
}
输出结果
arr : [1 2 3 4 5]
slice1 : [1 2 3]
slice1[0] : 1
slice1[1] : 2
slice1[2] : 3
slice1 : [100 2 200]
arr : [100 2 200 4 5]
slice2 : [100 2 200]
slice2 : [150 230 200]
slice1 : [150 230 200]
arr : [150 230 200 4 5]
- 切片遍历
package mainimport "fmt"func main() {var arr [5]int = [5]int{1, 2, 3, 4, 5}fmt.Printf("arr : %v\n", arr)var slice1 []int = arr[0:3]fmt.Printf("slice1 : %v\n", slice1)// for 循环方式遍历for i := 0; i < len(slice1); i++ {fmt.Println("slice1[", i, "] = ", slice1[i])}fmt.Println("======================")// for-range 方式遍历for i, v := range slice1 {fmt.Println("slice1[", i, "] = ", v)}
}
输出结果
arr : [1 2 3 4 5]
slice1 : [1 2 3]
slice1[ 0 ] = 1
slice1[ 1 ] = 2
slice1[ 2 ] = 3
======================
slice1[ 0 ] = 1
slice1[ 1 ] = 2
slice1[ 2 ] = 3
- 增加元素,内建函数 append 可以为切片动态添加元素
- 使用 append 对切片增加元素并返回修改后切片
- 当长度len在容量cap范围内时只增加长度,容量和底层数组不变;当长度len超过容量cap范围则会新创建底层数组并对容量进行扩容
- 元素数量小于 1024 时,约按原容量 1 倍增加,元素数量大于 1024 时约按原容量 0.5 倍增加(不同Go版本可能有变化,当前使用Go1.22)
- 切片头部增加元素会导致切片整体复制操作,效率没有末尾增加元素高
package mainimport "fmt"func main() {var arr [5]int = [5]int{1, 2, 3, 4, 5}fmt.Printf("arr : %v\n", arr)var slice1 []int = arr[0:3]fmt.Printf("slice1 : %v, len: %v, cap: %v\n", slice1, len(slice1), cap(slice1))// 增加元素,末尾增加slice1 = append(slice1, 100, 200, 300)fmt.Printf("slice1 append: %v, len: %v, cap: %v\n", slice1, len(slice1), cap(slice1))// 增加元素,末尾增加slice1 = append(slice1, 1, 2, 3, 4, 5, 6, 7, 8)fmt.Printf("slice1 append: %v, len: %v, cap: %v\n", slice1, len(slice1), cap(slice1))slice2 := []int{0: 100, 1023: 100}fmt.Printf("slice2 len: %v, cap: %v\n", len(slice2), cap(slice2))// 增加超过 1024 个元素,末尾增加slice2 = append(slice2, 1, 2, 3, 4, 5)fmt.Printf("slice2 len: %v, cap: %v\n", len(slice2), cap(slice2))
}
输出结果
arr : [1 2 3 4 5]
slice1 : [1 2 3], len: 3, cap: 5
slice1 append: [1 2 3 100 200 300], len: 6, cap: 10
slice1 append: [1 2 3 100 200 300 1 2 3 4 5 6 7 8], len: 14, cap: 20
slice2 len: 1024, cap: 1024
slice2 len: 1029, cap: 1536
- 切片复制,使用 copy 函数,复制元素数量为 src 元素数量和 dest 元素数量的最小值
package mainimport "fmt"func main() {var slice1 []int = []int{1, 2, 3}var slice2 []int = []int{100, 200, 300, 400, 500}var slice3 []int = []int{1}// copy slice2的3个元素替换到slice1元素copy(slice1, slice2)fmt.Printf("%v, %v, %v\n", slice1, slice2, slice3)// copy slice3的1个元素替换到slice2的第一个元素copy(slice2, slice3)fmt.Printf("%v, %v, %v\n", slice1, slice2, slice3)// copy slice1的1个元素替换到slice3的第一个元素copy(slice3, slice1)fmt.Printf("%v, %v, %v\n", slice1, slice2, slice3)
}
输出结果
[100 200 300], [100 200 300 400 500], [1]
[100 200 300], [1 200 300 400 500], [1]
[100 200 300], [1 200 300 400 500], [100]
- 删除元素,清空切片
package mainimport "fmt"func main() {var slice1 []int = []int{1, 2, 3}// 清空切片slice1 = slice1[0:0]fmt.Println("slice1 clear: ", slice1)slice1 = append(slice1, 1, 2, 3, 4, 5, 6)fmt.Println("slice1 append: ", slice1)// 清空切片slice1 = nilfmt.Println("slice1 clear: ", slice1)slice1 = append(slice1, 1, 2, 3, 4, 5, 6)fmt.Println("slice1 append: ", slice1)// 删除切片,删除第一个元素slice1 = slice1[1:]fmt.Println(slice1)// 增加第一个元素(将上一步删除的元素重新添加到原来位置)slice1 = append([]int{1}, slice1...)fmt.Println("slice1 append: ", slice1)// 删除切片,删除末尾元素slice1 = slice1[:len(slice1)-1]fmt.Println(slice1)// 增加末尾的元素slice1 = append(slice1, 6)fmt.Println("slice1 append: ", slice1)// 删除第三个元素slice3 := []int{}slice3 = append(slice3, slice1[0:2]...)slice3 = append(slice3, slice1[3:]...)slice1 = slice3fmt.Println("slice3: ", slice1)
}
输出结果
slice1 clear: []
slice1 append: [1 2 3 4 5 6]
slice1 clear: []
slice1 append: [1 2 3 4 5 6]
[2 3 4 5 6]
slice1 append: [1 2 3 4 5 6]
[1 2 3 4 5]
slice1 append: [1 2 3 4 5 6]
slice3: [1 2 4 5 6]
多维切片
- 多维切片即切片的元素也可以是切片类型
package mainimport "fmt"func main() {// 二维切片声明且初始化var slice1 [][]int = [][]int{{1, 2, 3}, {4, 5, 66}}fmt.Println("slice1: ", slice1)// 自动类型推导slice2 := [][]int{{1, 2, 3}, {4, 55, 6}}fmt.Println("slice2: ", slice2)// make创建切片slice3 := make([][]int, 2)fmt.Println("slice3: ", slice3)slice4 := make([][]int, 2, 5)fmt.Println("slice4: ", slice4)// 修改与访问slice2[0] = []int{100, 200, 300, 400}slice2[0][2] = 30fmt.Println("slice2: ", slice2)// 切片创建切片fmt.Println("slice3: ", slice2[0:1])// 切片遍历,for 循环for i := 0; i < len(slice2); i++ {for j := 0; j < len(slice2[i]); j++ {fmt.Printf("slice2[%v][%v] = %v\t", i, j, slice2[i][j])}fmt.Println()}// 切片遍历,for-rangefor i, s := range slice2 {for j, v := range s {fmt.Printf("slice2[%v][%v] = %v\t", i, j, v)}fmt.Println()}// 增加元素slice1 = append(slice1, []int{10, 20, 30, 40})fmt.Println("slice1 append: ", slice1)slice1[0] = append(slice1[0], 10, 20, 30, 40)fmt.Println("slice1 append: ", slice1)// 复制元素,src 数量少于 dst 数量时,将 src 对应行替换到 dst对应行,dst 多出行继续显示// src 数量大于 dst 数量时,以 dst 数量为准,将 src 对应行替换到 dst对应行fmt.Println("slice1 copy before: ", slice1)fmt.Println("slice2 copy before: ", slice2)copy(slice1, slice2)fmt.Println("slice1 copy: ", slice1)
}
输出结果
slice1: [[1 2 3] [4 5 66]]
slice2: [[1 2 3] [4 55 6]]
slice3: [[] []]
slice4: [[] []]
slice2: [[100 200 30 400] [4 55 6]]
slice3: [[100 200 30 400]]
slice2[0][0] = 100 slice2[0][1] = 200 slice2[0][2] = > 30 slice2[0][3] = 400
slice2[1][0] = 4 slice2[1][1] = 55 slice2[1][2] = 6
slice2[0][0] = 100 slice2[0][1] = 200 slice2[0][2] = > 30 slice2[0][3] = 400
slice2[1][0] = 4 slice2[1][1] = 55 slice2[1][2] = 6
slice1 append: [[1 2 3] [4 5 66] [10 20 30 40]]
slice1 append: [[1 2 3 10 20 30 40] [4 5 66] [10 20 30 40]]
slice1 copy before: [[1 2 3 10 20 30 40] [4 5 66] [10 20 30 40]]
slice2 copy before: [[100 200 30 400] [4 55 6]]
slice1 copy: [[100 200 30 400] [4 55 6] [10 20 30 40]]
起始
相关文章:
Golang基础-5
Go语言基础 介绍 基础 切片 切片声明 切片初始化 切片基础操作 多维切片 介绍 本文介绍Go语言中切片(slice)(切片声明、切片初始化、切片基础操作、多维切片)等相关知识。 基础 切片 切片(slice)是对数组的一个连续片段的引用,切…...
Mysql数据库:故障分析与配置优化
目录 前言 一、Mysql逻辑架构图 二、Mysql单实例常见故障 1、无法通过套接字连接到本地MySQL服务器 2、用户rootlocalhost访问被拒绝 3、远程连接数据库时连接很慢 4、无法打开以MYI结尾的索引文件 5、超出最大连接错误数量限制 6、连接过多 7、配置文件/etc/my.cnf权…...
常见的图像分析算法
图像分析算法是计算机视觉领域中的一个重要分支,它通过使用预先训练的人工智能模型从图像中提取和分析视觉信息。这些算法可以应用于多种场景,如物体识别、图像分类、图像增强、缺陷检测等。北京木奇移动技术有限公司,专业的软件外包开发公司…...
朵米3.5客服系统源码,附带系统搭建教程
朵米客服系统是一款全功能的客户服务解决方案,提供多渠道支持(如在线聊天、邮件、电话等),帮助企业建立与客户的实时互动。该系统具有智能分流功能,可以快速将客户请求分配给适当的客服人员,提高工作效率。…...
Python 踩坑记
前言 回归 Python 栈,相较 Go 的 Coding,Python 确实偏向复杂,看似编码方便快捷的背后,是越来越庞杂的细枝末节,稍不注意就是偏差。如果项目只是“能跑就行”,那大概率遍地是坑。开启踩坑记~ …...
搭建Spark单机版环境
在搭建Spark单机版环境的实战中,首先确保已经安装并配置好了JDK。然后,从群共享下载Spark安装包,并将其上传至目标主机的/opt目录。接着,解压Spark安装包至/usr/local目录,并配置Spark的环境变量,以确保系统…...
使用Flutter混淆技术保护应用隐私与数据安全
在移动应用开发中,保护应用代码安全至关重要。Flutter 提供了简单易用的混淆工具,帮助开发者在构建 release 版本应用时有效保护代码。本文将介绍如何在 Flutter 应用中使用混淆,并提供了相关的操作步骤和注意事项。 📝 摘要 本…...
ClickHouse初体验
1.clickHouse是啥? ClickHouse 是俄罗斯的 Yandex 于 2016 年开源的列式存储数据库(DBMS),使用 C语言编写,主要用于在线分析处理查询(OLAP),能够使用SQL查询实时生成分析数据报告 2.clickHouse的特点 2.1列式存储 对于列的聚合&…...
在k8s中部署高可用程序实践和资源治理
在k8s中部署高可用程序实践 1. 多副本部署1.1. 副本数量1.2. 更新策略1.3. 跨节点的统一副本分布1.4. 优先级1.5. 停止容器中的进程1.6. 预留资源 2. 探针2.1. 活性探针(liveness probes)2.2. 就绪探针(Readiness probe)2.3. 启动…...
WebView的使用与后退键处理-嵌入小程序或者 H5 页面
在使用 WebView 嵌入小程序或者 H5 页面时,通常会涉及到处理后退键的操作。在 Android 平台上,可以通过 WebView 的相关方法来实现后退键的处理。你可以按照以下步骤来实现: 在 Activity 或 Fragment 中找到 WebView 控件,并为其…...
【攻防世界】file_include (PHP伪协议+过滤器)
打开题目环境: 进行PHP代码审计,发现这是一个文件包含漏洞。 我们尝试利用PHP伪协议中的 php://filter来读取 check.php 中的内容。 构造payload 并提交: 发现payload被过滤掉了,我们就需要尝试使用不同的转换器。 PHP各类转换…...
Linux 内核中PHY子系统(网络):PHY驱动
一. 简介 PHY 子系统就是用于 PHY 设备相关内容的,分为 PHY 设备和 PHY 驱动,和 platform 总线一样,PHY 子系统也是一个设备、总线和驱动模型。 前面一篇文章学习了 PHY子系统中的 PHY设备。文章如下: Linux 内核中PHY子系统(网…...
【六 (1)机器学习-机器学习算法简介】
目录 文章导航一、机器学习二、基于学习方式的分类三、监督学习常见类型四、无监督学习常见类型五、强化学习常见分类 文章导航 【一 简明数据分析进阶路径介绍(文章导航)】 一、机器学习 机器学习是一门多领域交叉学科,涉及概率论、统计学…...
TCP服务端主动向客户端发送数据
C TCP 服务端和客户端通信的例子 在此基础上,要修改服务端代码,使其能够每秒向客户端发送当前时间,你需要添加一个循环,每次循环发送当前时间给客户端。同时,你需要在客户端代码中添加接收服务端发送的数据的逻辑。 …...
ObjectiveC-03-XCode的使用和基础数据类型
本节做为Objective-C的入门课程,笔者会从零基础开始介绍这种程序设计语言的各个方面。 术语 ObjeC:Objective-C的简称,因为完整的名称过长,后续会经缩写来代替;项目/工程:也称工程,指的是一个A…...
YOLOv9改进策略 :主干优化 | 无需TokenMixer也能达成SOTA性能的极简ViT架构 | CVPR2023 RIFormer
💡💡💡本文改进内容: token mixer被验证能够大幅度提升性能,但典型的token mixer为自注意力机制,推理耗时长,计算代价大,而RIFormers是无需TokenMixer也能达成SOTA性能的极简ViT架构 ,在保证性能的同时足够轻量化。 💡💡💡RIFormerBlock引入到YOLOv9,多个数…...
원클릭으로 주류 전자상거래 플랫폼 상품 상세 데이터 수집 및 접속 시연 예제 (한국어판)
클릭 한 번으로 전자상거래 플랫폼 데이터를 캡처하는 것은 일반적으로 웹 페이지에서 정보를 자동으로 추출 할 수있는 네트워크 파충류 기술과 관련됩니다.그러나 모든 형태의 데이터 수집은 해당 웹 사이트의 사용 약관 및 개인 정보 보호 정책 및 현지 법률 및 규정을 준수…...
2024年github开源top100中文
2024年github开源top100中文 动动美丽的小指头点个赞呗,感谢啦!💕💕💕😘😘😘 本文由Butterfly一键发布工具发布 语言star项目名称描述Python45670xai-org/grok-1Grok开源发布Ruby260…...
回收站删除的文件在哪里?专业恢复方法分享(最新版)
“我很想知道我从回收站删除的文件被保存在哪里了呢?我刚刚不小心清空了回收站,现在想将它们恢复,应该怎么操作呢?谁能教教我怎么从回收站恢复文件?” 回收站,作为Windows操作系统中的一个重要组件…...
什么是工时管理软件?
简而言之,工时管理软件是一种可以帮助管理者跟踪企业员工在项目和任务上花费的时间的软件。然而,工时管理软件不仅是一种收集信息的工具,它还是一种解决方案,使企业能够处理和优化不同的流程和活动,例如工资单、项目预…...
一文解析智慧城市,人工智能技术将成“智”理主要手段
长期以来,有关智慧城市的讨论主要围绕在技术进步方面,如自动化、人工智能、数据的公开以及将更多的传感器嵌入城市以使其更加智能化。实际上,智慧城市是一个关于未来的设想,其重要原因在于城市中存在各种基础设施、政治、地理、财…...
SQLBolt,一个练习SQL的宝藏网站
知乎上有人问学SQL有什么好的网站,这可太多了。 我之前学习SQL买了本SQL学习指南,把语法从头到尾看了个遍,但仅仅是心里有数的程度,后来进公司大量的写代码跑数,才算真真摸透了SQL,知道怎么调优才能最大化…...
TikTok防关联引流系统:全球多账号运营的终极解决方案
tiktok防关联引流系统介绍,tiktok防关联系统是基于tiktok生态研发的效率工具,帮你快速实现tiktok全球多账号运营,系统配备了性能强劲的安卓,防关联智能终端,可一建创建全球多国手机环境,完美满足各类app软件…...
卷积神经网络(CNN)的数学原理解析
文章目录 前言 1、介绍 2、数字图像的数据结构 3、卷积 4、Valid 和 Same 卷积 5、步幅卷积 6、过渡到三维 7、卷积层 8、连接剪枝和参数共享 9、卷积反向传播 10、池化层 11、池化层反向传播 前言 本篇主要分享卷积神经网络(CNN)的数学原理解析…...
2024年华为OD机试真题-亲子游戏-Java-OD统一考试(C卷)
题目描述: 宝宝和妈妈参加亲子游戏,在一个二维矩阵(N*N)的格子地图上,宝宝和妈妈抽签决定各自的位置,地图上每个格子有不同的糖果数量,部分格子有障碍物。 游戏规则是妈妈必须在最短的时间(每个单位时间只能走一步)到达宝宝的位置,路上的所有糖果都可以拿走,不能走障…...
大模型显存占用分析
kvcache显存占用分析 假设序列输入长度:s,输出长度:n,数据类型以FP16来保存KV cache。 峰值显存占用:b(sn)hl2*24blh(sn) 注:b表示batch size,第一个2表示k/v cache,第二个2表示FP1…...
matlab中旋转矩阵函数
文章目录 matlab里的旋转矩阵、四元数、欧拉角四元数根据两向量计算向量之间的旋转矩阵和四元数欧拉角转旋转矩阵旋转矩阵转欧拉角旋转矩阵转四元数参考链接 matlab里的旋转矩阵、四元数、欧拉角 旋转矩阵dcmR四元数quatq[q0,q1,q2,q3]欧拉角angle[row,pitch,yaw] % 旋转矩阵…...
探讨Spring Boot的自动配置原理
Spring Boot以其简化Spring应用开发和部署的能力而广受欢迎。其中最引人注目的特性之一就是自动配置,它极大地减少了开发者需要手动编写的配置量。在本篇博客中,我们将深入探讨Spring Boot自动配置的工作原理,以及它是如何使得Spring应用的配…...
【LeetCode】热题100 刷题笔记
文章目录 T1 两数之和T49 字母异位词分组常用小技巧 T1 两数之和 链接:1. 两数之和 题目: 【刷题感悟】这道题用两层for循环也能做出来,但我们还是要挑战一下时间复杂度小于 O ( n 2 ) O(n^2) O(n2)的解法,不能因为它是第一道 …...
基于springboot+vue+Mysql的火车订票管理系统
开发语言:Java框架:springbootJDK版本:JDK1.8服务器:tomcat7数据库:mysql 5.7(一定要5.7版本)数据库工具:Navicat11开发软件:eclipse/myeclipse/ideaMaven包:…...
如何管理企业网站/个人网上卖货的平台
先说一下这两个命令的用法格式:--起一个名字为A的savepoion savepoint A(这个A是savepoint的名字) --跳转到savepoint A处 rollback to A一旦执行了rollback那么savepoint的操作都将撤消,当然最后一定执行一次commit,否则所有的操作都是在缓存…...
什么网站可以接单做海报/html网页设计模板
php用curl抓取网页问题封装了一个curl抓取网页的函数,在本地测没问题;放到测试服务器上后,如果通过浏览器访问执行,大部分时候函数返回的HTTP状态码返回0,错误信息Error:name lookup timedout,极其偶像的情况下返回200…...
邯郸网站建设的地方/新手如何学seo
1、类SQL PLUS窗口:File->New->Command Window,这个类似于oracle的客户端工具sql plus,但比它好用多了。2、设置关键字自动大写:Tools->Preferences->Editor,将Keyword case选择Uppercase。这样在窗口中输入sql语句时,…...
昆明网站排名优化公司/廊坊seo关键词优化
6.引用 1.什么是引用? 引用不是新定义一个变量,而是给已存在变量取了一个别名,编译器不会为引用变量开辟内存空间,它和它引用的变量共用同一块内存空间。 **类型& 引用变量名(对象名) 引用实体;**void TestRef(…...
如何向谷歌提交网站/网络推广方案范文
if结构 多重if结构:if-else语句 嵌套if结构:if中嵌套if结构 switch结构 注意case后的冒号!!! break如果没有,就会在当前的case后一直顺序运行,知道default switch表达式中计算结果可以是&…...
服装网站建设进度及实施过程/产品seo怎么优化
浮点数的表示和精度如果a>0,那么1a一定大于1吗?在数学上,答案是肯定的。但在计算机上,答案就与a的大小和浮点数的精度有关了。在matalb上,可以作以下计算:>> a1/2^52a 2.220446049250313e-016>…...