C++ void*用法记录

void的字面意思是空类型,void *的意思是空类型指针,void 不是一个真正的类型,我们在声明变量的时候从来不会像下面这样声明:

void a;

如果我们写了一行这样的代码,某些编译器会直接报错,有些则不会,但也没有任何意义。


void真正的用途在下面两个方面:

  1. 对函数返回值的限定

  2. 对函数参数的限定



比如,函数没有返回值,那么函数可能会声明成这样:void fun(int a);

如果函数有返回值,但是函数没有参数,那么函数的可能会声明成这样:int fun(void)。


以上的情况都是很好理解的。下面介绍void *的一些用法。


1. 函数可接受任意类型的指针。

用过memset或者memcpy的细心的人会发现,在gcc中编译类似下面的代码都不会有警告:

int a;

int *p = &a;

memset(p, 0, 4);

或者

char c[4];

char *p = c;

memset(p, 0, 4);

为什么memset传int *还是char *都没有问题呢?我们知道不同类型间复制是要进行强制转换的,那么这里为什么不用强制类型转换呢。我们看memset的原型会发现,memset的第一个参数就是void *。


2. void *类型可以接受任意类型指针。

例如:

void *p1;

char *p2 = “hellp”;

p1 = p2;

这是没有问题的,任何类型的指针都可以直接赋值给它,无需进行强制类型转换。但需要注意的一点是,void *的类型并不能无需类型转换直接赋值给其他类型,比如malloc的返回值是void *,那么我们一般这样写:char *p = (char *)malloc(4);


3. void *类型不能做运算

比如我们不要做类似这样的操作:

void *p;

p++;

说白了void并不是一个真实的变量,void可以看作一个抽象概念。


以上说法由于C标准不同,可能有部分差异,需要特殊对待,但大体就是这样的。

C++,日志记录法是一种常见的调试技术,可以帮助我们在代码插入记录,以便在程序运行时查看信息和错误。下面是一个简单的示例,演示如何在C++使用日志记录法: ```cpp #include <iostream> #include <fstream> // 定义日志记录级别 enum LogLevel { LOG_LEVEL_DEBUG, LOG_LEVEL_INFO, LOG_LEVEL_WARNING, LOG_LEVEL_ERROR, }; // 定义日志记录器 class Logger { public: Logger() : m_logLevel(LOG_LEVEL_DEBUG) {} void setLogLevel(LogLevel level) { m_logLevel = level; } void log(LogLevel level, const std::string& message) { if (level < m_logLevel) { return; } std::ofstream file("log.txt", std::ios_base::app); file << "[" << getCurrentTime() << "] " << levelToString(level) << ": " << message << std::endl; } private: LogLevel m_logLevel; std::string getCurrentTime() { // 获取当前时间的代码 } std::string levelToString(LogLevel level) { // 将日志级别转换为字符串的代码 } }; int main() { Logger logger; // 设置日志记录级别 logger.setLogLevel(LOG_LEVEL_WARNING); // 记录日志 logger.log(LOG_LEVEL_DEBUG, "这是一个调试信息"); logger.log(LOG_LEVEL_INFO, "这是一个普通信息"); logger.log(LOG_LEVEL_WARNING, "这是一个警告信息"); logger.log(LOG_LEVEL_ERROR, "这是一个错误信息"); return 0; } ``` 在上面的代码,我们定义了一个`Logger`类,它可以记录不同级别的日志。我们可以使用`setLogLevel()`方法来设置日志记录级别,然后使用`log()`方法来记录日志。在`log()`方法,我们首先检查当前日志级别是否大于等于要记录的日志级别,如果是,就将日志记录到文件。 在实际应用,我们可能需要更复杂的日志记录器,例如支持多线程、异步日志等功能。但是,无论如何,日志记录法都是一种非常有用的调试技术,可以帮助我们更好地理解和调试代码。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值