尽量避免使用void main()

本文探讨了C++中main函数的不同定义方式,并强调了避免使用void main()的原因。推荐使用int main()或int main(int argc, char *argv[])的形式来确保程序的稳定性和可预测性。

尽量不要使用void main(),因为其可能会有非预期的结果。

最好用以下两种方式:

第一种"int main()"
第二种"int main(int argc, char *argv[])"

好的,让我们深入探讨一下`void*`指针以及如何设计和使用包含它的函数。 ### `void *` 指针简介 在C语言中,`void *`是一种特殊类型的指针,它代表了一个可以指向任意数据类型的通用地址。这意味着你可以将任何类型的指针赋值给一个`void *`类型,并且可以在需要的时候再把它转换回原来的类型。需要注意的是,在标准C++中直接操作`void *`较少见,因为泛型编程有更安全的方式如模板(templates)。但在C语言里这非常常见用于编写高度灵活的库或API。 ### 包含`void *` 参数的函数示例及作用 当我们将`void *`作为形参传递给某个函数时,该函数能够接受任何形式的数据而无需关心其确切类型。这种特性对于创建“无类型”功能特别有用——即那些不依赖于特定数据结构的操作,例如内存分配、复制等基础任务。 ```c #include <stdio.h> #include <string.h> // 定义接收 void * 类型参数并返回同样类型的简单拷贝函数 void* my_memcpy(void* dest, const void* src, size_t num) { char* p_dest = (char*)dest; const char* p_src = (const char*)src; for(size_t i=0; i<num; ++i) p_dest[i] = p_src[i]; return dest; } int main(){ int source[5] = {1,2,3,4,5}; int destination[5]; // 调用自定义memcpy函数完成数组内容拷贝 my_memcpy(destination,source,sizeof(source)); printf("Copied array elements:\n"); for(int j : destination){ printf("%d ",j); } return 0; } ``` 在这个例子中,我们实现了一个简单的`my_memcpy()`函数来模拟标准库中的`memcpy()`的行为。由于源(`src`) 和目标 (`dest`) 地址都声明为了`void *` ,因此它可以处理各种不同类型的数据块之间的拷贝工作而不必担心底层的具体信息。 --- **注意点** - 当从`void *`转换到其他类型的指针时务必保证原始数据的实际布局与其所指定的目标类型相匹配; - 尽量避免过度滥用`void *`以免降低代码的安全性和可读性; --
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值