• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            posts - 124,  comments - 29,  trackbacks - 0
            1:把(tuxedo安裝目錄)D:\Program Files\tuxedo10.0_VS2005\bin 下面的DLL都考到應用程序所在目錄,即CMT.exe  所在的同一目錄,同時把D:\Program Files\tuxedo10.0_VS2005下面的locale和udataobj目錄也考到應用程序所在目錄。
            2:  string nlsPath = Application.StartupPath + "\\locale\\C";
                        string curPath = Application.StartupPath;
                        Bea.Tuxedo.ATMI.Utils.tuxputenv("NLSPATH=" + nlsPath);
                        Bea.Tuxedo.ATMI.Utils.tuxputenv("TUXDIR=" + curPath);
                        Bea.Tuxedo.ATMI.Utils.tuxputenv("APPDIR=" + curPath);
                        Bea.Tuxedo.ATMI.Utils.tuxputenv("WSNADDR=//10.5.0.3:9300");   (這個最好讀配置文件因為它不是固定的)
            posted @ 2009-09-24 14:38 天書 閱讀(430) | 評論 (0)編輯 收藏
            posted @ 2009-07-03 16:19 天書 閱讀(756) | 評論 (0)編輯 收藏
            posted @ 2009-06-22 16:57 天書 閱讀(1057) | 評論 (0)編輯 收藏
            posted @ 2009-04-19 11:22 天書 閱讀(1207) | 評論 (1)編輯 收藏

              private void InstructorTree_Load(object sender, EventArgs e)
                    {
                        xmlfile = Application.StartupPath + "\\CC08Help.xml";
                        GetInsEvent += new GetInstructorHandle(HelpForm_GetInsEvent);
                        GetHtmlEvent += new GetNodeHtml(InstructorTree_GetHtmlEvent);
                        ReadXMLGetFileName();
                        this.tvHelp.ImageList = this.imgLHelp;
                     
                        //由Excel導出的XML文檔動態生成樹
                        if (xmlfile != "")
                        {
                            InitTreeView(xmlfile, this.tvHelp);
                        }
                        foreach (TreeNode tn in tvHelp.Nodes)
                        {
                            SetLeafNodeImageIndex(tn);
                        }
                        this.tvHelp.Nodes[0].Expand();
                    }

                    private TreeNode curTn = null;
                
                    private void InitTreeView(string xmlfileName, TreeView tv)
                    {
                        XmlDocument xdoc = new XmlDocument();
                        xdoc.Load(xmlfileName);
                        XmlNode xn = xdoc.SelectSingleNode("Help");
                        TreeNode tn = new TreeNode();
                        tn.Text = xn.ChildNodes[0].Attributes[0].Value;//命令聯機幫助
                        tv.Nodes.Add(tn);
                        makeOutTreeView(xn.ChildNodes[0], tn);  //遞歸
                    }

                    private void makeOutTreeView(XmlNode xn,TreeNode tn)
                    {
                        if (xn.ChildNodes.Count != 0)
                        {
                            for (int i = 0; i < xn.ChildNodes.Count; i++)
                            {
                                curTn = new TreeNode();
                                curTn.Text = xn.ChildNodes[i].Attributes[0].Value;
                                tn.Nodes.Add(curTn);

                                makeOutTreeView(xn.ChildNodes[i], curTn);
                            }
                        }
                    }

            posted @ 2009-02-20 15:21 天書 閱讀(1132) | 評論 (0)編輯 收藏

            using System;
            using System.Collections.Generic;
            using System.ComponentModel;
            using System.Data;
            using System.Drawing;
            using System.Text;
            using System.Windows.Forms;
            using System.Xml;


            namespace ExcelToXml
            {
                public partial class Form1 : Form
                {
                    public Form1()
                    {
                        InitializeComponent();
                    }
                    private string xmlFile = "";
                    private DataSet ds = null;
                    private string excelFileName = "";
                    private void ReadXMLGetFileName()
                    {
                        XmlDocument xdoc = new XmlDocument();
                        string file = Application.StartupPath + "http://excelFile.xml";
                        xdoc.Load(file);
                        XmlNode xno = xdoc.SelectSingleNode("excelFile");
                        for (int i = 0; i < xno.ChildNodes.Count; i++)
                        {
                            if (xno.ChildNodes[i].Name == "FileName")
                            {
                                excelFileName = xno.ChildNodes[i].InnerText;
                                break;
                            }
                        }
                    }
                    private void Form1_Load(object sender, EventArgs e)
                    {
                        xmlFile = Application.StartupPath + "\\CC08Help.xml";
                        ReadXMLGetFileName();
                        ds = ReadExcelToTree.ExcelToDataSet(@excelFileName);
                        if (ds != null)
                        {
                            xmlFormExcel(ds.Tables[0], xmlFile);
                        }
                    }
                    private XmlNode curNode = null;
                    private string curNodeName = "";
                    private XmlDocument xdoc = null;
                    void xmlFormExcel(DataTable dt,string xmlFile)
                    {
                       
                        xdoc = new XmlDocument();
                        xdoc.Load(xmlFile);
                        curNodeName = "Help";
                        curNode = xdoc.SelectSingleNode(curNodeName);
                       
                        int colums = dt.Columns.Count;
                        XmlNode[] curNodeLevel = new XmlNode[colums];
                        for (int i = 0; i < dt.Rows.Count; i++)
                        {
                            DataRow dr = dt.Rows[i];
                            for (int j = 1; j <= colums; j++)
                            {
                                if (j == 1 && dr[j].ToString() != String.Empty)
                                {
                                    XmlElement xe = xdoc.CreateElement("tn");
                                    xe.SetAttribute("value",dr[j].ToString());
                                    curNode.AppendChild(xe);
                                    curNodeLevel[0] = xe;
                                    break;
                                }
                                else if (j >= 2)
                                {
                                    if (dr[j].ToString() != string.Empty)
                                    {
                                        XmlElement xe = xdoc.CreateElement("tn");
                                        xe.SetAttribute("value", dr[j].ToString());
                                     
                                        curNodeLevel[j - 2].AppendChild(xe);
                                        curNodeLevel[j - 1] = xe;
                                        break;
                                    }
                                }
                            }
                        }
                        xdoc.Save(xmlFile);
                    }
                }
            }

            posted @ 2009-02-20 15:16 天書 閱讀(1448) | 評論 (1)編輯 收藏

            觸發器是一種特殊的存儲過程,類似于事件函數,SQL Server™ 允許為 INSERT、UPDATE、DELETE 創建觸發器,即當在表中插入、更新、刪除記錄時,觸發一個或一系列 T-SQL語句。

            觸發器可以在查詢分析器里創建,也可以在表名上點右鍵->“所有任務”->“管理觸發器”來創建,不過都是要寫 T-SQL 語句的,只是在查詢分析器里要先確定當前操作的數據庫。

            創建觸發器用 CREATE TRIGGER

            CREATE TRIGGER 觸發器名稱
            ON 表名
            FOR INSERT、UPDATE 或 DELETE
            AS
                T-SQL 語句

            注意:觸發器名稱是不加引號的。

            如下是聯機叢書上的一個示例,當在 titles 表上更改記錄時,發送郵件通知 MaryM。
            CREATE TRIGGER reminder
            ON titles
            FOR INSERT, UPDATE, DELETE
            AS
               EXEC master..xp_sendmail 'MaryM',
                  'Don''t forget to print a report for the distributors.'

            posted @ 2009-02-19 15:48 天書 閱讀(461) | 評論 (0)編輯 收藏
              觸發器是一種特殊的存儲過程,它在插入,刪除或修改特定表中

            的數據時觸發執行,它比數據庫本身標準的功能有更精細和更復雜的

            數據控制能力。
            數據庫觸發器有以下的作用:

                * 安全性。可以基于數據庫的值使用戶具有操作數據庫的某種權

            利。

                  # 可以基于時間限制用戶的操作,例如不允許下班后和節假日

                  修改數據庫數據。

                  # 可以基于數據庫中的數據限制用戶的操作,例如不允許股票

                  的價格的升幅一次超過10%。

                * 審計。可以跟蹤用戶對數據庫的操作。

                  # 審計用戶操作數據庫的語句。

                  # 把用戶對數據庫的更新寫入審計表。

                * 實現復雜的數據完整性規則。

                  # 實現非標準的數據完整性檢查和約束。觸發器可產生比規則

                  更為復雜的限制。與規則不同,觸發器可以引用列或數據庫對

                  象。例如,觸發器可回退任何企圖吃進超過自己保證金的期貨。

                  # 提供可變的缺省值。

                * 實現復雜的非標準的數據庫相關完整性規則。觸發器可以對數

            據庫中相關的表進行連環更新。例如,在auths表author_code列上的

            刪除觸發器可導致相應刪除在其它表中的與之匹配的行。

                  # 在修改或刪除時級聯修改或刪除其它表中的與之匹配的行。

                  # 在修改或刪除時把其它表中的與之匹配的行設成NULL值。

                  # 在修改或刪除時把其它表中的與之匹配的行級聯設成缺省值。

                  # 觸發器能夠拒絕或回退那些破壞相關完整性的變化,取消試

                  圖進行數據更新的事務。當插入一個與其主健不匹配的外部鍵

                  時,這種觸發器會起作用。例如,可以在books.author_code

                  列上生成一個插入觸發器,如果新值與auths.author_code列

                  中的某值不匹配時,插入被回退。

                * 同步實時地復制表中的數據。

                * 自動計算數據值,如果數據的值達到了一定的要求,則進行特

            定的處理。例如,如果公司的帳號上的資金低于5萬元則立即給財務人

            員發送警告數據。


            觸發器是一種特殊的存儲過程,類似于事件函數,SQL Server™ 允許為 INSERT、UPDATE、DELETE 創建觸發器,即當在表中插入、更新、刪除記錄時,觸發一個或一系列 T-SQL語句。

            觸發器可以在查詢分析器里創建,也可以在表名上點右鍵->“所有任務”->“管理觸發器”來創建,不過都是要寫 T-SQL 語句的,只是在查詢分析器里要先確定當前操作的數據庫。

            創建觸發器用 CREATE TRIGGER

            CREATE TRIGGER 觸發器名稱
            ON 表名
            FOR INSERT、UPDATE 或 DELETE
            AS
                T-SQL 語句

            注意:觸發器名稱是不加引號的。

            如下是聯機叢書上的一個示例,當在 titles 表上更改記錄時,發送郵件通知 MaryM。
            CREATE TRIGGER reminder
            ON titles
            FOR INSERT, UPDATE, DELETE
            AS
               EXEC master..xp_sendmail 'MaryM',
                  'Don''t forget to print a report for the distributors.'

            posted @ 2009-02-19 15:42 天書 閱讀(3626) | 評論 (1)編輯 收藏

            參考答案:
            執行效率的大幅提高
            ASP以源碼形式存放,以解釋方式運行,每次ASP網頁調用都需要對源碼進行解釋,運行效率不高.  ASP.net是把基于通用語言的程序在服務器上運行。不像以前的ASP即時解釋程序,而是將程序在服務器端首次運行時進行編譯,這樣的執行效果,當然比一條一條的解釋強很多.
            強大的開發工具支持
            ASP.net可以使用VS Studio 系列的強大的開發工具,只是所見即所得的開發支持。
            可擴充的適應性
            Asp.net可以完美支持windows平臺,也可以通過mono來支持linux的平臺。而且,asp.Net是語言獨立的,也就是說不但可以用C#編寫相關的代碼,你也可以使用vb,jscript等語言來編寫。
            多處理器環境的可靠性
            ASP.net已經被刻意設計成為一種可以用于多處理器的開發工具,它在多處理器的環境下用特殊的無縫連接技術,將很大的提高運行速度。即使你現在的ASP.net應用軟件是為一個處理器開發的,將來多處理器運行時不需要任何改變都能提高他們的效能,但現在的ASP確做不到這一點。
            安全型
            AspNet內置了強大的安全型管理機制,相對asp,安全型得到了很大的提高。

            點評:

            和asp相比,asp.net確實有了很大的飛躍,特別是這種代碼分類的方式,給編程人員帶來了很大的方便,了解asp.net的進步,可以讓我們更有信心學習asp。net.。

            posted @ 2009-02-19 15:29 天書 閱讀(1746) | 評論 (1)編輯 收藏

            C#可否對內存進行直接的操作 ?
            可以使用指針
            在這篇文章中將描述C#的一個特性指針和所謂的不安全代碼。

            非安全代碼

                   非安全代碼就是不在 CLR 完全控制下執行的代碼,它有可能會導致一些問題,因此他們必須用 “unsafe” 進行表明:

                   unsafe
                   {
                   ...
                   // unsafe context: can use pointers here
                   ...
                   }

                   在其他一些地方也可以使用關鍵字 ‘unsafe’,例如我們可以將類或方法表明為非安全的:

                   unsafe class Class1 {}
                   static unsafe void FastMove ( int* pi, int* pdi, int length) {...}

            ‘unsafe’ 關鍵字的必要性是它可以防止程序員的一些意外的用法。你可能會問既然是不安全的為什么還有人要用它。答案就是有時候,在有些情況下,還需要用到指針。

            指針

                   指針是一種用來存儲其他變量地址的特殊的變量,如果你把第一個變量的地址賦給第二個變量,你可以說第一個變量是指向第二個,CLR支持3種指針類型:受托管指針, 非托管指針和非托管函數指針。受托管指針存儲在堆上的托管塊的引用,一個非托管指針是傳統的C++指針并且每次使用必須要放在unsafe代碼塊中,一個非托管函數指針也是指向函數地址的傳統的C++指針(delegates 可以被看做是非托管函數指針).

                   你可以像下面這樣的聲明來創建指針:類型* 變量_名稱;

                   既然類型可以是任意一個非引用類型并且不包含引用類型字段,它只能是:sbyte, byte, short, ushort, int, uint, long, ulong, char, float, double, decimal, bool 和枚舉類型以及其他指針類型,也可以是任何用戶自定義的包括非托管類型字段的結構體.

                   下面是不同類型指針聲明的示例:

                   int* pi //declaration a pointer to integer variable
                   float* pf, pq // two pointers to float variables. Not *pf, *pq
                   char* pz // pointer to char

                   就像前面說的非托管代碼CLR是不能驗證的,為了編譯你需要指定 /unsafe 編譯選項,如果你是使用的是Microsoft Visual Studio你需要在項目選項中把 'Allow unsafe code block'設置成 True。



            指針的基本用法

            還有一些與指針緊密聯系的操作符,那就是 & 操作符,& 返回它所操作對象的地址。

            例如:
            unsafe
            {
            int* pi;
            int x = 1;
            pi = &x;
            System.Console.WriteLine("Value of x is: " + *pi);
            }

            在這個例子中我們創建了2個變量,’pi’是指向int的指針,’x’是int,然后我們將’x’在內存中的地址賦予’pi’,理解我們放在 ’pi’ 變量中的是 ’x’的地址而不是’x’的值非常重要 (使用: pi = x 將返回錯誤 "Cannot implicitly convert type 'int' to 'int*'")

            編譯后執行將會輸出:

            Value of x is: 1

            指針可以接受 null 值,也可能使用 void 指針類型,下面的代碼可以正常編譯:

            unsafe
            {
            nt x = 10;
            void* px = &x;
            double *pd = (double*)px;
            }

            fixed 關鍵字和垃圾回收

            在 C# 中使用指針需要比在 C++種更加注意。這是因為垃圾回收器(g.c.)會運行內存清理,在清理的過程中,g.c.會改變對象的物理內存位置,如果 g.c.改變了對象的位置指針將指向錯誤的內存位置。為了避免這樣的問題(已經與垃圾回收器連接),C# 包含 'fixed' 關鍵字. 它通知系統不要讓垃圾回收器重新部署對象。

                   如果我們忘了 ’fixed’ 關鍵字編譯器會給我們相應的警告,但它沒有智能到在下面的情況中也會警告我們。下面的代碼有一個嚴重的Bug盡管編譯很正常。

            C# 指針和 WinApi

                   使用指針最重要的好處就是可以與其他二進制代碼進行交互。許多 WinApi 函數都使用指針,例如GetComputerName (Kernel32.lib.)可以提供我們的計算機的名稱。

            BOOL GetComputerName(LPTSTR lpBuffer, // computer name
            LPDWORD lpnSize // size of name buffer);

            下面的程序演示如何使用GetComputerName:

            [System.Runtime.InteropServices.DllImport("Kernel32")]
            static extern unsafe bool GetComputerName(byte* lpBuffer,long* nSize);
            static void Main()
            {
            byte[] buffor = new byte[512];
            long size = buffor.Length;
            unsafe
            {
            long* pSize = &size;
            fixed (byte* pBuffor = buffor)
            {
            GetComputerName(pBuffor,pSize);
            }
            }
            System.Text.Encoding textEnc = new System.Text.ASCIIEncoding();
            System.Console.WriteLine("Computer name: {0}",textEnc.GetString(buffor));
            }

            結論

                   我們已經看到指針是C#語言中非常有用的部分,使用指針并不難但是要非常小心,因為有可能會導致難以診斷的問題,使用指針會擾亂垃圾回收器的功能,特別當我們在程序中大量使用指針。因此在之用指針之前我們應該多考慮,或者嘗試其他的解決辦法。

            posted @ 2009-02-19 15:22 天書 閱讀(2317) | 評論 (1)編輯 收藏
            僅列出標題
            共13頁: 1 2 3 4 5 6 7 8 9 Last 

            <2025年7月>
            293012345
            6789101112
            13141516171819
            20212223242526
            272829303112
            3456789

            常用鏈接

            留言簿(5)

            隨筆檔案

            文章分類

            文章檔案

            好友的Bolg

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            久久久av波多野一区二区| 精品久久久久久无码专区| 久久久精品人妻无码专区不卡| 国产精品成人久久久久三级午夜电影| 激情五月综合综合久久69| 亚洲国产另类久久久精品黑人| 香港aa三级久久三级| 漂亮人妻被黑人久久精品| 伊人久久大香线蕉成人| 久久精品国产69国产精品亚洲| 国内精品九九久久精品| 午夜精品久久久久成人| 久久精品成人免费网站| 少妇无套内谢久久久久| 四虎国产精品免费久久| 色综合久久综合网观看| 中文字幕亚洲综合久久| 久久精品国产乱子伦| 一本色道久久99一综合| 久久免费99精品国产自在现线 | 国产高潮久久免费观看| 久久精品无码一区二区WWW| 久久99热这里只有精品国产| 国产精品99久久99久久久| 久久久久亚洲国产| 中文成人久久久久影院免费观看| 久久久WWW成人免费毛片| 欧美综合天天夜夜久久| 精品久久久久久亚洲精品| 亚洲狠狠婷婷综合久久蜜芽 | 色综合久久夜色精品国产| 99久久免费只有精品国产| 精品久久香蕉国产线看观看亚洲| 少妇精品久久久一区二区三区| 久久婷婷五月综合成人D啪 | 亚洲午夜久久久影院| 少妇无套内谢久久久久| 久久www免费人成看片| 亚洲αv久久久噜噜噜噜噜| 99久久国产综合精品女同图片| 99久久无色码中文字幕人妻|