go语言练习
// main
package main import (
"fmt"
"runtime"
"sync"
) func main() {
fmt.Println("Hello World!")
runtime.GOMAXPROCS()
var wg sync.WaitGroup
wg.Add()
i :=
fmt.Println("Start Goroutines") go func() {
defer wg.Done()
//共享变量 i wg
fmt.Println(i)
for count := ; count < ; count++ {
for char := 'a'; char < 'a'+; char++ {
fmt.Printf("%c ", char)
}
}
}() go func() {
defer wg.Done()
fmt.Println(i)
for count := ; count < ; count++ {
for char := 'A'; char < 'A'+; char++ {
fmt.Printf("%c ", char)
}
}
}() fmt.Println("Waiting to Finish")
wg.Wait() fmt.Println("\nTerminating Program")
}
go 协程练习
接口练习
// Sample program to show what happens when the outer and inner
// type implement the same interface.
package main import (
"fmt"
) // notifier is an interface that defined notification
// type behavior.
type notifier interface {
notify()
} // user defines a user in the program.
type user struct {
name string
email string
} // notify implements a method that can be called via
// a value of type user.
func (u *user) notify() {
fmt.Printf("Sending user email to %s<%s>\n",
u.name,
u.email)
} // admin represents an admin user with privileges.
type admin struct {
user
level string
} // notify implements a method that can be called via
// a value of type Admin.
func (a *admin) notify() {
fmt.Printf("Sending admin email to %s<%s>\n",
a.name,
a.email)
} // main is the entry point for the application.
func main() {
// Create an admin user.
ad := admin{
user: user{
name: "john smith",
email: "john@yahoo.com",
},
level: "super",
} // Send the admin user a notification.
// The embedded inner type's implementation of the
// interface is NOT "promoted" to the outer type.
sendNotification(&ad) // We can access the inner type's method directly.
ad.user.notify() // The inner type's method is NOT promoted.
ad.notify()
} // sendNotification accepts values that implement the notifier
// interface and sends notifications.
func sendNotification(n notifier) {
n.notify()
}
work代码注释 《go语言编程实战》
package work import "sync" //接口
type Worker interface {
Task()
} //pool结构体
type Pool struct {
work chan Worker
wg sync.WaitGroup
} //new函数 返回 pool指针
func New(maxGorountines int) *Pool {
p := Pool{
work: make(chan Worker),
}
//wg添加wait数量
p.wg.Add(maxGorountines)
for i := ; i < maxGorountines; i++ {
go func() {
//执行POOL内的任务 完成后wg执行done
for w := range p.work {
w.Task()
}
p.wg.Done()
}()
} return &p
} //将任务放入POOL
func (p *Pool) Run(w Worker) {
p.work <- w
} //关闭POOL
func (p *Pool) Shutdown() {
close(p.work)
p.wg.Wait()
}
// main
package main import (
"fmt"
"log"
"sync"
"time"
"work"
) var names = []string{
"steve",
"bob",
"mary",
"therese",
"jason",
} type namePrinter struct {
name string
} func (m *namePrinter) Task() {
log.Println(m.name)
time.Sleep(time.Second)
} func main() {
fmt.Println("Hello World!")
p := work.New() var wg sync.WaitGroup
wg.Add( * len(names)) for i := ; i < ; i++ {
for _, name := range names {
np := namePrinter{
name: name,
}
go func() {
p.Run(&np)
wg.Done()
}()
}
}
wg.Wait()
p.Shutdown()
}
runner代码注释 《go语言编程实战》
// runner
package runner import (
"errors"
"fmt"
"os"
"os/signal"
"time"
) //runner结构体
type Runner struct {
interrupt chan os.Signal
complete chan error
timeout <-chan time.Time
tasks []func(int)
} //错误变量1
var Errtimeout = errors.New("received timeout")
//错误变量2
var ErrInterrupt = errors.New("received interrupt") //runner的new函数
func New(d time.Duration) *Runner {
return &Runner{
interrupt: make(chan os.Signal, ),
complete: make(chan error),
timeout: time.After(d),
}
} //func(int)加入 runner
func (r *Runner) Add(tasks ...func(int)) {
r.tasks = append(r.tasks, tasks...)
} //goroutine执行 结果超时或者错误 成功
func (r *Runner) Start() error {
signal.Notify(r.interrupt, os.Interrupt) go func() {
r.complete <- r.run()
}() select {
case err := <-r.complete:
return err
case <-r.timeout:
return Errtimeout
}
} //run函数 遍历函数数组
//若发生错误中断则返回 中断错误
func (r *Runner) run() error {
for id, task := range r.tasks {
if r.gotInterrupt() {
return ErrInterrupt
}
task(id)
}
return nil
} //通过interrupt接受中断
func (r *Runner) gotInterrupt() bool {
select {
case <-r.interrupt:
signal.Stop(r.interrupt)
return true
default:
return false
}
} //无用main函数
func main() {
fmt.Println("Hello World!") }
// main
package main import (
"fmt"
"log"
"os"
"runner"
"time"
) const timeout = * time.Second func main() {
fmt.Println("Hello World!")
log.Println("Starting work.") r := runner.New(timeout) r.Add(createTask(), createTask(), createTask()) if err := r.Start(); err != nil {
switch err {
case runner.Errtimeout:
log.Println("Terminating due to timeout")
os.Exit()
case runner.ErrInterrupt:
log.Println("Terminating due to interrupt")
os.Exit()
}
}
log.Println("Process ended")
} func createTask() func(int) {
return func(id int) {
log.Printf("processor - Task #%d", id)
time.Sleep(time.Duration(id) * time.Second)
}
}
go语言编程 代码修改
package library //music 记录
type MusicEntry struct {
Id string
Name string
Artist string
Source string
Type string
}
musicentry
package library import "errors" //音乐管理器 音乐记录数组
type MusicManager struct {
musics []MusicEntry
} //返回音乐管理器指针
func NewMusicManager() *MusicManager {
return &MusicManager{make([]MusicEntry, )}
} //返回音乐管理器 音乐数组的元素数
func (m *MusicManager) Len() int {
return len(m.musics)
} //输入索引 获取音乐记录指针
func (m *MusicManager) Get(index int) (music *MusicEntry, err error) {
if index < || index >= len(m.musics) {
return nil, errors.New("Index out of range.")
}
return &m.musics[index], nil
} //根据名字字符串 查找音乐记录的指针
func (m *MusicManager) Find(name string) *MusicEntry {
if len(m.musics) == {
return nil
} for _, m := range m.musics {
if m.Name == name {
return &m
}
}
return nil
} //添加音乐记录 输入音乐记录指针
func (m *MusicManager) Add(music *MusicEntry) { m.musics = append(m.musics, *music)
} //输入索引 移除指定索引 返回音乐记录指针
func (m *MusicManager) Remove(index int) *MusicEntry {
if index < || index >= len(m.musics) {
return nil
} removedMusic := &m.musics[index] // Remove the found item from the slice.
if index < len(m.musics)- { // Element between first and last
m.musics = append(m.musics[:index-], m.musics[index+:]...)
} else if index == { // empty it.
m.musics = make([]MusicEntry, )
} else { // The last element
m.musics = m.musics[:index-]
} return removedMusic
} //输入名字字符串 移除符合的音乐记录 返回音乐记录指针
func (m *MusicManager) RemoveByName(name string) *MusicEntry {
if len(m.musics) == {
return nil
} for i, v := range m.musics {
if v.Name == name {
return m.Remove(i)
}
}
return nil
}
manager
package library import "testing" func TestOps(t *testing.T) {
mm := NewMusicManager()
if mm == nil {
t.Error("NewMusicManager failed")
} if mm.Len() != {
t.Error("NewMusicManager failed,not empty")
} m0 := &MusicEntry{"", "MyHeart", "Celion", "http://wwww", "pop"}
mm.Add(m0) if mm.Len() != {
t.Error("MusicManager Add() failed")
} m := mm.Find(m0.Name)
if m == nil {
t.Error("MusicManager Find() failed")
} if m.Id != m0.Id || m.Name != m0.Name ||
m.Artist != m0.Artist || m.Source != m0.Source ||
m.Type != m0.Type {
t.Error("MusicManager Find() failed.Found item mismatch")
} m, err := mm.Get()
if m == nil || err != nil {
t.Error("MusicManager Get() failed")
} m = mm.Remove()
if m == nil || mm.Len() != {
t.Error("MusicManager Remove() failed")
} }
manager_test
服务器 代码备份
// main
package main import (
//"crypto/cipher"
//"bufio"
"bytes"
"crypto/aes"
"encoding/binary"
"errors"
"fmt"
"log"
"net"
) var g_string string type Header struct {
flag byte
packageLen int32
} //字节转换成整形
func BytesToInt(b []byte) int {
bytesBuffer := bytes.NewBuffer(b) var x int32
binary.Read(bytesBuffer, binary.LittleEndian, &x) return int(x)
} func recvBuf(conn net.Conn, buf []byte) (int, error) {
n, err := conn.Read(buf)
return n, err
} func recvHeader(conn net.Conn) (int, error) {
headerbuf := make([]byte, )
//fmt.Println("before buf:", headerbuf) n, err := recvBuf(conn, headerbuf)
if err != nil || n != {
fmt.Println("err:", err)
return -, err
}
//fmt.Println("after buf:", headerbuf, " n:", n)
if headerbuf[] != '|' {
fmt.Println("err:flag error,exit!")
return -, err
}
n = BytesToInt(headerbuf[:])
return n, err
} func recvBody(conn net.Conn, n int) (int, error) {
var err = errors.New(" closed")
buf := make([]byte, n) n, err = recvBuf(conn, buf)
if err != nil || n <= {
fmt.Println("err:", err)
return -, err
}
//buf 解密
mainecb(buf) return n, err
} func handleConn(conn net.Conn) {
fmt.Println("Enter func handleConn")
defer conn.Close()
who := conn.RemoteAddr().String()
fmt.Println(who)
for {
n, err := recvHeader(conn)
//fmt.Println("recvHeader n = ", n, " ", err)
if n <= || err != nil {
var ErrEOF = errors.New("EOF")
if err == ErrEOF {
fmt.Println("err eauql")
}
fmt.Println("err:recvHeader error,exit! ,err:", err)
break
}
_, err = recvBody(conn, n)
} } //===============================================
//ecb
//===============================================
//AES ECB模式的加密解密
type AesTool struct {
//128 192 256位的其中一个 长度 对应分别是 16 24 32字节长度
Key []byte
BlockSize int
} func (this *AesTool) Decrypt(src []byte) ([]byte, error) {
//key只能是 16 24 32长度
block, err := aes.NewCipher([]byte(this.Key))
if err != nil {
return nil, err
}
//返回加密结果
decryptData := make([]byte, len(src))
//存储每次加密的数据
tmpData := make([]byte, this.BlockSize) //分组分块加密
for index := ; index < len(src); index += this.BlockSize {
block.Decrypt(tmpData, src[index:index+this.BlockSize])
//copy(decryptData, tmpData)
decryptData = mergeByteArray(decryptData, tmpData)
}
return this.PKCS5UnPadding(decryptData), nil
} func mergeByteArray(a []byte, b []byte) []byte {
alen := len(a)
blen := len(b) z := make([]byte, alen+blen) for i := ; i < alen; i++ {
z[i] = a[i]
}
for i := ; i < blen; i++ {
z[alen+i] = b[i]
}
return z
} //unpadding
func (this *AesTool) unPadding(src []byte) []byte {
for i := len(src) - ; ; i-- {
if src[i] != {
return src[:i+]
}
}
return nil
} func (this *AesTool) PKCS5Padding(ciphertext []byte, blockSize int) []byte {
padding := blockSize - len(ciphertext)%blockSize
padtext := bytes.Repeat([]byte{byte(padding)}, padding)
return append(ciphertext, padtext...)
} func (this *AesTool) PKCS5UnPadding(origData []byte) []byte {
length := len(origData)
// 去掉最后一个字节 unpadding 次
unpadding := int(origData[length-])
origData = origData[:(length - unpadding)]
fmt.Println("origData inner:", string(origData))
return origData
} func mainecb(encryptData []byte) {
//key := []byte{'#', '2', '&', '*', '#', ....}
blickSize :=
tool := NewAesTool(key, blickSize)
decryptData, _ := tool.Decrypt(encryptData)
fmt.Println(string(decryptData))
}
func NewAesTool(key []byte, blockSize int) *AesTool {
return &AesTool{Key: key, BlockSize: blockSize}
} //====================================================
//var global_int = 99 func main() {
fmt.Println("Hello World!") listener, err := net.Listen("tcp", "192.。。。")
if err != nil {
log.Fatal(err)
}
for {
conn, err := listener.Accept()
if err != nil {
log.Println(err)
continue
}
go handleConn(conn)
} fmt.Println("net finish...")
}
go语言练习的更多相关文章
- C语言 · 高精度加法
问题描述 输入两个整数a和b,输出这两个整数的和.a和b都不超过100位. 算法描述 由于a和b都比较大,所以不能直接使用语言中的标准数据类型来存储.对于这种问题,一般使用数组来处理. 定义一个数组A ...
- Windows server 2012 添加中文语言包(英文转为中文)(离线)
Windows server 2012 添加中文语言包(英文转为中文)(离线) 相关资料: 公司环境:亚马孙aws虚拟机 英文版Windows2012 中文SQL Server2012安装包,需要安装 ...
- iOS开发系列--Swift语言
概述 Swift是苹果2014年推出的全新的编程语言,它继承了C语言.ObjC的特性,且克服了C语言的兼容性问题.Swift发展过程中不仅保留了ObjC很多语法特性,它也借鉴了多种现代化语言的特点,在 ...
- C语言 · Anagrams问题
问题描述 Anagrams指的是具有如下特性的两个单词:在这两个单词当中,每一个英文字母(不区分大小写)所出现的次数都是相同的.例如,"Unclear"和"Nuclear ...
- C语言 · 字符转对比
问题描述 给定两个仅由大写字母或小写字母组成的字符串(长度介于1到10之间),它们之间的关系是以下4中情况之一: 1:两个字符串长度不等.比如 Beijing 和 Hebei 2:两个字符串不仅长度相 ...
- JAVA语言中的修饰符
JAVA语言中的修饰符 -----------------------------------------------01--------------------------------------- ...
- Atitit 项目语言的选择 java c#.net php??
Atitit 项目语言的选择 java c#.net php?? 1.1. 编程语言与技术,应该使用开放式的目前流行的语言趋势1 1.2. 从个人职业生涯考虑,java优先1 1.3. 从项目实际来 ...
- 【开源】简单4步搞定QQ登录,无需什么代码功底【无语言界限】
说17号发超简单的教程就17号,qq核审通过后就封装了这个,现在放出来~~ 这个是我封装的一个开源项目:https://github.com/dunitian/LoTQQLogin ————————— ...
- InstallShield 脚本语言学习笔记
InstallShield脚本语言是类似C语言,利用InstallShield的向导或模板都可以生成基本的脚本程序框架,可以在此基础上按自己的意愿进行修改和添加. 一.基本语法规则 ...
- 用C语言封装OC对象(耐心阅读,非常重要)
用C语言封装OC对象(耐心阅读,非常重要) 本文的主要内容来自这里 前言 做iOS开发的朋友,对OC肯定非常了解,那么大家有没有想过OC中NSInteger,NSObject,NSString这些对象 ...
随机推荐
- Steering Behaviors
[Steering Behaviors] 1.Seek 下述的算法是一个基本Seek行为,但不带任何Steering输出的力.在该公式作用下,游戏个体的移动方式是直线型的,如果target的位置变了的 ...
- Handling Event
[Handling Event] 1.React events are named using camelCase 2.You must call preventDefault explicitly ...
- mybatis in查询 传入string
<select id="selectChoosenumberdetailNumber" > SELECT number FROM choosenumberdetail ...
- nginx配置 解决ajax请求跨域问题
文章来源:http://to-u.xyz/2016/06/30/nginx-cors/ 背景描述 最近在研究RESTful API接口设计,使用的是Nginx,要实现本地http://127.0.0. ...
- CentOS ./configure && make && make install详解
码的安装一般由3个步骤组成:配置(configure).编译(make).安装(make install). 在Linux中利用源码包安装软件最重要的就是要仔细阅读安装包当中的README INST ...
- AssetBundle Manager and Example Scenes
示例 1:加载资源 使用 “Asset/AssetBundles/Simulation Mode” 菜单打开模拟模式 打开 “AssetBundleSample/Scenes/AssetLoader” ...
- Delphi: 圆形进度(环形进度)
起源: 重回DC5项目,资源下载美工提供圆形进度条,复习Delphi,为实现其颇觉有趣,遂研究其. 最终效果图如下: 实现: 制作TCircleProgress控件,实现方法参照系统之TGauge控件 ...
- postman接口测试实例
牛刀小试项目 抽奖项目
- Xcode9 打包ipa(导出ipa测试包)时总是意外退出
今天用xcode9,打包ipa总是意外退出. 正处在测试阶段,所以打的也是测试包 ,路径是:Product -> Archive -> Export -> Save for Ad H ...
- SAP中的slashX
SlashX /n This terminates the transaction. 关闭当前事务. /nxxxx This terminates the current transaction, a ...