基于為何我不喜歡用Path.Combine的詳解
Path.Combine:

什么時(shí)候會(huì)用到Path.Combine呢?,當(dāng)然是連接路徑字符串的時(shí)候!
所以下面的代碼可以完美的工作:
public static void Main()
{
string[] arr_pa = { @"c:\abc\", @"c:\abc" };
string[] arr_pb = { @"test.txt" };
foreach (string pa in arr_pa)
{
foreach (string pb in arr_pb)
{
Console.WriteLine("'{0}' + '{1}'= '{2}'", pa, pb, Path.Combine(pa, pb));
}
}
}
結(jié)果如下:

當(dāng)然你也可以:
Console.WriteLine("'{0}' + '{1}'= '{2}'", pa, pb, Path.Combine(pa, "def", pb));
結(jié)果是:
![]()
從這個(gè)例子可以知道,我們不需要考慮arr_pa里面的字符串是不是以”\” 結(jié)尾,這的確提供了方便,而且這也是很多人喜歡使用Path.Combine的一個(gè)原因,但是僅此而已。
Path.Combine 雖然解決了路徑連接問題,但是由于很多人片面的去理解它,所有它非常容易造成錯(cuò)誤的應(yīng)用,要想用好Path.Combine 并非易事,下面我會(huì)列舉幾個(gè)實(shí)例來說明這點(diǎn)。
第一個(gè):當(dāng)path2 是相對(duì)路徑的時(shí)候,返回的是path2,path1會(huì)被丟棄。
看一下下面的代碼:
public static void Main()
{
string[] arr_pa = { @"c:\abc\", @"c:\abc" };
string[] arr_pb = { @"\test.txt", @"/test.txt", @"test.txt" };
foreach (string pa in arr_pa)
{
foreach (string pb in arr_pb)
{
Console.WriteLine("'{0}' + '{1}'= '{2}'", pa, pb, Path.Combine(pa, pb));
}
}
}
你知道這段代碼輸出什么嗎?
這段代碼的輸出如下:
可以看到對(duì)于”/test.txt” 和”\test.txt” ,Path.Combine 認(rèn)為path2是相對(duì)路徑,所以直接返回path2.。
第二點(diǎn):路徑是驅(qū)動(dòng)器,返回的結(jié)果不正確
public static void Main()
{
string[] arr_pa = { @"c:", @"c:\" };
string[] arr_pb = { @"\test.txt", @"/test.txt", @"test.txt" };
foreach (string pa in arr_pa)
{
foreach (string pb in arr_pb)
{
Console.WriteLine("'{0}' + '{1}'= '{2}'", pa, pb, Path.Combine(pa, pb));
}
}
}
輸出結(jié)果是:
可以看到,如果path1 是” C:”的話,那么Path.Combine結(jié)果就是不正確的。
第三點(diǎn):無法連接http路徑
除了連接本地路路徑之外,有的時(shí)候,也需要拼接http鏈接地址,可惜的是System.IO.Path.Combine卻無法拼接http地址。
將arr_pa 修改為
string[] arr_pa = { @"http://www.Test.com/", @"http://www.Test.com" };
結(jié)果如下:
在這里就沒有什么技巧了,純粹的死記硬背,
記住,只有
![]()
才會(huì)產(chǎn)生正確的解。
如果你將代碼修改為:
public static void Main()
{
string[] arr_pa = { @"http://www.Test.com/", @"http://www.Test.com" };
string[] arr_pb = { @"\test.txt", @"/test.txt", @"test.txt" };
foreach (string pa in arr_pa)
{
foreach (string pb in arr_pb)
{
Console.WriteLine("'{0}' + '{1}'= '{2}'", pa, pb, Path.Combine(pa, "def", pb));
}
}
}
那么無論怎樣,你都無法得到正確的結(jié)果:

正是因?yàn)樯鲜龅膸c(diǎn)不足,導(dǎo)致Path.Combine 很難用,這也是有一部分人選擇使用String.Format 的原因了。
當(dāng)然,我寫了一個(gè)MyPath.Combine的方法,可以解決上面的問題。 string firstPath = paths[0]; if (firstPath.StartsWith("HTTP", StringComparison.OrdinalIgnoreCase)) if (!firstPath.EndsWith(spliter)) for (int i = 1; i < paths.Length; i++) if (i != paths.Length - 1)//not the last one builder.Append(nextPath); return builder.ToString();
class MyPath
{
public static string Combine(params string[] paths)
{
if (paths.Length == 0)
{
throw new ArgumentException("please input path");
}
else
{
StringBuilder builder = new StringBuilder();
string spliter = "\\";
{
spliter = "/";
}
{
firstPath = firstPath + spliter;
}
builder.Append(firstPath);
{
string nextPath = paths[i];
if (nextPath.StartsWith("/") || nextPath.StartsWith("\\"))
{
nextPath = nextPath.Substring(1);
}
{
if (nextPath.EndsWith("/") || nextPath.EndsWith("\\"))
{
nextPath = nextPath.Substring(0, nextPath.Length - 1) + spliter;
}
else
{
nextPath = nextPath + spliter;
}
}
}
}
}
}
使用也比較簡(jiǎn)單
例如:
public static void Main()
{
string[] arr_pa = { @"c:\abc\", @"c:\abc", @"http://www.Test.com/", @"http://www.Test.com" };
string[] arr_pb = { @"\test.txt", @"/test.txt", @"test.txt" };
foreach (string pa in arr_pa)
{
foreach (string pb in arr_pb)
{
Console.WriteLine("'{0}' + '{1}'= '{2}'", pa, pb, MyPath.Combine(pa, pb));
}
}
}
結(jié)果如下:
當(dāng)然,你也可以這樣:
Console.WriteLine("{0}+{1}+{2}+{3}={4}",
pa, "p2", "\\p3/", pb, MyPath.Combine(pa, "p2", "\\p3/", pb));
輸出如下:

最后如果你不用Path.Combine,那么還可以選擇string.Format
相關(guān)文章
基于WPF實(shí)現(xiàn)3D畫廊動(dòng)畫效果的示例代碼
這篇文章主要為大家詳細(xì)介紹了如何基于WPF實(shí)現(xiàn)簡(jiǎn)單的3D畫廊動(dòng)畫效果,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-02-02
C#調(diào)用OpenXml讀取excel行數(shù)據(jù)
這篇文章主要為大家詳細(xì)介紹了C#如何調(diào)用OpenXml實(shí)現(xiàn)讀取excel行數(shù)據(jù),文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-12-12
Unity?UGUI的PointerEventData的介紹及使用
這篇文章主要為大家介紹了Unity?UGUI的PointerEventData的介紹及使用,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-07-07
C#中Foreach循環(huán)遍歷的本質(zhì)與枚舉器詳解
這篇文章主要給大家介紹了關(guān)于C#中Foreach循環(huán)遍歷本質(zhì)與枚舉器的相關(guān)資料,foreach循環(huán)用于列舉出集合中所有的元素,foreach語(yǔ)句中的表達(dá)式由關(guān)鍵字in隔開的兩個(gè)項(xiàng)組成,本文通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2021-08-08
Unity3D開發(fā)之獲取所有的子對(duì)象的方法詳解
這篇文章主要為大家詳細(xì)介紹了三種Unity3D中獲取所有的子對(duì)象(child)的方法,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-01-01

