Go语言基础工程目录如下(采用LiteIDE):

备注:需要提前设置GOPATH,即工作目录,bin、pkg、src为默认的GO工程目录结构。GOPATH可以支持多个,在windows下配置在环境变量里,以;分割。

go install com.fredric\lib 命令编译库

go install com.fredric\main 命令编译出执行文件main.exe

实际项目中运用了GO语言,抽时间夯实基础,在lib中实现了一些测试函数,如下:

1、集合相关

package lib

import (
"fmt"
) //测试数组
func ArrayTest() {
var array = []uint8{, , }
var i int = for i = ; i < len(array); i++ {
fmt.Printf("array %d Element:%d\n", i, array[i])
}
} //测试结构体
type User struct {
UserName string
PassWord string
} func StructTest() {
var user1 User
user1.UserName = "Fredric"
user1.PassWord = "Sinny" fmt.Printf("UserName: %s And Password %s\n", user1.UserName, user1.PassWord) //结构体指针
var pUser1 *User
pUser1 = &user1
fmt.Printf("UserName: %s And Password %s\n", pUser1.UserName, pUser1.PassWord)
} //测试切片
func SliceTest() {
//切片可以理解为可变数组
var slice1 []uint8 = make([]uint8, , )
//5为初始长度、10为容量,容量是可选参数,初始值为0
fmt.Printf("slice1:%v Len:%d Cap:%d\n", slice1, len(slice1), cap(slice1)) //此时LEN和CAP都为6
slice1 = []uint8{, , , , , }
fmt.Printf("slice1:%v Len:%d Cap:%d\n", slice1, len(slice1), cap(slice1)) //切片可以超出容量
var array = []uint8{, , , , , , , , , , }
slice1 = array
fmt.Printf("slice1:%v\n", slice1)
//打印结果为3,4,5
fmt.Printf("slice1 2:5 %v", slice1[:])
array[] =
//数组的值修改后,切片的值也对应修改,此时slice1[0] = 11
//因此slice是一个指针,指向那段数据内存
fmt.Printf("slice1:%v [0]:%d\n", slice1, slice1[]) //此时slice1尾部增加0,0两个元素,len = 13 CAP = 32
//注意:为什么此处CAP比len大那么多,因为在Slice上追加元素的时候,首先会放到这块空闲的内存中,
//如果添加的参数个数超过了容量值,内存管理器会重新划分一块容量值为原容量值*2大小的内存空间
slice1 = append(slice1, , )
fmt.Printf("slice1:%v Len:%d Cap:%d\n", slice1, len(slice1), cap(slice1)) newSlice := make([]uint8, len(slice1), cap(slice1))
copy(newSlice, slice1)
fmt.Printf("newSlice:%v Len:%d Cap:%d\n", newSlice, len(newSlice), cap(newSlice))
} //测试MAp
func MapTest() {
var myMap map[uint8]string myMap = make(map[uint8]string)
myMap[] = "fredric"
myMap[] = "sinny" for item := range myMap {
fmt.Printf("No[%d] Element Is %s\n", item, myMap[item])
} item, res := myMap[]
fmt.Printf("%s %t\n", item, res) delete(myMap, )
item, res = myMap[]
fmt.Printf("%s %t\n", item, res)
}

2、函数相关

package lib

import (
"fmt"
) //多个参数多个返回值
func test01(param1 string, param2 uint8) (string, bool) {
fmt.Printf("Param1 = %s, Param2 = %d\n", param1, param2)
return "result", true
} //测试函数特性
func FuncTest() {
//res1, res2 := test01("hello,world", 6)
//fmt.Println(res1, res2) //打印输出24
fmt.Println(Factorial())
} //菲波那切数列的递归函数
func Factorial(x int) (result int) {
if x == {
result =
} else {
result = x * Factorial(x-)
}
return
}

3、面向对象相关

package lib

import (
"fmt"
) //定义一个接口
type Service interface {
doService()
getParam() string
setParam(input string)
} type ServiceImpl1 struct {
param string
} func (impl1 *ServiceImpl1) doService() {
fmt.Println("ServiceImpl1", impl1.param)
} func (impl1 *ServiceImpl1) getParam() string {
return impl1.param
} func (impl1 *ServiceImpl1) setParam(input string) {
impl1.param = input
} type ServiceImpl2 struct {
param string
} func (impl2 *ServiceImpl2) doService() {
fmt.Println("ServiceImpl2", impl2.param)
} func (impl2 *ServiceImpl2) getParam() string {
return impl2.param
} func (impl2 *ServiceImpl2) setParam(input string) {
impl2.param = input
} //测试利用接口的面向对象
func OOTest() {
var service Service
service = new(ServiceImpl1)
service.setParam("Fredric")
//打印ServiceImpl1 Fredric
service.doService() service = new(ServiceImpl2)
service.setParam("Sinny")
//打印ServiceImpl2 Sinny
service.doService()
}

GO 基础(一)的更多相关文章

  1. java基础集合经典训练题

    第一题:要求产生10个随机的字符串,每一个字符串互相不重复,每一个字符串中组成的字符(a-zA-Z0-9)也不相同,每个字符串长度为10; 分析:*1.看到这个题目,或许你脑海中会想到很多方法,比如判 ...

  2. node-webkit 环境搭建与基础demo

    首先去github上面下载(地址),具体更具自己的系统,我的是windows,这里只给出windows的做法 下载windows x64版本 下载之后解压,得到以下东西 为了方便,我们直接在这个目录中 ...

  3. js学习笔记:webpack基础入门(一)

    之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...

  4. Golang, 以17个简短代码片段,切底弄懂 channel 基础

    (原创出处为本博客:http://www.cnblogs.com/linguanh/) 前序: 因为打算自己搞个基于Golang的IM服务器,所以复习了下之前一直没怎么使用的协程.管道等高并发编程知识 ...

  5. [C#] C# 基础回顾 - 匿名方法

    C# 基础回顾 - 匿名方法 目录 简介 匿名方法的参数使用范围 委托示例 简介 在 C# 2.0 之前的版本中,我们创建委托的唯一形式 -- 命名方法. 而 C# 2.0 -- 引进了匿名方法,在 ...

  6. HTTPS 互联网世界的安全基础

    近一年公司在努力推进全站的 HTTPS 化,作为负责应用系统的我们,在配合这个趋势的过程中,顺便也就想去搞清楚 HTTP 后面的这个 S 到底是个什么含义?有什么作用?带来了哪些影响?毕竟以前也就只是 ...

  7. Swift与C#的基础语法比较

    背景: 这两天不小心看了一下Swift的基础语法,感觉既然看了,还是写一下笔记,留个痕迹~ 总体而言,感觉Swift是一种前后端多种语言混合的产物~~~ 做为一名.NET阵营人士,少少多多总喜欢通过对 ...

  8. .NetCore MVC中的路由(1)路由配置基础

    .NetCore MVC中的路由(1)路由配置基础 0x00 路由在MVC中起到的作用 前段时间一直忙于别的事情,终于搞定了继续学习.NetCore.这次学习的主题是MVC中的路由.路由是所有MVC框 ...

  9. .NET基础拾遗(5)多线程开发基础

    Index : (1)类型语法.内存管理和垃圾回收基础 (2)面向对象的实现和异常的处理基础 (3)字符串.集合与流 (4)委托.事件.反射与特性 (5)多线程开发基础 (6)ADO.NET与数据库开 ...

  10. .NET 基础 一步步 一幕幕[面向对象之方法、方法的重载、方法的重写、方法的递归]

    方法.方法的重载.方法的重写.方法的递归 方法: 将一堆代码进行重用的一种机制. 语法: [访问修饰符] 返回类型 <方法名>(参数列表){ 方法主体: } 返回值类型:如果不需要写返回值 ...

随机推荐

  1. Travis CI用来持续集成你的项目

    这里持续集成基于GitHub搭建的博客为项目 工具: zqz@ubuntu:~$ node --version v4.2.6 zqz@ubuntu:~$ git --version git versi ...

  2. Git 在团队中的最佳实践--如何正确使用Git Flow

    我们已经从SVN 切换到Git很多年了,现在几乎所有的项目都在使用Github管理, 本篇文章讲一下为什么使用Git, 以及如何在团队中正确使用. Git的优点 Git的优点很多,但是这里只列出我认为 ...

  3. 匹夫细说C#:庖丁解牛迭代器,那些藏在幕后的秘密

    0x00 前言 在匹夫的上一篇文章<匹夫细说C#:不是“栈类型”的值类型,从生命周期聊存储位置>的最后,匹夫以总结和后记的方式涉及到一部分迭代器的知识.但是觉得还是不够过瘾,很多需要说清楚 ...

  4. PC分配盘符的时候发现==》RPC盘符不可用

    服务器汇总:http://www.cnblogs.com/dunitian/p/4822808.html#iis 服务器异常: http://www.cnblogs.com/dunitian/p/45 ...

  5. 微框架spark--api开发利器

    spark简介 Spark(注意不要同Apache Spark混淆)的设计初衷是,可以简单容易地创建REST API或Web应用程序.它是一个灵活.简洁的框架,大小只有1MB.Spark允许用户自己选 ...

  6. 【JQ基础】数组

    each() 方法规定为每个匹配元素规定运行的函数.

  7. Xcode 锁终端

    锁终端 输入: <1>cd /Applications/Xcode.app 回车 结果显示: Xcode.app 输入: <2>sudo chown -hR root:whee ...

  8. DockerCon 2016 – 微软带来了什么?

    根据Forrester的调查,接近半数的企业CIO在考虑IT架构的时候更乐于接受开源方案,这主要是基于低成本,避免供应商锁定和敏捷的需求:同时另外一家North Bridge的调研机构的调查显示,20 ...

  9. uboot环境配置

    uboot环境配置 通过配置uboot让它在启动过程中从tftp获取内核和设备树,并从在加载内核之后把通过启动参数将"从nfs挂载根文件系统"传入内核.这个配置主要是通过uboot ...

  10. Tomcat之APR错误

    在发布Apache Tomcat的时候,突然出现如下错误: An incompatible version 1.1.31 of the APR based Apache Tomcat Native l ...