• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

Golang n.Addr类代码示例

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

本文整理汇总了Golang中github.com/gocircuit/circuit/use/n.Addr的典型用法代码示例。如果您正苦于以下问题:Golang Addr类的具体用法?Golang Addr怎么用?Golang Addr使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。



在下文中一共展示了Addr类的5个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于我们的系统推荐出更棒的Golang代码示例。

示例1: Remove

// Remove removes the exported value with handle id from the table, if present.
// If present, a check is performed that importer is the same one, registered
// with the table. If not, an error is returned.
func (exp *expTabl) Remove(id circuit.HandleID, importer n.Addr) {
	if importer == nil {
		panic("cannot remove perm handles from exp")
	}
	exp.lk.Lock()
	defer exp.lk.Unlock()

	exph, present := exp.id[id]
	if !present {
		return
	}
	if importer.WorkerID() != exph.Importer.WorkerID() {
		panic("releasing importer different than original")
	}
	delete(exp.id, id)

	impTabl, present := exp.nonperm[exph.Importer.WorkerID()]
	if !present {
		panic("missing importer map")
	}
	delete(impTabl, exph.Value.Interface())

	if len(impTabl) == 0 {
		delete(exp.nonperm, exph.Importer.WorkerID())
	}
}
开发者ID:hanjin8307,项目名称:circuit,代码行数:29,代码来源:exp.go


示例2: RemoveImporter

func (exp *expTabl) RemoveImporter(importer n.Addr) {
	if importer == nil {
		panic("nil importer")
	}
	exp.lk.Lock()
	defer exp.lk.Unlock()

	impTabl, present := exp.nonperm[importer.WorkerID()]
	if !present {
		return
	}
	delete(exp.nonperm, importer.WorkerID())

	for _, exph := range impTabl {
		delete(exp.id, exph.ID)
	}
	runtime.GC()
}
开发者ID:hanjin8307,项目名称:circuit,代码行数:18,代码来源:exp.go


示例3: Dial

func (d *Dialer) Dial(addr n.Addr) (conn n.Conn, err error) {
	d.Lock()
	defer d.Unlock()
	//
	workerID := addr.WorkerID()
	s, present := d.open[workerID]
	if !present {
		// Make new session to worker if one not present
		s = d.sub.DialSession(addr.(*Addr).TCP, func() {
			d.scrub(addr.WorkerID())
		})
		if err = d.auth(addr, s.Dial()); err != nil {
			s.Close()
			return nil, err
		}
		d.open[workerID] = s
		go d.watch(workerID, s) // Watch for idleness and close
	}
	return NewConn(s.Dial(), addr.(*Addr)), nil
}
开发者ID:prodigeni,项目名称:circuit,代码行数:20,代码来源:dialer.go


示例4: exportPtr

// exportPtr returns *permPtrMsg if importer is nil, and *ptrMsg otherwise.
func (r *Runtime) exportPtr(v interface{}, importer n.Addr) interface{} {
	// Add exported value to export table
	exph := r.exp.Add(v, importer)
	// log.Printf("exporting %T with handle %s for importer %v", v, exph.ID.String(), importer)

	if importer == nil {
		return &permPtrMsg{ID: exph.ID, TypeID: exph.Type.ID}
	}

	// Monitor the importer for liveness.
	// DropPtr the handles upon importer death.
	r.lk.Lock()
	defer r.lk.Unlock()
	_, ok := r.live[importer.WorkerID()]
	if !ok {
		r.live[importer.WorkerID()] = struct{}{}

		// The anonymous function creates a "lifeline" connection to the worker importing v.
		// When this conncetion is broken, v is released.
		go func() {

			// Defer removal of v's handle from the export table to the end of this function
			defer func() {
				r.lk.Lock()
				delete(r.live, importer.WorkerID())
				r.lk.Unlock()
				// DropPtr/forget all exported handles
				r.exp.RemoveImporter(importer)
			}()

			conn, err := r.t.Dial(importer)
			if err != nil {
				// log.Println("problem dialing lifeline to", importer.String(), err.Error())
				return
			}
			defer conn.Close()

			if conn.Write(&dontReplyMsg{}) != nil {
				log.Println("problem writing on lifeline to", importer.String(), err.Error())
				return
			}
			// Read returns when the remote dies and
			// runs the conn into an error
			conn.Read()
		}()
	}
	return &ptrMsg{ID: exph.ID, TypeID: exph.Type.ID}
}
开发者ID:hanjin8307,项目名称:circuit,代码行数:49,代码来源:vexp.go


示例5: Add

func (exp *expTabl) Add(receiver interface{}, importer n.Addr) *expHandle {
	if receiver == nil {
		panic("bug: nil receiver in export")
	}

	exp.lk.Lock()
	defer exp.lk.Unlock()

	// Is receiver already exported in the respective perm/nonperm fashion?
	var impHere bool
	var impTabl map[interface{}]*expHandle
	if importer != nil {
		// Non-permanent case
		impTabl, impHere = exp.nonperm[importer.WorkerID()]
		if impHere {
			exph, present := impTabl[receiver]
			if present {
				return exph
			}
		}
	} else {
		// Permanent case
		if exph, present := exp.perm[receiver]; present {
			return exph
		}
	}

	// Build exported handle object
	//fmt.Printf("recv (%#T): %#v\n", receiver, receiver)
	typ := exp.tt.TypeOf(receiver)
	if typ.Type != reflect.TypeOf(receiver) {
		panic("bug: wrong type")
	}
	exph := &expHandle{
		ID:       circuit.ChooseHandleID(),
		Importer: importer,
		Value:    reflect.ValueOf(receiver),
		Type:     typ,
	}

	// Insert in handle map
	if _, present := exp.id[exph.ID]; present {
		panic("handle id collision")
	}
	exp.id[exph.ID] = exph

	// Insert in value map
	if importer != nil {
		// Non-permanent case
		if !impHere {
			impTabl = make(map[interface{}]*expHandle)
			exp.nonperm[importer.WorkerID()] = impTabl
		}
		impTabl[receiver] = exph
	} else {
		// Permanent case
		exp.perm[receiver] = exph
	}

	return exph
}
开发者ID:hanjin8307,项目名称:circuit,代码行数:61,代码来源:exp.go



注:本文中的github.com/gocircuit/circuit/use/n.Addr类示例整理自Github/MSDocs等源码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
Golang n.Conn类代码示例发布时间:2022-05-23
下一篇:
Golang errors.Unpack函数代码示例发布时间:2022-05-23
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap