1.字符串的组成?
Golang的字符串都是由单个字节连接起来的,每个字节都是UTF8编码标识的Unicode文本。(不需要在考虑中文不兼容问题)

2.如何遍历字符串?
先看一个例子:

package main

import (
"fmt"
) func main() {
var str = "123"
for i := 0; i < len(str); i++ {
fmt.Println(str[i])
}
}

  

输出:

49
50
51

和想象中不太一样,接着看下面。

遍历有两种方式:

  • for i:=0;i<len;i++{}
  • for k,v:=range string {}

区别在于第一种遍历的事ASCII字符,第二种是Unicode字符,当遇到汉字的时候第一种就会乱码了。这也就解释了前文为啥不是输出123了,需要格式化ASCII码才是我们想看到的。

第一种

package main

import (
"fmt"
) func main() {
var str = "123世界!"
for i := 0; i < len(str); i++ {
fmt.Printf("%c\n", str[i])
}
}

  

输出:

1
2
3
ä
¸
–
ç
•
Œ
ï
¼

这里乱码原因需要解释下:
在遍历的时候,ASCII字符只需要一个字节,而非ASCII 字符的可能需要2或者3、4个字节不固定,所以碰到非ASCII 字符的用str[i]来获取一个字节,获取的不全,肯定就乱码了。

有什么办法解决乱码呢?
那就是转为rune类型的切片就好了

package main

import (
"fmt"
) func main() {
var str = "123世界!"
strRune := []rune(str)
for _, v := range strRune {
fmt.Printf("%c\n", v)
}
}

  输出:

1
2
3


因为在Golang中字符类型实际存储使用rune的。

第二种 range

package main

import (
"fmt"
) func main() {
var str = "123世界!"
for _, v := range str {
fmt.Printf("%c\n", v)
}
} 

 输出:

1
2
3


3.如何将字符串与整型互转?
转换 表达

import "strconv"
Atoi : i, err := strconv.Atoi("8888")
Itoa: s := strconv.Itoa(333)
Format xxx 转成string字符串
  • FormatBool: func FormatBool(b bool) string
  • FormatFloat: func FormatFloat(f float64, fmt byte, prec, bitSize int) string
  • FormatInt: func FormatInt(i int64, base int) string
  • FormatUint: func FormatUint(i uint64, base int) string

FormatInt()和FormatUint()有两个参数:第二个参数base指定将第一个参数转换为多少进制,有效值为2<=base<=36。当指定的进制位大于10的时候,超出10的数值以a-z字母表示。例如16进制时,10-15的数字分别使用a-f表示,17进制时,10-16的数值分别使用a-g表示。

例如:FormatInt(-42, 16)表示将-42转换为16进制数,转换的结果为-2a。

FormatFloat()参数众多:

bitSize表示f的来源类型(32:float32、64:float64),会据此进行舍入。

fmt表示格式:'f'(-ddd.dddd)、'b'(-ddddp±ddd,指数为二进制)、'e'(-d.dddde±dd,十进制指数)、'E'(-d.ddddE±dd,十进制指数)、'g'(指数很大时用'e'格式,否则'f'格式)、'G'(指数很大时用'E'格式,否则'f'格式)。

prec控制精度(排除指数部分):对'f'、'e'、'E',它表示小数点后的数字个数;对'g'、'G',它控制总的数字个数。如果prec 为-1,则代表使用最少数量的、但又必需的数字来表示f。

eg:

s := strconv.FormatBool(true)
s := strconv.FormatFloat(3.1415, 'E', -1, 64)
s := strconv.FormatInt(-42, 16)
s := strconv.FormatUint(42, 16) Parse类函数用于转换字符串为给定类型的值:ParseBool()、ParseFloat()、ParseInt()、ParseUint()。
eg:
b, err := strconv.ParseBool("true")
f, err := strconv.ParseFloat("3.1415", 64)
i, err := strconv.ParseInt("-42", 10, 64)
u, err := strconv.ParseUint("42", 10, 64)
 

 

package main

import (
"fmt"
"strconv"
) func main() {
var str = "123世界!"
for _, v := range str {
fmt.Printf("%c\n", v)
} s := strconv.FormatBool(true)
fmt.Println(s)
s = strconv.FormatFloat(3.1415, 'E', -1, 64)
fmt.Println(s)
s = strconv.FormatInt(-42, 16)
fmt.Println(s)
s = strconv.FormatUint(42, 8)
fmt.Println(s)
}

  输出:

1
2
3



true
3.1415E+00
-2a
52

  

4.如何改变其中某个字符?
根据前文我们知道字符有两种,一种是ASCII,一种是Unicode。
所以需要根据不同的字节数来替换。

package main

import (
"fmt"
) func main() {
var str = "123世界!"
for _, v := range str {
fmt.Printf("%c\n", v)
} bytes := []byte(str)
bytes[1] = 'a'
str = string(bytes)
fmt.Println(str)
}

输出:

1
2
3



1a3世界!

  

如果是想兼容汉字那么使用rune:

package main

import (
"fmt"
) func main() {
var str = "123世界!"
for _, v := range str {
fmt.Printf("%c\n", v)
}
runes := []rune(str)
runes[4] = 'a'
str = string(runes)
fmt.Println(str)
}

  

输出:

1
2
3



123世a!

  

5.如何截取字符串?
substr := str[n:m] 左开右闭

6.如何计算长度?

若全为ASCII字符,则len(str)。
若存在非ASCII的Unicode字符,则utf8.RuneCountInString(str)。

package main

import (
"fmt"
"unicode/utf8"
) func main() {
var str = "123世界!"
fmt.Println(utf8.RuneCountInString(str))
}

  输出:

6

7.如何连接字符串?
提供三种方式:

第一种(最简单):使用+

package main

import (
"fmt"
) func main() { str1 := "123"
str2 := "世界!"
fmt.Println(str1 + str2) }

输出:

123世界!

第二种(最高效):使用字节拼接

package main

import (
"bytes"
"fmt"
) func main() { str1 := "123"
str2 := "世界!"
var buf bytes.Buffer
buf.WriteString(str1)
buf.WriteString(str2)
fmt.Println(buf.String()) }

输出:

123世界!

第三种:使用系统包

package main

import (
"fmt"
"strings"
) func main() { str1 := "123"
str2 := "世界!"
str := strings.Join([]string{str1, str2}, "")
fmt.Println(str) }

三种连接方式性能测试

文件:study_test.go

package main

import (
"bytes"
"strings"
"testing"
) func StrPlus1(a []string) string {
var s, sep string
for i := 0; i < len(a); i++ {
s += sep + a[i]
sep = " "
}
return s
} func StrPlus2(a []string) string {
return strings.Join(a, " ")
} func StrPlus3(a []string) string { var buf bytes.Buffer
var sep = " "
for i := 0; i < len(a); i++ {
buf.WriteString(a[i])
buf.WriteString(sep) }
return buf.String()
} func BenchmarkStrPlus1(b *testing.B) {
for i := 0; i < b.N; i++ {
StrPlus1([]string{"xxx", "bbb", "aaa"})
}
} func BenchmarkStrPlus2(b *testing.B) {
for i := 0; i < b.N; i++ {
StrPlus2([]string{"xxx", "bbb", "aaa"})
}
} func BenchmarkStrPlus3(b *testing.B) {
for i := 0; i < b.N; i++ {
StrPlus3([]string{"xxx", "bbb", "aaa"})
}
}

运行压力测试go test -test.bench=".*"

输出:

golang学习笔记---string && strconv的更多相关文章

  1. golang学习笔记13 Golang 类型转换整理 go语言string、int、int64、float64、complex 互相转换

    golang学习笔记13 Golang 类型转换整理 go语言string.int.int64.float64.complex 互相转换 #string到intint,err:=strconv.Ato ...

  2. golang学习笔记16 beego orm 数据库操作

    golang学习笔记16 beego orm 数据库操作 beego ORM 是一个强大的 Go 语言 ORM 框架.她的灵感主要来自 Django ORM 和 SQLAlchemy. 目前该框架仍处 ...

  3. golang学习笔记10 beego api 用jwt验证auth2 token 获取解码信息

    golang学习笔记10 beego api 用jwt验证auth2 token 获取解码信息 Json web token (JWT), 是为了在网络应用环境间传递声明而执行的一种基于JSON的开放 ...

  4. golang学习笔记8 beego参数配置 打包linux命令

    golang学习笔记8 beego参数配置 打包linux命令 参数配置 - beego: 简约 & 强大并存的 Go 应用框架https://beego.me/docs/mvc/contro ...

  5. golang学习笔记7 使用beego swagger 实现API自动化文档

    golang学习笔记7 使用beego swagger 实现API自动化文档 API 自动化文档 - beego: 简约 & 强大并存的 Go 应用框架https://beego.me/doc ...

  6. golang学习笔记5 用bee工具创建项目 bee工具简介

    golang学习笔记5 用bee工具创建项目 bee工具简介 Bee 工具的使用 - beego: 简约 & 强大并存的 Go 应用框架https://beego.me/docs/instal ...

  7. golang学习笔记20 一道考察对并发多协程操作一个共享变量的面试题

    golang学习笔记20 一道考察对并发多协程操作一个共享变量的面试题 下面这个程序运行的能num结果是什么? package main import ( "fmt" " ...

  8. golang学习笔记19 用Golang实现以太坊代币转账

    golang学习笔记19 用Golang实现以太坊代币转账 在以太坊区块链中,我们称代币为Token,是以太坊区块链中每个人都可以任意发行的数字资产.并且它必须是遵循erc20标准的,至于erc20标 ...

  9. golang学习笔记18 用go语言编写移动端sdk和app开发gomobile

    golang学习笔记18 用go语言编写移动端sdk和app开发gomobile gomobile的使用-用go语言编写移动端sdk和app开发https://blog.csdn.net/u01249 ...

随机推荐

  1. logstash 入门篇

    场景介绍 基于分布式集群海量日志数据,且分布在不同的服务器上,日志的采集以及可视化是需要我们解决的问题.ELK就是这么一个方案,当然我们这里主要讲解logstash安装配置和基础语法. ELK帮我们解 ...

  2. 当MySQL数据库遇到Syn Flooding

    Syn攻击是最常见又最容易被利用的一种攻击手法,利用TCP协议的缺陷,发送大量伪造TCP连接请求,常用假冒的IP发来海量的SYN包,被攻击的服务器回应SYN+ACK,因为对方是假冒的IP,永远收不到包 ...

  3. Modbus协议 CRC 校验码

    CRC(循环冗余校验)在线计算 http://www.ip33.com/crc.html 里面的8005的多项式值,但网上看到的算法都是用A001来异或的 ---------------------- ...

  4. PHP基础(谈一谈Session&Cookie)

    cookie和sessiond的主要区别 (1).保存位置稍有区别 cookie数据存放在客户的浏览器上,服务器端不用保存.session数据放在服务器上,本地内存也有一份. (2).安全性不同 co ...

  5. Hadoop 从节点的 NodeManager 无法启动

    一.问题描述 日志文件信息如下: -- ::, INFO nodemanager.NodeManager (LogAdapter.java:info()) - registered UNIX sign ...

  6. Linux中断管理 (3)workqueue工作队列【转】

    转自:https://www.cnblogs.com/arnoldlu/p/8659988.html 目录: <Linux中断管理> <Linux中断管理 (1)Linux中断管理机 ...

  7. 安装教程-VMware 12 安装Ubuntu 19.04 桌面版

    VMware 12 安装Ubuntu 19.04 桌面版 1.实验描述 在虚拟机中,手动安装 Ubuntu 19.04 操作系统,为学习 Linux 桌面版提供平台,因此,有的参数有些差异,请勿较真. ...

  8. ios webview

    //#pragma mark - UIWebView Delegate Methods -(void)webViewDidFinishLoad:(UIWebView *)webView{ //获取到w ...

  9. Linux用户态与内核态通信的几种方式

    本文首发于我的公众号 Linux云计算网络(id: cloud_dev),专注于干货分享,号内有 10T 书籍和视频资源,后台回复「1024」即可领取,欢迎大家关注,二维码文末可以扫. Linux 用 ...

  10. adb连接夜神模拟器与adb常用操作命令

    adb connect 127.0.0.1:62001 adb kill-server 在关闭adb服务后,要使用如下的命令启动adb服务. adb start-servermore than one ...