公司红头文件发错怎么办

公司红头文件发错怎么办,第1张

根据具体错误来解决。

如果事业单位在制作文件时发生了文号错误的问题时,就应该根据文号出错的具体情况来解决。比如说,如果出错的文号是已经用过的文号,那么就要把已经发出的错误文号文件进行回收,并重新发放新的正确文号的文件。但如果是用了是一个后边才应该使用到的文号的话,则一般来说没有什么太大的影响。

已经印发的公文有非常小的错误,比如说个别文字或标点的错误,不影响公文的内容,这种情况可以不用纠正。

致命错误 C1076

错误消息

编译器限制 : 达到内部堆限制;使用 /Zm 指定更高的限制

此错误可能是由过多符号或过多模板实例化引起的。

解决此问题的方法是:

1.使用 /Zm 选项设置编译器内存限制。

2.消除不需要的包含文件。

3.消除不需要的全局变量,例如,动态分配内存而不是声明一个大数组。

4.消除未使用的声明。

5.将大函数拆分为更小的函数。

6.将大类拆分为更小的类。

7.将当前文件拆分成更小的文件。

如果在生成开始后立即发生 C1076,则说明为 /Zm 指定的值对程序而言可能太高。请减小 /Zm 的值。

这样子设置就可以了,在“工程”->“设置”->“C/C++”->“工程选项中”在/c之前加上“/Zm1000”

看到有一位同学在头文件中这么写:

1 static const wchar_t* g_str1 = …2 static const wchar_t* g_str2 = …

这种定义变量的方式我从来没有见过,而且它还能顺利通过编译,于是我很想知道编译器是如何处理这种变量定义的。

定义全局变量时使用static,意味着该变量的作用域只限于定义它的源文件中,其它源文件不能访问。既然这种定义方式出现在头文件中,那么可以很自然地推测:包含了该头文件的所有源文件中都定义了这些变量,即该头文件被包含了多少次,这些变量就定义了多少次。

假如将上面两行代码的static去掉,编译的时候就会出现变量重定义的错误,这进一步证实了上面的推测,因为没有static的话变量的作用域是全局的,定义了两个以上的同名变量就会出现该错误。

推测终究是推测,要真正证实这个推测还要通过写代码来验证。验证的方式是:在头文件中使用static定义变量,在多个源文件中包含该头文件,然后在每个源文件中输出变量的地址,同时在一个源文件中改变变量的值并输出,在另一个源文件中也输出。如果每个源文件的输出都不同,则推测得证;否则推测是错误的。

下面是定义变量的头文件的代码:

1 //Header.h2 #pragma once3 4 static int g_int = 3

接下来在另一个头文件中声明两个测试函数:

1 //Functions.h2 #pragma once3 4 void TestSource1()5 void TestSource2()

分别在两个源文件中定义这两个测试函数:

1 //Source1.cpp 2 #include <stdio.h>3 #include "Header.h" 4  5 void TestSource1() { 6  7     wprintf(L"g_int's address in Source1.cpp: %08x\n", &g_int)8     g_int = 59     wprintf(L"g_int's value in Source1.cpp: %d\n", g_int)10 }

1 //Source2.cpp2 #include <stdio.h>3 #include "Header.h"4 5 void TestSource2() {6 7     wprintf(L"g_int's address in Source2.cpp: %08x\n", &g_int)8     wprintf(L"g_int's value in Source2.cpp: %d\n", g_int)9 }

最后在main函数中调用这两个测试函数:

1 //Main.cpp2 #include "Functions.h"3 4 int wmain() {5 6     TestSource1()7     TestSource2()8 }

运行该程序:

可以看到,虽然在代码中好像使用了相同的变量,但是实际上使用的是不同的变量,在每个源文件中都有单独的变量。所以,在头文件中定义static变量会造成变量多次定义,造成内存空间的浪费,而且也不是真正的全局变量。应该避免使用这种定义方式。

作为对比,下面使用正确的方式来定义全局变量:

1 //Header.h2 #pragma once3 4 extern int g_int

1 //Source1.cpp 2 #include <stdio.h>3 #include "Header.h" 4  5 int g_int = 36  7 void TestSource1() { 8  9     wprintf(L"g_int's address in Source1.cpp: %08x\n", &g_int)10     g_int = 511     wprintf(L"g_int's value in Source1.cpp: %d\n", g_int)12 13 }

其它文件不变。

运行程序:

可以看到,这次两个源文件中使用的都是同一个变量。要注意的是,使用extern声明变量时不能带有初始值,否则仍然属于变量定义,会出现变量重定义的错误。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/11504990.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-16
下一篇 2023-05-16

发表评论

登录后才能评论

评论列表(0条)

保存