首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

为什么用transaction_safe 7、libstdc++和-fgnu-tm编译时,std::is_function不能识别fgnu函数?

在使用transaction_safe 7、libstdc++和-fgnu-tm编译时,std::is_function无法识别fgnu函数的原因是因为这些选项会启用事务内存(Transactional Memory)的支持,而fgnu函数是一种特殊的函数类型,它与事务内存机制有关。

事务内存是一种并发控制机制,用于解决多线程并发访问共享内存时可能出现的数据竞争问题。它通过将一系列内存操作组织成事务,保证这些操作要么全部执行成功,要么全部回滚,从而确保数据的一致性和并发访问的正确性。

在使用transaction_safe 7、libstdc++和-fgnu-tm编译时,编译器会对代码进行优化,将一些操作转换为事务操作。然而,std::is_function是用于判断类型是否为函数类型的模板类,它在编译时需要对类型进行解析和分析,而fgnu函数是一种特殊的函数类型,它与事务内存机制紧密相关,因此std::is_function无法正确识别fgnu函数。

要解决这个问题,可以考虑使用其他方式来判断函数类型,例如使用std::is_invocable、std::is_callable等模板类来判断函数类型。另外,也可以通过手动定义一个类型特征来判断函数类型,例如:

代码语言:cpp
复制
template<typename T>
struct is_fgnu_function {
    static constexpr bool value = /* 判断T是否为fgnu函数类型的逻辑 */;
};

// 使用示例
static_assert(is_fgnu_function<decltype(fgnu_function)>::value, "fgnu_function is not a fgnu function");

需要注意的是,以上方法仅适用于判断特定类型是否为fgnu函数类型,对于一般的函数类型判断仍然可以使用std::is_function。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • Linux下离线手动下载安装C++开发环境

    Linux下我们习惯了使用软件包管理器来安装我们需要的软件,比如Red Hat公司的Fedora、RHEL(Red Hat Enterprise Linux)和后来加入红帽的CentOS,使用rpm和yum来安装软件,Ubuntu使用apt-get来安装。 使用软件包管理器确实很方便,在联网的环境下,从下载到安装,以及自动关联软件的依赖项,并且一次安装所有依赖的软体包,为我们省去了很多繁琐的操作。这样确实很好,但是我们却失去了了解软件有哪些组成模块和依赖项的机会。下面我就要折腾一下,手动下载安装C++环境,摆托yum install gcc-c++ 这种傻瓜式操作。手动下载安装还有一个好处就是为不能联网的机器安装软件。有时候,确实要这样做。

    02

    cmake:动态链接库(so)中静态链接tcmalloc(gperftools2.4)暨静态链接libstdc++

    将tcmalloc作为动态库使用,非常方便,网上有很多资料介绍了。tcmalloc.a也可以以静态链接的方式加入应用程序中,大概因为使用太方便,网上关于这方面的介绍都是一笔带过,但是如果要在动态 库(so)中静态编译tcmalloc,却是有所不同的。 我的项目中有一个so动态库,需要在java中通过jni调用,因为涉及频繁的内存分配操作所以这个so希望用tcmalloc管理内存池以提高系统运行效率,如果使用以动态库方式使用tcmalloc。那么在应用服务器(tomcat)启动的时候,需要先设置LD_PRELOAD参数指向tcmalloc.so,然后执行startup.sh启动tomcat。这样以来,不仅是我的so库,整java程序在运行过程中的所有向操作系统申请释放内存的过程都交给了tcmalloc管理了,其实挺好的。使用这种方案,我的so库代码不需要在编译时链接tcmalloc,什么都不用改变,就能使用tcmalloc。 但是凡事有利就有弊,这个方案带的成本就是在系统安装、维护时稍显复杂:需要在服务器上安装tcmalloc和libunwind(应用系统运行在64位操作系统下),还可能需要修改tomcat启动脚本以加入LD_PRELOAD参数,对工程实施人员的要求比较高。

    01

    GCC 4.7相对4.6.x的改进点

    原文:http://www.iteye.com/news/24628 针对C的功能改进: 支持ISO C11标准中的更多特性。除了之前的-std=c1x和-std=gnu1x选项外,GCC现在还支持-std=c11和-std=gnu11选项。 针对C++的功能改进: g++现在支持-std=c++11、-std=gnu++11和-Wc++11-compat选项,这些选项的作用相同。 实现了C++11的extended friend语法。 实现了C++11的重写控制。 实现了C++11的非静态数据成员初始化。 实现了C++11的用户定义数据标识。 实现了C++11的别名声明。 实现了C++11的委托构造函数。 针对运行时库(libstdc++)的改进  实验性地支持新的ISO C++11标准: 增加了--enable-clocale=newlib配置选项。 用于无序关联容器的调试模式迭代器。 通过包含来避免破坏全局命名空间。

    03
    领券