精选推荐

最新动态

C++怎么使用placement new_C++定位new操作详解【内存】

placement new 不是“另一种 new”,而是 operator new 的重载形式,它不分配内存,只在已有的内存地址上构造对象。你不能用它替代 new 去申请堆内存——它根本不会调用 ::operator new(size_t),也不会管理内存生命周期。

C++如何实现非阻塞I/O?(select/poll/epoll封装)

因为 select 的 fd_set 是固定大小(通常 1024),每次调用都要把整个位图从用户态拷贝到内核态,且内核需线性扫描所有 fd 判断就绪状态。连接数一过千,性能断崖式下降。

c# 构造函数和析构函数

构造函数不是普通方法,它没有返回类型(连 void 都不能写),名字必须和类名完全一致,且不能被显式调用。常见错误是加了 void 或拼错类名,编译器会直接报错:CS0501: ‘X.X()’ must declare a body because it is not marked abstract, extern, or partial。

c# dispose 和 finalizer 的区别

根本区别就一句话:Dispose() 是你控制的、可预测的资源释放;Finalize(即析构函数 ~ClassName())是 GC 在不确定时间、不确定线程上被动触发的“补救机制”。你不调用 Dispose(),程序可能跑着跑着就卡住或报“无法访问已关闭的文件”这类错误;你不写 Finalize,只要 Dispose() 写对了,系统照样稳如老狗。

c++中的RTTI是什么_c++运行时类型识别与dynamic_cast原理【详解】

RTTI 是 C++ 中“运行时类型识别”(Run-Time Type Identification)的缩写,核心作用是在程序运行期间,准确判断一个基类指针或引用实际指向的是哪个派生类对象。它不是语法糖,而是有明确运行时开销和使用前提的底层机制——只对含虚函数的多态类生效。

C++如何安全地进行向下类型转换(downcasting)?(dynamic_cast)

在 C++ 中,安全的向下类型转换必须依赖 dynamic_cast,且仅适用于**多态类型**(即含有至少一个虚函数的类)。它会在运行时检查转换是否合法,失败时返回空指针(对指针)或抛出 std::bad_cast 异常(对引用),从而避免未定义行为。