程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C++ >> C++入門知識 >> 透析C++代碼實現ControlTemplate

透析C++代碼實現ControlTemplate

編輯:C++入門知識

現在主流的開發語言就是C++語言了,但是不過感覺沒有C語言實現的那麼靈活,現介紹一下代碼實現 ControlTemplate的方法,希望大家學習探討,好了下面就是C++代碼舉例說明:

  1. FrameworkElementFactory fe = new FrameworkElementFactory(typeof(Image), "Image");   
  2.  
  3.            BitmapImage bi = new BitmapImage();   
  4.            bi.BeginInit();   
  5.            bi.UriSource = new Uri(@"E:ChartControlHanYangChartControlImageMainBackground.jpg");   
  6.            bi.EndInit();   
  7.  
  8.            fe.SetValue(Image.SourceProperty, bi);   
  9.  
  10.            //控件呈現的顯示內容2這裡為TextBox)   
  11.            FrameworkElementFactory fe2 = new FrameworkElementFactory(typeof(TextBox), "TextBox");   
  12.            fe2.SetValue(TextBox.WidthProperty,100.0);   
  13.            fe2.SetValue(TextBox.HeightProperty, 100.0);   
  14.  
  15.            //把要呈現的顯示內容封裝起來   
  16.            FrameworkElementFactory f = new FrameworkElementFactory(typeof(Grid), "Grid");   
  17.            f.AppendChild(fe);   
  18.            f.AppendChild(fe2);  

從上表可以看出,int與long相同。那麼,為什麼C++代碼還要區分這兩種數據類型呢?實際上這是個遺留問題。在16位編程環境中,int要求2個字節而long要求4個字節。而在32位編程環境中,這兩種數據都用4個字節存放。

C++Builder只生成32位程序,所以int與long相同。說明 在C++ Builder和BorLand C++ 5.0中,Bool是個真正的數據類型。有些C++編譯器有Bool關鍵字,則Bool不是個真正的數據類型。

有時Bool只是個typedef,使Bool等價於int。typedef實際上建立別名,使編譯器在一個符號與另一符號間劃上等號。typedef的語法如下:typedef int Bool;這就告訴編譯器:Bool是int的別名。說明 只有double和float數據類型使用浮點數帶小數點的數)。

其它數據類型只涉及整數值。盡管integer數據類型也可以指定帶小數點的數值,但小數部分會捨棄,只將整數部分賦予整型變量。例如:int x=3.75;得到的x取值為3。注意,這個整數值並不是四捨五入,而是放棄小數部分。順便說一句,大多數Windows程序很少用到浮點數。

C++代碼可以在必要時進行不同數據類型間的換算。例如:short result;long num1 = 200;long num2 = 200;result = num1 * num2;這裡我想將兩個長整型的積賦予一個短整型。盡管這個公式混用了兩種數據類型,但C++能夠進行換算。計算結果會怎樣呢?結果會讓你大吃一驚,是25536,這是繞接(wrop)的結果。

從表1.1可以看出,短整型的最大取值為32767,在最大值之上加1會怎麼樣呢?得到的是32768。這實際上與汽車裡程計從99999回到00000的道理一樣。為了說明這點,請輸入並運行下列清單1.3中包含的程序。

為了避開C++的復雜性而干脆不用C++Linus的做法),無異於因噎廢食。”在所有可用C和C++的領域,C++都是比C更好的語言。當我說“更好的”時候,我說的是C++擁有比C更安全的類型檢查、更好的抽象機制、更優秀的庫。

當然,凡事都有例外,如果你做的項目1)不大。2)編碼中用不到什麼抽象機制,甚至ADT抽象數據類型,例如std::complex這種不含多態和繼承的)也用不到,RAII也用不到,異常也用不到。

3)你連基礎庫如,簡化資源管理的智能指針、智能容器)都用不著。那麼也許你用C的確沒問題;所以如果你的情況如此,不用和我爭論,因為我無法反駁你。我們這裡說的領域大致是Bjarne在“C++應用列表”裡面列出來的那些地方。

  • 學習C++語言總結之談
  • 優秀的面向對象的設計語言——C++語言
  • 什麼是C++語言的設計原則
  • VC++應用程序介紹以及模式說明
  • 如何為C++堆棧插入新元素

即便是C++的反對者也許也很難找到理由說“我還是不用C++代碼”。在我看來,一個真正從實踐意義上理性反對使用C++的人只有一個理由:C++的復雜性帶來的混亂抵消乃至超過了C++的抽象機制和庫在他的特定項目中)帶來的好處。

值得注意的是,這裡需要避免一個陷阱,就是一旦人們認定了“C++代碼不好”,那麼這個理由就會“長出自己的腳來”,即,就算我們拿掉C++的復雜性,他們可能也會堅持還是不用C++,並為之找一堆理由。

我假定你不是這樣的人。不過,也許最可能的是他會說:“問題是我們今天用的C++並非如此簡潔),你的假設不成立。”是的,我的假設不成立。但雖然我們無法消除復雜性,我們實際上是可以容易地避開復雜性,避短揚長的。這也是本文的要點,容我後面再詳述。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved