如何用Visual Studio解决方案/项目中的新GUID替换所有现有的GUID?

问题描述

我有一个使用C#和C ++开发的Windows应用程序,因此它具有多个.cs和.cpp文件。现在,许多.cs文件都具有以下格式的GUID:

[Guid(“ D01A42F5-FD89-4c8f-8065-726AD4363411”)]

我的项目中存在大量的GUID。现在,我将当前的32位应用程序升级到64位,因此不想为两个应用程序使用相同的GUID。

无论如何,是否有需要替换所有GUID的情况而无需手动进行?我知道工具->创建GUID 选项,但是在这种情况下,我需要在所有这些类文件中手动替换它们。

编辑:下面两个条目之间发生冲突,并在以后安装的应用程序中被覆盖。

计算机\ HKEY_CLASSES_ROOT \名称空间dll \ CLSID

计算机\ HKEY_LOCAL_MACHINE \ SOFTWARE \ Classes \ namespacedll \ CLSID

解决方法

总有没有不用手工操作就可以替换所有GUID吗?

不。

我也不明白为什么这是一个问题。 32位和64位通常不会交互,因此,除非您能通过示例或指向文档的链接来说明问题,否则在我看来,这就像“忙碌的工作”一样-无需进行大量工作。

,

我个人的方法是创建一个应用程序以读取每个项目文件,用正则表达式将每个单独的GUID匹配/替换为一个新生成的GUID。

您可以采用一种更简单的方法,即不太可能生成重复项,并且使用正则表达式替换来交换和移位现有GUID值的一部分。

因此您可以将所有内容与此匹配:

([0-9A-F])([0-9A-F])([0-9A-F])([0-9A-F])([0-9A-F])([0-9A-F])([0-9A-F])([0-9A-F])\-([0-9A-F])([0-9A-F])([0-9A-F])([0-9A-F])\-4([0-9A-F])([0-9A-F])([0-9A-F])\-([0-9A-F])([0-9A-F])([0-9A-F])([0-9A-F])\-([0-9A-F])([0-9A-F])([0-9A-F])([0-9A-F])([0-9A-F])([0-9A-F])([0-9A-F])([0-9A-F])([0-9A-F])([0-9A-F])([0-9A-F])([0-9A-F])

然后将其替换为移位/交换版本:

$31$1$30$2$29$3$28$4-$27$5$26$6-4$25$7$24-$8$23$9$22-$10$21$11$20$12$19$13$18$14$17$15$16

请注意,这仅适用于版本4 GUID,因为我们期望使用静态4版本标识符。还要注意,它实际上并没有生成新的GUID;它只是重新排列了现有的。它需要最后一个字符,然后是第一个,然后是下一个最后,然后是下一个最后,依此类推。有利的一面是,一旦应用了转换,所有当前相同的GUID值将彼此相同。

Example