close

這是我的文章備份,原文在這裡: http://www.dotblogs.com.tw/mis2000lab/archive/2008/05/05/3795.aspx



花了很多時間,幫忙回答問題。

我最討厭遇見的「顧人怨」問題,就是:請幫我把 YY程式碼改成XX,好嗎?

把C#改成VB.NET語法,或是相反流程,真的這麼難嗎?

搞不好連回答都沒看呢,光是看見語法不同,就懶得看下去了。

這種反應最讓我抓狂!

語法再怎麼不同,原理與觀念是相同的。

如果是把JAVA程式,改成 C++,那可能有些「眉角」(細節)要注意....

但是,.....在 .NET裡面,C#與VB語法的轉換,跟本就像是用"鉛筆"與"原子筆"來寫字一樣,差別這麼大嗎?

不過是一種習慣的修正而已。

況且,語法不同,更有機會讓我們邊改邊想。這是學得更多的好機會啊!

----------------------------------------------------------------------------------------------------------------------------

以這個範例來說,透過 Jet.OLEDB 讀取 Excel裡面的資料

微軟的MSDN文件,採用C#來寫。我修改了一下,並且改成VB語法。

只作了兩件事:

第一,VB語法如下:
Dim objConn As OleDbConnection = New OleDbConnection(sConnectionString)

C#語法如下:
OleDbConnection objConn = new OleDbConnection(sConnectionString);

改了什麼?很大的改變嗎?   說難聽一點,頂多是後面加上一個分號(;)結尾而已啦

第二,VB語法如下:
DataGrid1.DataSource = objDataset1.Tables(0).DefaultView

C#語法如下:
DataGrid1.DataSource = objDataset1.Tables[0].DefaultView;

改了什麼?很大的改變嗎?   說難聽一點,[]符號修改成 ()而已啦!

初學者也就算了,如果學過程式(那怕是學過一年而已的大二資訊科系學生,上面的改變都不會太難吧!?)

C#轉換VB,根本毫無難度可言!  因為他們是系出同門的,都是 .NET的程式語法!

----------------------------------------------------------------------------------------------------------------------------

您也可以參考董大偉老師的文章,針對VB or C#的看法---- 關於如何選擇VB和C# 

董大偉老師說的很棒,他說:「你不需要全部會,但是你至少需要看得懂別人寫的Code

    如果你習慣用其中一種語言(例如我習慣VB),我覺得那沒什麼關係,每個人都會有自己的習慣,

    但是若你害怕用任何一種語言 或是 denial任何一種語言,那就不可以了

    必須對C#和VB都無所懼怕,依照你當時的需要選擇你要開發的語言。

忙?沒時間?

對於學生或是初學者來說,你們會比線上的Programmer忙嗎?比他們更沒時間?

人家都抽空幫忙回答了,你還敢說忙?

如果連 .NET的 C#與VB語法的轉換都不會,或是連 "試一下" 都懶....

真的,好可惜!

就好像一個很飢餓的人,只是因為飯桌上「沒有筷子」、用不慣刀叉,就放棄進食了。

放棄求生意志,寧願餓死,卻不願意暫時修改一下用餐習慣

您,會是這種人嗎?

...................................................................................................................................................................................................................

新書上市-- ASP.NET專題實務(文魁出版 / P8187)。懇請支持,謝謝。

2008/八月份 天瓏書局排行榜前十名 


arrow
arrow
    全站熱搜
    創作者介紹
    創作者 MIS2000 Lab 的頭像
    MIS2000 Lab

    MIS2000 Lab -- ASP.NET專題實務 / WebForm + MVC線上教學影片

    MIS2000 Lab 發表在 痞客邦 留言(0) 人氣()