C++实现golang chan 版本一

这篇博客探讨了用C++实现Golang中chan的概念,当前实现仍不完善,涉及线程锁的优化、selector模式的整合以及每个Chan对应独立线程的考虑。作者指出需要解决性能问题,如一个线程管理多个Chan,以及如何优雅地结束chan和处理未完成的数据。此外,还提及了阻塞和非阻塞通道的设计挑战。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这是我的一个简单例子,目前不够完善。

需要后续的优化,如,线程锁的更换,selector模式的加入,以及每个Chan依赖一个独立的线程,性能问题(一个线程管理多个Chan)。chan如何主动结束,程序结束时chan如何结束(通过数据未处理完)等等情况。阻塞式通道和非阻塞通道的设计!!!


Lock.h

#pragma once

#if defined(__cplusplus) && (__cplusplus >= 201103)
#include <thread>
typedef std::thread::id TID;
#else
// #error "not support c++11"
#if defined(WIN32) || defined(WIN64)
#include <windows.h>
typedef DWORD TID;
#elif defined(__linux__)
#include <pthread.h>  // 需要 -pthread
#include <unistd.h>
typedef pthread_t TID ;
#endif
#endif

#if defined(__cplusplus) && (__cplusplus >= 201103)
#include <mutex>
class VLock {
	std::mutex m_Lock; 
public:
	void Lock() {m_Lock.lock();}
	void UnLock() {m_Lock.unlock();};
	bool TryLock() {return m_Lock.try_lock();};
};
#else
//#error "not support c++11"
#if defined(WIN32) || defined(WIN64)
class VLock {
	CRITICAL_SECTION m_Lock ;
public:
	VLock() {InitializeCriticalSection(&m_Lock);}
	~VLock() {DeleteCriticalSection(&m_Lock);}
	void Lock() {EnterCriticalSection(&m_Lock);}
	void UnLock() {LeaveCriticalSection(&m_Lock);};
};
#elif defined(__linux__)
class VLock {
	pthread_mutex_t 	m_Mutex; 
public:
	VLock() {pthread_mutex_init( &m_Mutex , NULL );}
	~VLock() {pthread_mutex_destroy( &m_Mutex) ;}
	void Lock() {pthread_mutex_lock(&m_Mutex);}
	void UnLock() {pthread_mutex_unlock(&m_Mutex);};
};
#endif
#endif



//自动加锁解锁器
class AutoLock_T
{
public:
	AutoLock_T(VLock& rLock)
	{
		m_pLock = &rLock;
		m_pLock->Lock();
	}
	~AutoLock_T()
	{
		m_pLock->UnLock();
	}
protected:
private:
	AutoLock_T();
	VLock* m_pLock;
};



//当前线程挂起一定时间
extern void VSleep( unsigned int millionseconds = 0 ) ;

//获得当前线程ID
extern TID VGetCurrentThreadId( ) ;


Lock.cpp

#include "Lock.h"


void VSleep( unsigned int millionseconds ) {
#if defined(__cplusplus) && (__cplusplus >= 201103)
	std::this_thread::sleep_for(std::chrono::milliseconds(millionseconds));
#else
	// #error "not support c++11"
#if defined(WIN32) || defined(WIN64)
	Sleep( millionseconds ) ;
#elif defined(__linux__)
	usleep( millionseconds*1000 ) ;
#endif
#endif

}

TID VGetCurrentThreadId() {
#if defined(__cplusplus) && (__cplusplus >= 201103)
	return std::this_thread::get_id();
#else
	// #error "not support c++11"
#if defined(WIN32) || defined(WIN64)
	return GetCurrentThreadId( ) ;
#elif defined(__linux__)
	return pthread_self();
#endif
#endif

}

Thread.h

#pragma once

#include "Lock.h"

//当定义此宏时,所有线程将只执行一次后就推出。
//#define _EXEONECE 10

#if defined(WIN32) || defined(WIN64)
DWORD WINAPI MyThreadProcess( void* derivedThread );
#elif defined(__linux__)
void
<think>嗯,用户想讨论Golang的发展前景,首先我需要收集关于Go语言的现状和趋势的信息。根据引用[2],Go在微服务、云计算和分布式系统领域应用广泛,国内行情也不错。那我可以从行业现状、技术优势、未来趋势这几个方面来组织回答。 首先,行业需求方面,云计算和微服务的兴起确实推动了Go的普及,像Docker和Kubernetes这样的项目都是用Go写的,这对就业市场有影响。然后技术优势,Go的并发模型和高效执行速度是它的卖点,适合高并发场景,比如电商和金融科技。接着未来趋势,云原生和国产化替代可能是关键点,引用[2]提到大龄程序员的转型,可能和Go的简洁性有关,适合快速开发。 还要考虑用户可能的深层需求,比如是否想转行Go或者评估学习价值。需要提到学习资源和社区生态,比如国内有哪些公司在用,是否有足够的文档和支持。另外,对比其他语言,比如Python和JavaScript,Go在性能上的优势,但可能在泛型等特性上还有改进空间。 注意引用格式,用户提供的引用[2]详细讨论了国内行情和趋势,可以引用这部分。其他引用如[1]和[3]提到多语言的重要性,但可能相关性不大,但可以稍微提及掌握多种语言的优势。不过用户的问题集中在Go的前景,所以重点放在引用[2]的内容。 最后,生成的相关问题需要围绕Go的应用场景、学习难度、与其他语言的对比,以及性能优化等,这样用户如果有后续疑问,可以引导他们深入探讨。</think>### Go语言(Golang)发展前景分析 #### 1. **行业需求与现状** - **云计算与微服务**:Go语言凭借高并发、低延迟的特性,在云计算和微服务领域占据重要地位。例如,Docker和Kubernetes等核心云原生工具均基于Go开发,推动其成为云基础设施的“标配语言”[^2]。 - **国内行情**:国内互联网大厂(如字节跳动、腾讯、阿里)广泛使用Go构建高并发服务,例如抖音的后端服务曾通过Go实现性能优化。 - **就业市场**:Go开发岗位需求持续增长,尤其在分布式系统、区块链和实时通信领域,薪资水平普遍高于Java/PHP等传统语言。 #### 2. **技术优势** - **高效编译与执行**:Go编译速度快,生成的可执行文件轻量,适合快速迭代和部署。 - **并发模型**:通过`goroutine`和`channel`实现轻量级并发编程,显著降低多线程开发复杂度。 - **语法简洁**:去除了继承和类等复杂概念,强制代码格式化,提升团队协作效率。 #### 3. **未来趋势** - **云原生深化**:随着企业上云进程加速,Go在服务网格(如Istio)、Serverless架构中的应用将进步扩大。 - **国产化替代**:在信创背景下,Go可能成为替代C/C++的部分场景(如中间件开发)的候选语言。 - **生态扩展**:社区持续完善框架(如Gin、Beego)和工具链(如Go Modules),推动其在AI推理、边缘计算等新兴领域的探索。 #### 4. **挑战与改进** - **泛型支持**:Go 1.18引入泛型,但需时间验证其大规模应用效果。 - **生态多样性**:相比Java/Python,Go在机器学习、数据分析等领域的库仍待丰富。 ```go // 示例:Go语言的并发模型实现 package main import "fmt" func main() { ch := make(chan string) go func() { ch <- "Hello, Golang!" }() // goroutine msg := <-ch fmt.Println(msg) } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值