现在的位置: 首页 > 综合 > 正文

常用代码汇编

2012年07月30日 ⁄ 综合 ⁄ 共 2792字 ⁄ 字号 评论关闭

实现多台服务器的互相访问,建立连接服务器:使用存储过程:sp_addlinkedserver;sp_addlinkedsrvlogin

蜂鸣:

[DllImport("kernel32.dll")]
  public static extern bool Beep(int frequency, int duration);
  
  public static void ABeep(int iFrequency, int iDuration)
  {
    Beep(iFrequency,iDuration);
  }
//////////////////////////////
在屏幕上绘制图片
[DllImport("Gdi32.dll")]
static extern IntPtr CreateDC(string lpszDriver, string lpszDevice, string lpszOutput, IntPtr initData);

IntPtr screem = CreateDC("DISPLAY", null, null, IntPtr.Zero);
Graphics g = Graphics.FromHdc(screem);
g.FillRectangle(Brushes.Red, 0, 0, 1000, 1000);
刷新桌面图片消失
//////////////////////////////
读取硬盘的序列号:
private string[] GetMoc()
{
string[] str = new string[2];
ManagementClass mcCpu = new ManagementClass("win32_Processor");
ManagementObjectCollection mocCpu = mcCpu.GetInstances();
foreach(ManagementObject m in mocCpu)
{
str[0] = m["ProcessorId"].ToString();
}

ManagementClass mcHD = new ManagementClass("win32_logicaldisk");
ManagementObjectCollection mocHD = mcHD.GetInstances();
foreach(ManagementObject m in mocHD)
{
if(m["DeviceID"].ToString() == "C:")
{
str[1] = m["VolumeSerialNumber"].ToString();
break;
}
}
return str;
}
4、读取硬盘id的
DllImport("kernel32.dll")]
private static extern int GetVolumeInformation(
 string  lpRootPathName,
 string  lpVolumeNameBuffer,
 int  nVolumeNameSize,
 ref int  lpVolumeSerialNumber,
 int  lpMaximumComponentLength,
 int  lpFileSystemFlags,
 string  lpFileSystemNameBuffer,
 int  nFileSystemNameSize
 );
/////////////////////////////
(1) 绘制控件,可在窗体外绘制
ControlPaint.DrawReversibleFrame(new Rectangle(pBegin.X,pBegin.Y,pEnd.X - pBegin.X,pEnd.Y - pBegin.Y),
       Color.White,FrameStyle.Dashed);
/////////////////////////////
C#也支持对注册表的编辑,.NET框架在Microsoft.Win32名字空间中提供了两个类来操作注册表:Registry和RegistryKey。这两个类都是密封类不允许被继承。下面我们分别来介绍这两个类。

  Registry类提供了7个公共的静态域,分别代表7个基本主键(其中两个在XP系统中没有,在这就不介绍了)分别是:Registry.ClassesRoot,Registry.CurrentUser,Registry.LocalMachine,Registry.Users,Registry.Current Config。它们分别对应哪几个键我想各位一看就会知道吧。

  RegistryKey类中提供了对注册表操作的方法。要注意的是操作注册表必须符合系统权限,否则将会抛出错误。

  下面我们就来几个操作注册表常用的几个方法

  创建子键的方法原型为:
   public RegistryKey CreateSubKey(string sunbkey);

   参数sunbkey表示要创建的子键的名称或路径名。创建成功返回被创建的子键,否则返回null。

  打开子键的方法原型为:
   public RegistryKey OpenSubKey(string name);
  public RegistryKey OpenSubKey(string name,bool writable);

  参数name表示要打开的子键名或其路径名,参数writable表示被打开的子键是否允许被修改,第一个方法打开的子键是只读的。Microsoft.Win32类还为我们提供了另一个方法,用于打开远程计算机上的注册表,方法原型为:
   public static RegistryKey OpenRemoteBaseKey(RegistryHive hKey,string machineName); 

  删除子键的方法原型为:
   public void DeleteKey(string subkey); 

  该方法用于删除指定的主键。如果要删除的子键还包含主键则删除失败,并返回一个异常,如果要彻底删除该子键极其目录下的子键可以用方法DeleteSubKeyTree,该方法原型如下:
   public void DeleteKeyTree(string subkey); 

  读取键值的方法原型如下:
   public object GetValue(string name);
  public object GetValue(string name,object defaultValue); 

  参数name表示键的名称,返回类型是一个object类型,如果指定的键不存在则返回null。如果失败又不希望返回的值是null则可以指定参数defaultValue,指定了参数则在读取失败的情况下返回该参数指定的值。

  设置键值的方法原型如下:
   public object SetValue(string name,object value);

抱歉!评论已关闭.