FindFirstFileEx不区分大小写 - c#

因为我正在使用一个宏,如果给定路径的大小写与驱动器上的本地路径不相等,则该宏似乎可以工作,因此我首先需要验证该路径是否存在大小写。不幸的是(对于我而言)Directory.Exists()不区分大小写。

因此,我尝试将dwAdditionalAttributes设置为1的FindFirstFileEx来表示FIND_FIRST_EX_CASE_SENSITIVE。但是,这似乎对我不起作用。我的本地路径是C:\Dir1\Dir2\Dir3。我比较的路径是C:\dir1\Dir2\Dir3。不幸的是,我总是得到Dir3的结果。如果案件不匹配,我本来期望结果为空。

我怎么了

string dir = @"C:\Dir1\Dir2\Dir3" + '\0';
int FIND_FIRST_EX_CASE_SENSITIVE = 1;
WIN32_FIND_DATA fi;

IntPtr h = FindFirstFileEx( dir,
                            FINDEX_INFO_LEVELS.FindExInfoStandard,
                            out fi,
                            FINDEX_SEARCH_OPS.FindExSearchNameMatch,
                            IntPtr.Zero,
                            FIND_FIRST_EX_CASE_SENSITIVE);

参考方案

此功能取决于注册表键HKLM\SYSTEM\CurrentControlSet\Control\Session Manager\kernel\obcaseinsensitive的值设置为0,这不是默认值。

换句话说,它取决于基础文件系统设置,而不是API本身。

此处有更多详细信息:http://www.siao2.com/2010/12/08/10101148.aspx

LeetCode题解计算机为什么是基于二进制的?

可以是三进制么?二进制有什么好处?题解:为什么叫电子计算机?算盘应该没有二进制

LeetCode题解统计城市的所有灯泡

这个是我刚毕业的时候,一个真实的面试题,这是一个开放题。题目描述:想办法,将一个城市的所有灯泡数量统计出来。题解:费米估算法1、如果某个城市常驻人口有1000万2、假设每5人居住在一套房里,每套房有灯泡5只,那么住宅灯泡共有1000万只3、假设公众场所每10人共享一只灯泡,那么共有100万只4、主要的这两者相加就得出了1100万只当然实际上这是估算的,具体应…

LeetCode题解黑白圆盘

一个圆盘被涂上了黑白二色,两种颜色各占一个半圆。圆盘以一个未知的速度、按一个未知的方向旋转。你有一种特殊的相机可以让你即时观察到圆上的一个点的颜色。你需要多少个相机才能确定圆盘旋转的方向?题解:可以用一个相机即可

LeetCode题解圆上任取三点构成锐角三角形的概率

来自字节跳动的一道几何题题解:1/4

LeetCode题解深度优先遍历和回溯的关系?

深度优先遍历的范围更大还是回溯的范围更大?为什么?题解:我的理解是:dfs是回溯思想的一种体现- 回溯:是在整个搜索空间中搜索出可行解,在搜索过程中不断剪枝回退,这是回溯的思想,这个搜索空间并没有限制于特定的数据结构。- dfs:dfs是指特定的数据结构中如图,树(特殊的图)中搜索答案,范围限制在了特定的数据结构。个人拙见。