草庐IT

native-base

全部标签

c++ - 为什么 std::ios_base::sync_with_stdio 没有在 libc++ (clang) 中实现?

让我们看一下这个代码示例:#includeintmain(){std::ios_base::sync_with_stdio(false);intn;std::cin>>n;for(inti=0;i>buf;}}此代码示例对这样的输入的性能:1000000001...9999999在我的机器上:g++-5-O2-std=c++11:./a.outclang-700.0.72-O2-std=c++11:./a.out经过一些分析后,我发现libc++根本没有禁用同步。然后我查看了他们的代码,发现了这个:https://github.com/llvm-mirror/libcxx/blob/6

c++ - 将 std::map<int, std::shared_ptr<Base>> 转换为 std::map<int, std::shared_ptr<Derived>> 的最有效安全方法

我们目前存储了几个不同的数据模型集合,如下所示:std::map>>models;字符串映射到一个已知的类型列表,这都是通过序列化处理的。嵌套映射包含“对象ID”和关联(反序列化)std::shared_ptr的集合DataObject是一个基类,我们从中派生出多种类型。我们有一个方法来获取给定类型的所有数据对象:staticstd::map>*getAll(std::stringtype);这只是在给定的“类型”键处返回指向map的指针。今天我遇到了一个代码审查来添加我认为调用UB但似乎起作用的以下内容。这让我有点紧张并寻找有效的解决方案:templatestaticstd::map

c++ - 在 C++ 中显式转换为 native 类型

我正在尝试为不支持longlong的编译器编写一个实现64位整数的类,以便在现有代码中使用。基本上,我应该能够在某个地方有一个typedef来选择我是想使用longlong还是我的类,其他一切都应该编译和工作。因此,我显然需要从int、long等转换构造函数,以及到这些类型的相应转换运算符(强制转换)。这似乎会导致算术运算符出错。对于native类型,编译器“知道”当operator*(int,char)被调用时,它应该将char提升为int并且调用operator*(int,int)(而不是将int转换为char,例如)。在我的例子中,它混淆了各种内置运算符和我创建的运算符。在我看来

c++ - 为 X86 创建 native 应用程序?

有没有一种方法可以让我制作一个C或C++程序,它可以在没有操作系统的情况下运行,并且会在左上角绘制一个红色像素之类的东西?我一直想知道这些类型的应用程序是如何制作的。由于Windows是用C编写的,我想有一种方法可以做到这一点。谢谢 最佳答案 如果你正在为一个裸处理器编写代码,根本没有库支持,你将不得不获取所有硬件手册,弄清楚如何访问你的显存,并执行硬件需要的任何操作以获得一个绘制到显示器上的像素(或蜂鸣器上的声音,或从磁盘读取的内存块,或其他)。当您使用操作系统时,您将依赖设备驱动程序来了解这一切。每天仍在为没有操作系统的平台编写

c++ - 智能指针 : cast between base and derived classes

假设你有这样一个函数:SmartPtrdoSomething(SmartPtra);像这样的类:classA{}classB:publicA{}现在我这样做:SmartPtrfoo=newB();doSomething(foo);现在,我想取回一个SmartPtr来自doSomething的对象.SmartPtrb=doSomething(foo);这可能吗?我需要做什么样的选角?现在,我刚发现一些我认为丑陋的东西:B*b=(B*)doSomething().get()重要说明:我无权访问SmartPtr和doSomething()代码。 最佳答案

c++ - 将 vector<shared_ptr<Derived>> 传递给需要 vector<shared_ptr<Base>> 的函数

我使用的代码结构有问题,如下(简化):classSPoint{public:SPoint(doublex,doubley,doublez):_x(x),_y(y),_z(z){}protected:double_x,_y,_z;}classPoint3D:publicSPoint{public:Point3D(doublex,doubley,doublez):SPoint(x,y,z){//defaultvaluesforUandV}protected:doubleU,V;}这些点用于创建折线:classSPolyline{public:SPolyline(constvector>&p

c# - 将 SYSTEMTIME( native C++)转换为日期时间 (C#)

我有一个与C#服务器通信的C++客户端,并且我有针对用户定义类型的自定义序列化。现在我需要将日期和时间结构从C++传递到C#。谷歌搜索导致了以下方法:在SYSTEMTIME结构中填写日期/时间(这不是当前系统时间,而是程序根据一定条件填写)将SYSTEMTIME转换为FILETIME将FILETIME转换为__int64(这给出了一个64位值,表示从1601年1月1日开始的100纳秒间隔数)在构造函数中将此64位值用于C#中的DateTime。只是为了试水,我写了2个片段,一个是用(原生)C++编写的,用于执行步骤1、2、3,另一个是用C#编写的,用于执行步骤4。还没有从C++到C#的

eclipse报错Errors running builder ‘Android Package Builder‘ on project ‘xxx‘. sun/misc/BASE64Encoder

eclipse报错Errorsrunningbuilder‘AndroidPackageBuilder’onproject‘xxx’.sun/misc/BASE64Encoder由于毕设是需要用到安卓,所以这段时间都在学习安卓开发的相关知识,碰到了如下的问题,困扰了许久,今晚终于解决了,发出来给有需要的人参考一下~本人是小白,第一次发博客,如有说的不对的地方,还望大佬们指正[抱拳]。问题描述搭建完eclipse环境之后,运行安卓项目一直不成功,一直报如下的错误:Errorsrunningbuilder'AndroidPackageBuilder'onproject'Myapplication'

c++ - 当 Base 和 Derived 都使用 Derived 类型参数进行模板化时调用 Base 构造函数时出现编译器错误

我很难理解为什么以下代码无法编译:templateclassBase{public:Base(inta){}};templateclassDerived:publicBase{public:Derived(inta):Base(a){}};intmain(){}在我的编译器(gcc5.4.0withC++11)上输出错误信息error:class'Derived'doesnothaveanyfieldnamed'Base'Derived(inta):Base(a){}我看到这有点类似于Templatebaseconstructorcallinmemberinitializationli

c++ - Derived from two Bases - 删除 vector **奇怪**问题

这个问题在这里已经有了答案:Whentousevirtualdestructors?(20个答案)关闭4年前。我花了几个小时试图找出问题出在哪里,但它看起来很奇怪。我以更容易理解的方式重写了我的问题。当它到达它说删除的行时,调试程序会创建一个断点。附言。有趣的是,如果我们采用intb1并将其移动到Base2,它就可以工作。基数1:#pragmaonceclassBase1{public:Base1();~Base1();intb1;};Base2.h:#pragmaonce#include#includeclassDerived;classBase2{public:Base2();~B