温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

C++中怎么使用非模板核心实现提供稳定的ABI接口

发布时间:2021-11-24 10:50:28 来源:亿速云 阅读:136 作者:iii 栏目:大数据

这篇文章主要介绍“C++中怎么使用非模板核心实现提供稳定的ABI接口”,在日常操作中,相信很多人在C++中怎么使用非模板核心实现提供稳定的ABI接口问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C++中怎么使用非模板核心实现提供稳定的ABI接口”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

T.84:使用非模板核心实现提供稳定的ABI接口

Reason(原因)

Improve stability of code. Avoid code bloat.

提高代码的稳定性。避免代码膨胀。

Example(示例)

It could be a base class:

它可以作为基类存在:

struct Link_base {   // stable
   Link_base* suc;
   Link_base* pre;
};

template<typename T>   // templated wrapper to add type safety
struct Link : Link_base {
   T val;
};

struct List_base {
   Link_base* first;   // first element (if any)
   int sz;             // number of elements
   void add_front(Link_base* p);
   // ...
};

template<typename T>
class List : List_base {
public:
   void put_front(const T& e) { add_front(new Link<T>{e}); }   // implicit cast to Link_base
   T& front() { static_cast<Link<T>*>(first).val; }   // explicit cast back to Link<T>
   // ...
};

List<int> li;
List<string> ls;

Now there is only one copy of the operations linking and unlinking elements of a List. The Link and List classes do nothing but type manipulation.

(虽然例示了两个List类,)对于List的关联和非关联元素来讲,只有一套操作(函数)的拷贝。Link和List除了类型操作之外不做任何事。

Instead of using a separate "base" type, another common technique is to specialize for void or void* and have the general template for T be just the safely-encapsulated casts to and from the core void implementation.

除了使用独立的“基础”类型,另外一个通用技术是定义基于void和void*类型的核心实现并准备一个目的仅限于安全地封装从或到void核心实现进行转换的通用模板类。

Alternative: Use a Pimpl implementation.

其他选项:使用指向实现的指针技术来实现。

到此,关于“C++中怎么使用非模板核心实现提供稳定的ABI接口”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI