go 学习之路(三)
一、strings和strconv使用
1、strings.HasPrefix(s string,prefix string) bool :判断字符串s是否以prefix开头
2、stings.HasSuffix(s string,suffix string) bool:判断字符串s是否以suffix结尾
3、strings.Index(s string,str string) int: 判断str在s中首次出现的位置,如果没有,返回-1
4、strings.LastIndex(s string,str string) int:判断str在s中最后出现的位置,如果没有,返回-1
5、strings.Replace(str string, old string, new string, n int):字符串替换
6、strings.Count(str string, substr string)int:字符串计数
7、strings.Repeat(str string, count int)string:重复count次str
8、strings.ToLower(str string)string:转为小写
9、strings.ToUpper(str string)string:转为大写
package main import (
"fmt"
"strings"
) //判断字符串以xx开头
func judge_prefix(str string) string {
var str_change string
if strings.HasPrefix(str, "http://") == false {
str_change = "http://" + str
}
return str_change
} //判断字符串以xx结尾
func judge_suffix(str string) string {
var str_change string
if strings.HasSuffix(str, "/") == false {
str_change = str + "/"
}
return str_change
} //字符串中s首次出现的位置,没有返回-1
func str_index(str string, show_str string) int {
result := strings.Index(str, show_str)
return result
} //字符串替换,n代表字符串出现第一次,-1表示全部替换
func replace(str string, old string, new string, n int) string {
result := strings.Replace(str, old, new, n)
return result
} //字符串中出现某字符串的次数
func count(str string, substr string) int {
result := strings.Count(str, substr)
return result
} func main() {
url := judge_prefix("baidu.com")
path := judge_suffix("go_dev")
index := str_index("llohehe", "he")
replace := replace("hellohehe", "he", "wo", -1)
count := count("hellohehe", "he")
fmt.Println("url", url)
fmt.Println("path", path)
fmt.Println("index", index)
fmt.Println("replace", replace)
fmt.Println("count", count)
}
strings.TrimSpace(str string):去掉字符串首尾空白字符
strings.Trim(str string, cut string):去掉字符串首尾cut字符
strings.TrimLeft(str string, cut string):去掉字符串首cut字符
strings.TrimRight(str string, cut string):去掉字符串首cut字符
strings.Field(str string):返回str空格分隔的所有子串的slice
strings.Split(str string, split string):返回str split分隔的所有子串的slice
strings.Join(s1 []string, sep string):用sep把s1中的所有元素链接起来
strconv.Itoa(i int):把一个整数i转成字符串
strconv.Atoi(str string)(int, error):把一个字符串转成整数
package main import (
"fmt"
"strings"
"strconv"
) //去空格
func removeSpace(str string) string {
result := strings.TrimSpace(str)
return result
} //字符串首尾remove某字符
func removeStr(str string, cut string) string {
result := strings.Trim(str, cut)
return result
} func removeLeft(str string, cut string) string {
result := strings.TrimLeft(str, cut)
return result
} func main() {
removeSpace := removeSpace(" xxx ")
removeStr := removeStr("abbaaaaaaacdab", "ab")
removeLeft := removeLeft("abbacdab", "ab")
strSplit("abc,def,ghi", ",")
fmt.Println(removeSpace)
fmt.Println(removeStr)
fmt.Println(removeLeft)
splitResult := strings.Split(str,"l")
str2 = strings.Join(splitResult,"l")
str2 = strconv.Itoa(1000)
number,err := strconv.Atoi(str2)
if err != nil{
fmt.Println("can not convert to int",err)
}
}
时间和日期类型
1、time包
2、time.Time类型,用来表示时间
3、获取当前时间,now :=time.Now()
4、time.Now().Day(),time.Now().Minute(),time.Now().Month(),time.Now().Year()
5、格式化,fmt.Printf(“%02d/%02d%02d %02d:%02d:%02d”, now.Year()…)
example:获取当前时间,并格式化成2018/04/07 16:09:00格式
package main import (
"fmt"
"time"
) func main() {
now := time.Now()
fmt.Println(now.Format("2006/01/02 15:04:05"))
}
example:获取程序执行时间
package main import (
"fmt"
"time"
) func test() {
time.Sleep(time.Millisecond * 100)
}
func main() {
start := time.Now().UnixNano()
test()
end := time.Now().UnixNano()
fmt.Printf("cost:%d us\n", (end-start)/1000)
}
指针类型
1、普通类型,变量存的就是值,也叫值类型
2、获取变量的地址,用&,比如: var a int, 获取a的地址:&a
3、指针类型,变量存的是一个地址,这个地址存的才是值
4、获取指针类型所指向的值,使用:*,比如:var *p int, 使用*p获取p指向的值
package main import (
"fmt"
) func main() {
var a int = 10
fmt.Println(&a) var p *int //p是指针,存的是地址
p = &a // p=a的地址
*p = 100 //a的地址所指向的值赋值100
fmt.Println(a) //a输出100
}
流程控制
1、if / else分支判断
package main import (
"fmt"
) func main() {
bool1 := true
if bool1 {
fmt.Printf("the value is true")
} else {
fmt.Printf("the value is false")
}
}
if的条件可以赋值,赋值的变量作用域就在这个if语句里
if contents, err := ioutil.ReadFile(filename); err != nil {
fmt.Println(err)
} else {
fmt.Printf("%s\n", contents)
}
example:从终端读取输入,并转成整数,如果转成整数出错,则输出错误,否则输出该整数
package main import (
"fmt"
"strconv"
) func main() {
var str string
fmt.Scanf("%s", &str)
number, err := strconv.Atoi(str)
if err != nil {
fmt.Println("conver failed,err:", err)
return
}
fmt.Println(number)
}
2、switch case语法
switch var{
case var1:
case var2:
case var3:
default:
}
package main import (
"fmt"
) func main() {
var a int = 10
switch a {
case 0:
fmt.Println("a is equal 0")
case 10:
fmt.Println("a is equal 10")
default:
fmt.Println("a is equal default")
}
}
fallthrough穿透执行
example:猜数字,写一个程序,随机生成一个0到100的整数n,然后用户在终端输入数字,如果和n相等,则提示用户猜对了。如果不相等,则提示用户,大于或小于n
package main import (
"fmt"
"math/rand"
) func main() {
var n int
n = rand.Intn(100)
for {
var input int
fmt.Scanf("%d\n", &input)
flag := false
switch {
case input == n:
fmt.Println("you are right")
break
flag = true
case input > n:
fmt.Println("bigger")
case input < n:
fmt.Println("less")
}
if flag {
break
}
}
}
for
写法1 for 初始化语句;条件判断;变量修改
example:终端打印如下图形
package main import (
"fmt"
) func Print(n int) {
for i := 1; i < n+1; i++ {
for j := 0; j < i; j++ {
fmt.Printf("A")
}
fmt.Println()
}
} func main() {
Print(10)
}
写法2:for 条件{
}
写法3:for range 语法
package main import (
"fmt"
) func main() {
str := "hello,world,中国"
for i, v := range str {
if i > 2 {
continue
}
if i > 3 {
break
}
fmt.Printf("index[%d] val[%c] len[%d]\n", i, v, len([]byte(string(v))))
} }
goto和label语句
package main import (
"fmt"
) func main() {
LABEL1:
for i := 0; i <= 5; i++ {
for j := 0; j <= 5; j++ {
if j == 4 {
continue LABEL1
}
fmt.Printf("i is:%d,and j is:%d\n", i, j)
}
}
}
package main import (
"fmt"
) func main() {
i := 0
HERE:
fmt.Println(i)
i++
if i == 5 {
return
}
goto HERE
}
函数
申明语法
func 函数名 (参数列表) 返回值 { }
golang函数特点:
不支持重载,一个包不能有两个名字一样的函数
函数是一等公民,函数也是一种类型,一个函数可以赋值给变量
匿名函数
多返回值
example1:
package main import (
"fmt"
) func add(a, b int) int {
return a + b
} func main() {
c := add //函数赋值给变量
fmt.Println(c)
sum := c(10, 20)
fmt.Println(sum)
}
example2:定义函数类型
package main import (
"fmt"
) type add_func func(int, int) int func sub(a, b int) int {
return a - b
} func operator(op add_func, a, b int) int {
return op(a, b)
} func main() {
c := sub
fmt.Println(c)
sum := operator(c, 100, 200)
fmt.Println(sum)
}
函数参数传递方式:
map、slice、chan、指针、interface默认引用方式传递
函数能对返回值命名
可变参数
example:支持一个或多个int相加或string拼接
func add(a int, arg ...int) int {
var sum int
sum += a
for i := 0; i < len(arg); i++ {
sum += arg[i]
}
return sum
} func content(a string, arg ...string) string {
var result string = a
for i := 0; i < len(arg); i++ {
result += arg[i]
}
return result
} func main() {
// result := add(10, 3, 4)
result := content("hello", " ", "world")
fmt.Println(result)
}
defer用途:
当函数返回时,执行defer语句,用来资源清理
多个defer,先进后出方式执行(栈)
defer在函数结束时才被执行,不合理的使用方式会浪费更多资源
案例:循环处理多个日志文件时,导致文件关闭时间延长
package main import (
"log"
"os"
"fmt"
) func main(){
for i:=0;i<1000;i++{
path := fmt.Sprintf("./log/%d.txt",i) f,err :=os.Open(path)
if err != nil {
log.Println(err)
continue
}
defer f.Close()
}
}
关闭操作只有在main函数结束后才会执行,并不是每一次循环结束后执行
将循环和处理分离
package main import (
"fmt"
"log"
"os"
) func main() {
do := func(n int) {
path := fmt.Sprintf("./log/%d.txt", n) f, err := os.Open(path)
if err != nil {
log.Println(err)
}
defer f.Close()
} for i := 0; i < 1000; i++ {
do(i)
}
}
example:关闭文件句柄
func read() {
file :=open(filename)
defer file.close()
}
package main import (
"fmt"
) func test() []func() {
var s []func()
for i := 0; i < 2; i++ {
s = append(s, func() { //将多个匿名函数添加到列表
fmt.Println(i)
})
}
return s //返回匿名函数列表
} func main() {
for _, f := range test() { //迭代执行所有的匿名函数
f()
}
}
上述代码输出
2
2
添加匿名函数到列表时并未执行,当main执行这些函数时,读取得是环境变量i最后一次循环的值,i=2,内存地址一样
package main import (
"fmt"
) func test() []func() {
var s []func()
for i := 0; i < 2; i++ {
x := i //x每次循环都重新定义,并不是重新赋值
s = append(s, func() { //将多个匿名函数添加到列表
fmt.Println(x)
})
}
return s //返回匿名函数列表
} func main() {
for _, f := range test() { //迭代执行所有的匿名函数
f()
}
}
输出
0
1
内存地址不一样
错误处理
package main import (
"errors"
"fmt"
"log"
) var errDivByZero = errors.New("division by zero") func div(x, y int) (n int, err error) {
if y == 0 {
return 0, errDivByZero
}
return x / y, nil
}
func main() {
z, err := div(5, 2)
if err == errDivByZero {
log.Fatalln(err)
}
fmt.Println(z)
}
go 学习之路(三)的更多相关文章
- 学习之路三十九:新手学习 - Windows API
来到了新公司,一开始就要做个程序去获取另外一个程序里的数据,哇,挑战性很大. 经过两周的学习,终于搞定,主要还是对Windows API有了更多的了解. 文中所有的消息常量,API,结构体都整理出来了 ...
- Redis——学习之路三(初识redis config配置)
我们先看看config 默认情况下系统是怎么配置的.在命令行中输入 config get *(如图) 默认情况下有61配置信息,每一个命令占两行,第一行为配置名称信息,第二行为配置的具体信息. ...
- zigbee学习之路(三):按键的控制
一.前言 通过前一次的实验,相信大家都已经对cc2530程序的编写有了一定的认识,这次我们来操作和实验的是cc2530上的按键模块. 二.原理分析 我们先来看一下按键的原理图: 根据原理图我们可以得出 ...
- 学习之路三十二:VS调试的简单技巧
这段时间园子里讲了一些关于VS的快捷键以及一些配置技巧,挺好的,大家一起学习,一起进步. 这段时间重点看了一下关于VS调试技巧方面的书,在此记录一下学习的内容吧,主要还是一些比较浅显的知识. 1. 调 ...
- 交互原型设计软件axure rp学习之路(三)
(三)Axure rp元件的触发事件 l OnClick(点击时): 鼠标点击事件,除了动态面板的所有的其他元件的点击时触发.比如点击按钮. l OnMouseEnter(鼠标移入时): 鼠标进入 ...
- 学习之路三十五:Android和WCF通信 - 大数据压缩后传输
最近一直在优化项目的性能,就在前几天找到了一些资料,终于有方案了,那就是压缩数据. 一丶前端和后端的压缩和解压缩流程 二丶优点和缺点 优点:①字符串的压缩率能够达到70%-80%左右 ②字符串数量更少 ...
- IOS7学习之路三(UISpriteKit游戏开发SKNode)
ios7新添加了自己的游戏开发框架UISpriteKit ,可以用此做一些2D的小游戏, 今天学习了一下SKNode的知识做一下笔记,以便以后查阅. 1.SKNode继承自UIResponder. 2 ...
- python学习之路 三:字符编码
本节重点 彻底掌握字符编码之前的转换关系 掌握 python2 vs python3 上编码的区别 掌握 python2 和python3 上bytes,str 的区别 补充知识点:三元运算 三元运 ...
- react.js学习之路三
学习react.js,知识点整理: 1.props和state: props是相对于父级来说,固定的不会改变的内容.一般会先定义一个变量,则在父级中进行引用, var user = "liu ...
- go语言学习之路三:切片
前面讲了变量的有关知识,这里对于其他的数据类型就不多作介绍,(和C差不多),因此重点来讨论下切片. 一.切片是引用类型,这里要稍微介绍两个概念:值类型,构造类型和引用类型 1.值类型:是一种由类型的实 ...
随机推荐
- 【需要重新维护】Redis笔记20170811视频
很多内容都是抄的,个人记录 1.windows下初见 安装 进入目录 修改配置文件(暂时使用默认,未配置环境变量) 目录下:redis-server.exe启动服务 新建命令提示符,目录下,redis ...
- Java学习笔记——Socket实现文件传输
我越是逃离,却越是靠近你. 我越是背过脸,却越是看见你. 我从你开始, 我在你结束. 需求:实现局域网下socket传输文件. 客户端步骤: 1.建立与服务器的连接 2.创建client输出流 3.创 ...
- 6tunnel数据转发
6tunnel 一条命令实现端口映射.数据转发,实现代理服务器功能. 安装脚本 #!/bin/bash DIR=/opt/software INSTALL=6tunnel-master.tar.gz ...
- 另一个ACM之路建议
ACM联系建议 一位高手对我的建议: 一般要做到50行以内的程序不用调试.100行以内的二分钟内调试成功.acm主要是考算法的 ,主要时间是花在思考算法上,不是花在写程序与debug上. 下面给个计划 ...
- Oracle Goldengate是如何保证数据有序和确保数据不丢失的?
工作中一直在用Oracle 的中间件Oracle GondenGate 是如何保证消息的有序和不丢失呢? Oracle GoldenGate逻辑架构 首先,先看一下Oracle GoldenGate ...
- Siimple DP (Dynamic Programing)
HDU 2084:https://vjudge.net/problem/HDU-2084 Problem Describe : When it comes to the DP algorithm, a ...
- 搭建Spring Initializr服务器
前言 按照网上很多教程,出错特别多.首先是GitHub和maven仓库的网络环境比较差,踩了很多坑:其次是SpringInitializr更新迭代几个版本,0.7.0我也没能弄成功.索性就用了旧版本0 ...
- 基于Actor模型的CQRS、ES解决方案分享
开场白 大家晚上好,我是郑承良,跟大家分享的话题是<基于Actor模型的CQRS/ES解决方案分享>,最近一段时间我一直是这个话题的学习者.追随者,这个话题目前生产环境落地的资料少一些,分 ...
- 鸽巢原理及其扩展——Ramsey定理
第一部分:鸽巢原理 咕咕咕!!! 然鹅大家还是最熟悉我→ a数组:but 我也很重要 $:我好像也出现不少次 以上纯属灌水 文章简叙:鸽巢原理对初赛时的问题求解以及复赛的数论题目都有启发意义.直接的初 ...
- 个人永久性免费-Excel催化剂功能第18波-在Excel上也能玩上词云图
这年头数据可视化日新月异,在Excel上做数据分析,最后一步,难免要搞个图表输出高大上一回,微软也深知此道,在Excel2016上更新了一大波图表功能,市场上很耀眼的词云图还是没加进来,虽然在各大的在 ...