开源 企业版 高校版 私有云 模力方舟 AI 队友
代码拉取完成,页面将自动刷新
开源项目 > 程序开发 > 编程语言/脚本语言 &&
捐赠
捐赠前请先登录
扫描微信二维码支付
取消
支付完成
支付提示
将跳转至支付宝完成支付
确定
取消
13 Star 69 Fork 22

johnsonyl/cpps

加入 Gitee
与超过 1400万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
已有帐号? 立即登录
文件
v1.0.2
分支 (1)
标签 (4)
master
v1.0.3-beta
v1.0.3
v1.0.2
v1.0.0
v1.0.2
分支 (1)
标签 (4)
master
v1.0.3-beta
v1.0.3
v1.0.2
v1.0.0
克隆/下载
克隆/下载
提示
下载代码请复制以下命令到终端执行
为确保你提交的代码身份被 Gitee 正确识别,请执行以下命令完成配置
初次使用 SSH 协议进行代码克隆、推送等操作时,需按下述提示完成 SSH 配置
1 生成 RSA 密钥
2 获取 RSA 公钥内容,并配置到 SSH公钥
在 Gitee 上使用 SVN,请访问 使用指南
使用 HTTPS 协议时,命令行会出现如下账号密码验证步骤。基于安全考虑,Gitee 建议 配置并使用私人令牌 替代登录密码进行克隆、推送等操作
Username for 'https://gitee.com': userName
Password for 'https://userName@gitee.com': # 私人令牌
v1.0.2
分支 (1)
标签 (4)
master
v1.0.3-beta
v1.0.3
v1.0.2
v1.0.0
cpps
/
src
/
cpps_new.cpp
cpps
/
src
/
cpps_new.cpp
cpps_new.cpp 3.55 KB
一键复制 编辑 原始数据 按行查看 历史
johnsonyl 提交于 2023年12月06日 16:41 +08:00 . cpps 增加tcmalloc支持
#include "cpps/cpps.h"
#ifdef USE_NEDMALLOC
#include "nedmalloc.h"
#endif
cpps::memory_allocal::memory_allocal()
{
handler = NULL;
_real = false;
mainthreadid = 0;
}
cpps::memory_allocal::~memory_allocal()
{
if (_real) {
#ifdef _DEBUG
handler->dump();
#endif
delete handler;
handler = NULL;
}
}
void cpps::memory_allocal::init(cpps_alloc_f _alloc_func, cpps_free_f _free_func)
{
if (handler == NULL) {
_real = true;
mainthreadid = cpps_this_thread_get_id();
handler = new memory_allocal_handler();
handler->cpps_set_allocf(_alloc_func, _free_func);
}
}
bool cpps::memory_allocal::global()
{
return !(_real && mainthreadid == cpps_this_thread_get_id());
}
cpps::memory_allocal_handler* cpps::memory_allocal::gethandler()
{
return handler;
}
void cpps::memory_allocal::sethandler(memory_allocal_handler* h)
{
handler = h;
}
cpps::memory_allocal& cpps::memory_allocal::instance()
{
static memory_allocal ins;
return ins;
}
cpps::memory_allocal_handler::memory_allocal_handler()
{
alloc_func = NULL;
free_func = NULL;
}
void* cpps::memory_allocal_handler::mmalloc(size_t __size, const char* file, unsigned int _line)
{
if (alloc_func != NULL) return alloc_func(__size);
#ifdef USE_NEDMALLOC
void* ret = nedalloc::nedmalloc(__size);
#else
#ifdef _WIN32
//__size = (size_t)ceil(__size / 1024.0) * 1024;
//void* ret = (PBYTE)VirtualAlloc(NULL, __size, MEM_COMMIT, PAGE_READWRITE);
__size++;
char* ret = memory_allocal::instance().global() ? (char*)VirtualAlloc(NULL, __size, MEM_COMMIT, PAGE_READWRITE) : (char*)malloc( __size) ;
ret[0] = memory_allocal::instance().global() ? 1 : 0;
ret = ret + 1;
//if(memory_allocal::instance().global())
//printf("alloc %s memory...\n", memory_allocal::instance().global() ? "global" : "local");
#else
void* ret = malloc(__size);
#endif
#endif
#ifdef _DEBUG
#ifdef _WIN32
if (ret == NULL) {
system("pause");
}
#endif
_lock.lock();
_size += __size;
memorylist.insert(memory_info_list::value_type(ret, new memory_info(__size, file, _line)));
_lock.unlock();
#endif
return ret;
}
void cpps::memory_allocal_handler::mfree(void* m)
{
if (free_func != NULL) { free_func(m); return; }
#ifdef _DEBUG
_lock.lock();
auto it = memorylist.find(m);
if (it != memorylist.end()) {
auto info = it->second;
_size -= info->size;
delete info;
memorylist.erase(it);
}
_lock.unlock();
if (m == NULL) {
system("pause");
}
#endif
#ifdef USE_NEDMALLOC
nedalloc::nedfree(m);
#else
#ifdef _WIN32
if (m) {
//printf("Thread ID:%d release Address: %I64d \r\n", GetCurrentThreadId(), (size_t)m);
char* p = (char*)m;
p = p - 1;
p[0] == 1 ? VirtualFree(p, 0, MEM_RELEASE) : free(p);
}
#else
if(m) free(m);
#endif
#endif
}
void cpps::memory_allocal_handler::cpps_set_allocf(cpps_alloc_f _alloc_func, cpps_free_f _free_func)
{
alloc_func = _alloc_func;
free_func = _free_func;
}
#ifdef _DEBUG
size_t cpps::memory_allocal_handler::size()
{
return _size;
}
void cpps::memory_allocal_handler::dump()
{
_lock.lock();
if (!memorylist.empty()) {
char outFileName[256];
//ȡεͳɦ
sprintf(outFileName, "%s_%d.log", "dump_no_delete_memory.txt", rand());
FILE* pFile = fopen(outFileName, "wb+");
std::string out;
for (auto it : memorylist) {
auto info = it.second;
char buffer[10240];
sprintf(buffer, "file :%s line:%d \r\n", info->file, info->line);
fwrite(buffer, strlen(buffer), 1, pFile);
}
fclose(pFile);
}
_lock.unlock();
}
#endif
Loading...
举报
举报成功
我们将于2个工作日内通过站内信反馈结果给你!
请认真填写举报原因,尽可能描述详细。
请选择举报类型
取消
发送
误判申诉

此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。

如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。

取消
提交

简介

CPPS是一种轻量级的嵌入式脚本语言,其语法类似于C++。它具有当前主流语言的许多特性,包括协程、面向对象、lambda、闭包、泛型变量、自定义模块支持、GC垃圾收集和跨平台。CPPS将程序解释为字节码,通过内置语法解析在虚拟机中运行
取消

发行版 (3)

全部

开源评估指数源自 OSS-Compass 评估体系,评估体系围绕以下三个维度对项目展开评估:

1. 开源生态

  • 生产力:来评估开源项目输出软件制品和开源价值的能力。
  • 创新力:用于评估开源软件及其生态系统的多样化程度。
  • 稳健性:用于评估开源项目面对多变的发展环境,抵御内外干扰并自我恢复的能力。

2. 协作、人、软件

  • 协作:代表了开源开发行为中协作的程度和深度。
  • 人:观察开源项目核心人员在开源项目中的影响力,并通过第三方视角考察用户和开发者对开源项目的评价。
  • 软件:从开源项目对外输出的制品评估其价值最终落脚点。也是开源评估最"古老"的主流方向之一"开源软件" 的具体表现。

3. 评估模型

    基于"开源生态"与"协作、人、软件"的维度,找到与该目标直接或间接相关的可量化指标,对开源项目健康与生态进行量化评估,最终形成开源评估指数。

贡献者

全部

近期动态

不能加载更多了
编辑仓库简介
简介内容
主页
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
C++
1
https://gitee.com/cppscript/cpps.git
git@gitee.com:cppscript/cpps.git
cppscript
cpps
cpps
v1.0.2
点此查找更多帮助

搜索帮助

评论
仓库举报
回到顶部
登录提示
该操作需登录 Gitee 帐号,请先登录后再操作。
立即登录
没有帐号,去注册

AltStyle によって変換されたページ (->オリジナル) /