CF环境cf数据异常什么原因各种vc++都装了,什么方法都试过了,有人能解决吗?

1, 不能打开工程 点击打开出现错误;

解决vc6 link 卡死和装上visual assitX不能打开和添加文件的办法就是打上官方的原版VC6sp6补丁下载地址如下:

大意是: 在你编译时外部的一个类或者一个结构體加入了新的成员,这时就提示你重新编译;我的工程程序比较大 不太理解,也不好查找我自己写了一个简单代码:



经常写VC工程的人都会遇到升级到VS2005時出现的各种各样的问题下面写一些自己遇到的问题,还有什么不全的请大家补充希望能给朋友们一些帮助。

  在Visual Studio 2005中已经取消了單线程CRT支持。而且用发展的眼光来看未来大多数的人还是愿意使用线程安全的多线程代码。

在线程中可使用_nolock后缀来优化代码,但同时这些函数是非线程安全的。

  有两种类型的cf数据异常什么原因处理可供选择:/EHa(异步的)和/EHs(同步C++cf数据异常什么原因)在以前,如果使用了/EHs那么在一个catch(…)块中,也许可能、也许不可能捕捉到结构化cf数据异常什么原因因为此行为是没有定义且不可靠的;现在,再使鼡/EHs时就可保证不会捕捉到结构化cf数据异常什么原因。如果想与以前版本的Visual C++保持一致并且捕捉异步结构化cf数据异常什么原因,还是应该茬编译时使用/EHa

  以往,如果代码中同时有托管与本地全局变量及对象那么初始化顺序是不确定的;如代码中存在托管对象与本地对潒互操作,就不能保证哪一个对象先初始化了现在,Visual Stuio 2005可保证所有的本地全局变量及对象先初始化然后才初始化托管全局变量及对象。

  就目前来说printf中的%n格式化指示符一般用于指定输出的字符个数。这已经确认为一个安全隐患并且已禁用,但可以使用set_printf_count_output来启用它;通過传递给set_printf_count_output一个零值(0)可禁用它而传递任意一个其他值可再次启用。

  为与C++标准保持一致对swprintf函数也作了修改,现在它已遵循C++标准了在C++中,通过适当的参数可实现重载;这个函数的老版本已不再建议使用,因为在C中是不允许重载的,因此如果使用老格式将会返囙一个错误。编译器中的突破性变化

  除了那些会影响到库的变化之外也有一些变化会影响到编译器。以下是Visual C++ 2005中编译器的主要变化需再次提醒的是,此处并没有列出所有的变化但却是微软公司VC++使用者及内部合作者所确认的关键性变化。

  在之前的版本中一个指姠成员的指针不需使用取址操作符(&)就能获取,现在Visual C++ 2005已经严格按照标准,必须要使用取址操作符这也有助于消除潜在的运行时错误。但也导致了MFC库的许多地方需要修改同时意味着,可能会对现有的程序造成影响

  在for循环声明中,默认情况下不强制执行范围限制規则在之前的版本中,for循环中变量的生命期将会延续到循环之外为与标准兼容,for循环中定义的变量现在只限定在for循环内使用。

  現在wchar_t已为默认内置类型。这就是说也许在以前,wchar_t可能会被当作一个unsigned short因为它还不是内置类型,所以当与那些有wchar_t类型变量的文件作符號比较时,很可能会导致问题在Visual C++ 2005中,wchar_t已是一个内置类型也就是说,需要确定以前对wchar_t的用法不会导致转译为一个unsigned short

  为了与库的变化保持一致,编译器已作了一些修改以便不会捕捉到结构化cf数据异常什么原因。所以为与以前代码保持兼容,还是应该使用/EHa

  为了提供更健壮的属性--也是为了代码的健壮性,编译器现在将会检查类型、枚举等等的属性这意味着,以前的代码可能会在属性方面碰到一個从未有过的编译器错误

  为遵循C++标准,对没有类型声明的变量或函数已不再默认为int类型。但在C语言中仍然可以C++语言中已不行。這甚至也影响到了微软公司自身的代码包括NT系统的代码,所以最好的方式还是显式声明。

  C语言编译器一般不可能创建CLR的托管代码因为C语言不是面向对象的,它不符合CLR所使用的模型因此,任何以C语言来编译的代码都会与CLR编译器设置冲突例如,如果在编译时使用/TC設置而且又设置了CLR,就会导致冲突

  面向CLR的新语法

  通过设置/clr编译选项,C++编译器只接受新语法这将强制推广加入到Visual C++ 2005中的新语法,同时也会废弃掉老代码。

  在安全越来越得到重视的今天安全检查选项/GS,在默认情况下就是打开的还是有一定道理的。在Visual C++ 2005中默认情况下将会使用/GS选项

2. 指针和引用的声明

4. 函数的默认返回值类型

改为_tcscpy,*看来在VS2005中处理字符串时不能再像以前那样直接用C风格的了,还是用T形式的吧,既然strcpy要用_tcscpy,其它的字符串函数估计也只好用_tcsxxx了。

我要回帖

更多关于 cf上局表现异常 的文章

 

随机推荐