当你命名你的源文件时*.c
,MSVC假定它正在编译C,这意味着C89。所有块本地变量都需要在块的开头声明。
解决方法包括:
- 在代码块的开始部分声明/初始化所有局部变量(紧接在大括号之后
{
) - 将源文件重命名为
*.cpp
或等效并编译为C ++。 - 升级到VS 2013,放宽这个限制。
示例:
下面程序会报错
//最简单的创建多线程实例
#include<stdio.h>
#include<windows.h>
//子线程函数
DWORD WINAPI ThreadFun(LPVOID pm)
{
printf("子线程的线程ID号为:%d\n 子线程输出Hello World\n",GetCurrentThreadId());
return 0;
}
//主函数,所谓主函数其实就是主线程执行的函数
int main()
{
//HANDLE handle=CreateThread(NULL,0,ThreadFun,NULL,0,NULL);
printf("最简单的创建多线程实例\n");
printf("--by MoreWindows(http://blog.csdn.net/MoreWindows)--\n\n");
HANDLE handle=CreateThread(NULL,0,ThreadFun,NULL,0,NULL);//注意这个位置
WaitForSingleObject(handle,INFINITE);
//WaitForSingleObject(CreateThread(NULL,0,ThreadFun,NULL,0,NULL),INFINITE);
return 0;
}
代码没问题
怀疑是纯C环境 比较老的版本
所以要求变量定义只能在开头
//最简单的创建多线程实例
#include<stdio.h>
#include<windows.h>
//子线程函数
DWORD WINAPI ThreadFun(LPVOID pm)
{
printf("子线程的线程ID号为:%d\n 子线程输出Hello World\n",GetCurrentThreadId());
return 0;
}
//主函数,所谓主函数其实就是主线程执行的函数
int main()
{
HANDLE handle=CreateThread(NULL,0,ThreadFun,NULL,0,NULL);//放到最开始的地方就不会报错了
printf("最简单的创建多线程实例\n");
printf("--by MoreWindows(http://blog.csdn.net/MoreWindows)--\n\n");
//HANDLE handle=CreateThread(NULL,0,ThreadFun,NULL,0,NULL);
WaitForSingleObject(handle,INFINITE);
//WaitForSingleObject(CreateThread(NULL,0,ThreadFun,NULL,0,NULL),INFINITE);
return 0;
}
这样编译器就没有报错了。