草庐IT

linux-standard-base

全部标签

c++ - 将 Derived*const 转换为 Base*const

编辑-将问题置于上下文中。给定:structBase{...};structDerived:publicBase{...};classAlice{Alice(Base*const_a);...};classBob:publicAlice{Bob(Derived*const_a);...};当我尝试实现时Bob::Bob(Derived*const_d):Alice(static_cast(_d)){}它不起作用。const_cast对我来说没有意义,因为我不想更改常量,而且我没有更改我指向的内容,那么为什么g++会告诉我invalidstatic_castfromtype‘Derive

c++ - 将 raw operator new、placement new 和 standard delete 结合起来是否合法?

伙计们!出于好奇——以下代码可能不合法,对吗?T*p=::operatornew(sizeof(T));//allocatememoryforaTnew(p)T;//constructaTintotheallocatedmemorydeletep;//deletetheobjectusingthestandarddeleteoperator 最佳答案 没有。您只能删除从新返回的内容-没有异常(exception)。 关于c++-将rawoperatornew、placementnew和s

c++ - 是否有从代码库中删除第三方 C 和 C++ 库的好技巧或工具? (OS X 或 Linux)

我正在减少和隔离我对某些库的使用。我编写的许多现有程序直接使用这些库。我想要编译器(在这种情况下是GCC和/或Clang)或一些工具来帮助我在我的代码库中识别这些用途。简而言之,我想在整个代码库中毒害这些库的使用,除了它们将由一个库使用,并且一个库将对我的代码库中的其他模块可见。问题:1)你知道可以帮助我解决这个问题的工具吗?2)或者你能推荐一些策略来使这个过程更容易吗?条件和详情:删除它们的包含不是一种选择。由于我的代码库的大小和我想要隔离的符号数量,搜索无效。考虑到代码库的复杂性和要删除的符号数量,使用重构工具将过于乏味。由于第三方库中声明的数量,单独弃用符号不是一种选择。第三方库

【Linux】SystemV IPC

进程间通信一、SystemV共享内存1.共享内存原理2.系统调用接口(1)创建共享内存(2)形成key(3)测试接口(4)关联进程(5)取消关联(6)释放共享内存(7)测试通信3.共享内存的特性二、SystemV消息队列(了解)1.SystemV消息队列原理2.系统调用接口(1)创建消息队列(2)形成key(3)发送/接收数据(4)释放消息队列三、IPC在内核中的数据结构设计四、SystemV信号量1.引入概念2.理解信号量3.了解系统调用接口(1)申请信号量(2)释放信号量(3)操作信号量一、SystemV共享内存1.共享内存原理那么我们知道,进程间通信的本质就是先让不同的进程看到同一份资源

c++ - 在 C : Derived to base conversions 中包装 C++

我正在将一个简单的C++继承层次结构包装到“面向对象的”C中。我试图弄清楚在将指向C++对象的指针视为指向不透明C结构的指针时是否存在任何问题。特别是在什么情况下派生到基的转换会出现问题?类本身比较复杂,但层级较浅,仅采用单继承://AbaseclasswithlotsofimportantsharedfunctionalityclassBase{public:virtualvoidsomeOperation();//Moreoperations...private://Data...};//OneofseveralderivedclassesclassFirstDerived:pub

Linux系统安全:安全技术 和 防火墙

一、安全技术入侵检测系统(IntrusionDetectionSystems):特点是不阻断任何网络访问,量化、定位来自内外网络的威胁情况,主要以提供报警和事后监督为主,提供有针对性的指导措施和安全决策依据,类似于监控系统一般采用旁路部署(默默的看着你)方式。入侵防御系统(IntrusionPreventionSystem):以透明模式工作,分析数据包的内容如:溢出攻击、拒绝服务攻击、木马、系统漏洞等进行准确的分析判断,在判定为攻击行为后立即予以阻断,主动而有效的保护网络的安全,一般采用在线部署方式。(必经之路)防火墙(FireWall):隔离功能,工作在网络或主机边缘,对进出网络或主机的数据

Linux 上的 Wayland 是什么?它与 X 有何不同?

导读Wayland是 Linux 发行版的替代窗口系统。它取代了老化的X11标准。由于它需要修改应用程序才能使用它,因此迄今为止采用速度很慢。在撰写本文时,增强的安全性是相对于X11的主要优势。X11或XWindow系统可让您的图形桌面环境显示和控制窗口。Wayland是X11的替代品。它的设计速度更快、更安全。以下是您需要了解的有关它们的信息。什么是Wayland?Wayland是X11的现代替代品,几十年来X11一直是Linux上的默认窗口系统。Wayland是一种通信协议,定义XWindow显示服务器和客户端应用程序之间的消息传递。Wayland项目提供了客户端和服务器库,使应用程序能够

Linux中普通用户如何使用sudo指令提升权限

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档目录前言普通用户为何无法使用sudo?我们来看一下具体操作总结前言世上有两种耀眼的光芒,一种是正在升起的太阳,一种是正在努力学习编程的你!一个爱学编程的人。各位看官,我衷心的希望这篇博客能对你们有所帮助,同时也希望各位看官能对我的文章给与点评,希望我们能够携手共同促进进步,在编程的道路上越走越远!提示:以下是本篇文章正文内容,下面案例可供参考普通用户为何无法使用sudo?我们来举一个例子:你是一个学校的老师,你每天上下班教学生上课,出入的校门次数多了,学校门口的保安大爷,就会对你熟悉,知道你是这个学校的老师,不会让你出示证明,会放

c++ - "the procedure entry point _ZNSt8_detail15_List_node_base7_M_hookEPS0_ could not be located in the dynamic link library libstdc -6.dll."

有个小问题。我有C++代码,它链接到一些库。我以前有源代码的(原始)exe,它在第一台机器上运行完美。还有第二台机器,我在那里处理源代码,更改它,等等。在第二台机器上,该源代码的构建工作正常,当我复制second.exe并尝试在第一台机器上运行它时萌芽它显示错误信息"theprocedureentrypoint_ZNSt8_detail15_List_node_base7_M_hookEPS0_couldnotbelocatedinthedynamiclinklibrarylibstdc++-6.dll."有一件事,second.exe被复制到与original.exe相同的文件夹中,

C++ linux检测所有串口

有没有一种很好的方法来检测所有连接到Linux串行端口上的连接设备?我正在用C++编程,但也欢迎使用其他示例。您可以尝试打开每个端口,当它成功时,您将其添加到端口列表中,但这似乎不是一个很好的解决方案。您可以进入开发主管,因为我的串行端口是USB端口,所以我可以检查哪些ttyUSB..文件已生成。但这不适用于非USB串行端口,因为tty0到tty63的文件始终位于此目录中。我的例子:std::stringport;intfdstd::vector>list;for(inti=0;i谢谢! 最佳答案 在Linux中枚举设备的标准方法是