C#创建一个公共类,但是为什么只能引用其中的static方法,而不能调用public方法?

如题,各位大牛帮忙给说一下原因及解决办法,谢谢。如题,各位大牛帮忙给说一下原因及解决办法,谢谢。

1个回答

静态方法能调用,说明引用是可以的
1首先排除是否忘记对象实例化
2其次看看是否是抽象方法,导致没法直接点出来
3然后就是关闭VS或者你的其他的编辑器,重新打开,再试试

KuangPu_001
狂舖 好的,谢谢
11 个月之前 回复
weixin_41072161
小眼聚光~ 回复狂舖: 照理说,你能调用静态方法,那正常的方法都能调用的,跟你在窗口的后端代码没啥关系,这个问题要不就是粗心的小问题,要不就得上手看代码。反正我是想不出来这个啥情况。。。
11 个月之前 回复
KuangPu_001
狂舖 这个类库昨天写完的,然后定义了很多个执行sql语句并返回结果的public方法,但是只能调用该类里面的static方法。public partial class Form1 : Form 这是我创建的那个Windows窗口的开头,是不是这个地方有影响呢
11 个月之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
C# 如何将一个类中全部字段添加到List中(字段为自定义类,引用类型,不是值类型)?
自定义了一个类,里面包含了很多字段(也是自定义的类),如何将类中的字段全部添加到list中 做这个功能主要是为了能够通过list来访问FileInfoInIni,调用FileInfoInIni的方法。 或者哪位大神有更好的办法能实现这个功能也行 ``` class SystemParamClass { public String ModelFileSavePathName = "D:/Data/SystemParam";//保存参数的文件夹名称 public String ModelSystemParamFileName = "/SystemParam.ini"; public List<FileInfoInIni> AllIniParam = new List<FileInfoInIni>(); public FileInfoInIni LeftDownCamGrapImageHeight; public FileInfoInIni LeftDownCamGrapImagePoseX; public FileInfoInIni LeftDownCamGrapImagePoseY; public FileInfoInIni RightDownCamGrapImageHeight public FileInfoInIni RightDownCamGrapImagePoseX; public FileInfoInIni RightDownCamGrapImagePoseY; } ``` 如何写一个方法,自动将 FileInfoInIni 全部添加到 AllIniParam 中 FileInfoInIni  为自定义的类,我试过了反射,只能设置值,不知道怎么转换类型,然后添加进去 ``` public static void AddTolist(object TempClass) { Type t = TempClass.GetType(); FieldInfo[] fields = t.GetFields(BindingFlags.NonPublic | BindingFlags.Instance | BindingFlags.Static | BindingFlags.Public); foreach (FieldInfo field in fields) { if (field.FieldType == typeof(FileInfoInIni)) { Console.WriteLine("Field:" + field); Console.WriteLine("Field:" + field.Name ); } //Console.WriteLine("Field:" + field); } } ``` 不能强制转换类型 ![图片说明](https://img-ask.csdn.net/upload/201911/15/1573789359_269905.jpg) FileInfoInIni的定义 ``` public class FileInfoInIni { private string FilePathAndName; private string FileSection; private string FileAppName; public object Value; public string Key { get => FileAppName; } [DllImport("kernel32", CharSet = CharSet.Ansi, EntryPoint = "GetPrivateProfileStringA", ExactSpelling = true, SetLastError = true)] private static extern int GetPrivateProfileString([MarshalAs(UnmanagedType.VBByRefStr)] ref string lpApplicationName, [MarshalAs(UnmanagedType.VBByRefStr)] ref string lpKeyName, [MarshalAs(UnmanagedType.VBByRefStr)] ref string lpDefault, [MarshalAs(UnmanagedType.VBByRefStr)] ref string lpReturnedString, int nSize, [MarshalAs(UnmanagedType.VBByRefStr)] ref string lpFileName); [DllImport("kernel32", CharSet = CharSet.Ansi, EntryPoint = "WritePrivateProfileStringA", ExactSpelling = true, SetLastError = true)] private static extern int WritePrivateProfileString([MarshalAs(UnmanagedType.VBByRefStr)] ref string lpApplicationName, [MarshalAs(UnmanagedType.VBByRefStr)] ref string lpKeyName, [MarshalAs(UnmanagedType.VBByRefStr)] ref string lpString, [MarshalAs(UnmanagedType.VBByRefStr)] ref string lpFileName); public string GetINI(string Section, string AppName, string lpDefault, string FileName) { string text = Strings.LSet("", 256); FileInfoInIni.GetPrivateProfileString(ref Section, ref AppName, ref lpDefault, ref text, Strings.Len(text), ref FileName); return Strings.Left(text, checked(Strings.InStr(text, "\0", CompareMethod.Binary) - 1)); } public long WriteINI(string Section, string AppName, string lpDefault, string FileName) { return (long)FileInfoInIni.WritePrivateProfileString(ref Section, ref AppName, ref lpDefault, ref FileName); } public bool ReadValue() { bool result; try { this.Value = this.GetINI(this.FileSection, this.FileAppName, "", this.FilePathAndName); bool flag = Operators.ConditionalCompareObjectEqual(this.Value, "", false); if (flag) { result = false; return result; } } catch (Exception expr_41) { ProjectData.SetProjectError(expr_41); result = false; ProjectData.ClearProjectError(); return result; } result = true; return result; } public bool SaveValue() { bool result; try { string left = this.Value.ToString(); this.WriteINI(this.FileSection, this.FileAppName, Conversions.ToString(this.Value), this.FilePathAndName); string iNI = this.GetINI(this.FileSection, this.FileAppName, "", this.FilePathAndName); bool flag = Operators.CompareString(left, iNI, false) != 0; if (flag) { result = false; return result; } } catch (Exception expr_71) { ProjectData.SetProjectError(expr_71); result = false; ProjectData.ClearProjectError(); return result; } result = true; return result; } public FileInfoInIni(string TempFilePathAndName, string TempFileSection, string TempFileAppName) { this.Value = RuntimeHelpers.GetObjectValue(new object()); this.FilePathAndName = TempFilePathAndName; this.FileSection = TempFileSection; this.FileAppName = TempFileAppName; this.Value = null; } public void dispose() { this.FilePathAndName = ""; this.FileSection = ""; this.FileAppName = ""; this.Value = null; } } ```
C#静态类中的静态数组相关
我在静态类中定义一个静态数组,但是想在该类中初始化这个数组,也就是给数组赋值。 ``` public static class GlobalCont { private const int ITEMNUM = 20; private static string[] itemname; public static string[] Itemname { get { return GlobalCont.itemname; } set { for (int i = 0; i < ITEMNUM; i++) { itemname[i]=APPL.Properties.Resources.ResourceManager.GetString("str"+String.Format("{0:D3}",i)); } } } } ``` 1.我想知道怎样可以赋值,使得在别的类中调用该数组时已经是被初始化过的。 2.我想知道重新封装一个属性时set有什么用途,可以用来初始化数据吗?(我大概知道这里的写法是有误的,但是不会用)
C#调用C++ dll的参数转换问题,如何转换char **类型的参数到C#
这是C++代码 DLL_API int Onvif_Discovery(char** deviceaddress, int* nDevices); 这是C#调用 [DllImport("OnvifDll.dll",EntryPoint="Onvif_Discovery", CharSet=CharSet.Ansi,CallingConvention=CallingConvention.StdCall)] public extern static int Onvif_Discovery(out IntPtr deviceAddr, ref int nDevices); 其中deviceAddr的参数我试过ref string,string,stringbulider,都报错,尝试读写受保护的内存。 初学C#的妹子一枚,希望哪位有经验的C#大神给予解答!万分感激!!!
C# 关于 static class 的应用
我们通常定义一个静态对象: public static class Common { public static readonly string A = "a"; public static readonly string B = "b"; } 通过 Common.A 这样的方式就可以使用了。 但是我现在希望 Common 类支持另外一个使用方式----可以将它作为另一个类的一个属性字段: public class Tools { ///应当如何被定义? public Common Common { get; set; } } 我希望同时可以这样使用 : public class Test { public void sample() { Tools tool = new Tools(); ///可以这样用 string value = tool.Common.A; ///也可以这样用 value = Common.A; } } 那么在Tools对象里面,Common应该怎样被定义? 这样做的原因:Tools 是一个常用对象,用户一定知道有Tools,但不一定知道有 Common,将Common定义在Tools可以方便使用,但是 Common 确实只是一个常量集合,没必要进行 new 操作。
C#中普通类中的静态类成员不能自动实例化后调用,需要显式实例化?
在VS2015版本的C#,在一个大类中(Atest),声明一系列的静态成员类(Btest)。 意图实现无需实例化下,调用Btest的方法及成员。也就是普遍的全局变量; 但一直实现不了。大类(Atest)为普通类不可以,声明为Static也不可以。 烦请大神解答一下。 感谢老马的回复! 在段码增补后是可以运行了。是不说,普通类内部定义的静态类成员必须显式实例化后,才可以使用。并且是唯一的?而不是像一些资料中声明的,可以自动实例化? 代码如下: ``` using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace ConsoleApplication1 { class Program { static void Main(string[] args) { Console.WriteLine("程序开始");//程序开始 **_ if (Atest.BtestC == null) //检测未实例化下的状态 { Atest.BtestC = new Btest(); }**_ if (Atest.BtestC == null) //检测未实例化下的状态 { Console.WriteLine ("普通类的成员:静态类为空"); } //运行为无数据 else { Atest.BtestC.Ashow (); } Console.WriteLine(Atest.AAid);//显示为空 Atest.AAid = "已设置Atest.AAid"; //检测静态字符串变量 Console.WriteLine(Atest.AAid);//显示有数据 Atest NAtest = new Atest("实例化Atest"); Console.WriteLine(NAtest.Aid);//显示实例化后的标志 if (Atest.BtestC == null) //检测实例化下的类中状态 { Console.WriteLine("普通类的成员:静态类为空"); } //运行为无数据 else { Atest.BtestC.Ashow(); } //NAtest.BtestC.Ashow(); 此种方式不可以调用 Console.Read(); } } public class Atest { public static Btest BtestC { get; set; } public static String AAid { get; set; } public string Aid { get; set; } public Atest() { Aid = "Default"; } public Atest(string NAid ) { Aid = NAid; } } public class Btest { public string Bid { get; set; } public Btest() { Bid = "Default"; } public Btest(string BBid ) { Bid = BBid; } public void Ashow() { //Console.WriteLine(Bid); Console.WriteLine("Btest.Ashow"); } } } ```
一个关于C#结构的问题
定义一个C#结构,为啥不能在结构中,给里面的字段赋初始值? 假如在结构中,声明字段为static类型,是不是就可以给字段赋初始值了呢?
求助C#演示抽象类和接口的一个问题
问题:编写一个程序以演示抽象类和接口,要求如下: (1)定义一个Employee抽象类,其中包含Name和Salary属性及Print()抽象方法。类似地,定义IPromotable和IGoodStudent两个接口,使它们都包含Promote()方法。 (2)从Employee()类派生出Shixi类,使其包含存储实习期的字段months。从Emphoyee类和IPromotable接口类派生出Programmer类,使其有存储加班时间的hours字段,并通过实现接口中的Promote()方法将薪水提高到1.5倍。 (3)从Employee类以及IPromotable和IGoodWorker接口派生出Manager类,使其具有存储秘书名字的mishu字段,并通过实现IPromotable接口中的Promote()方法将薪水提高到1.8倍,通过实现IGoodWorker接口中的Promote()方法输出经理职位晋升。派生类中重写Print()方法,输出职员的姓名和薪水,平均加班时间、秘书、加新后的薪水等信息。 编写一个程序以演示抽象类和接口,要求如下: (1)定义一个Employee抽象类,其中包含Name和Salary属性及Print()抽象方法。类似地,定义IPromotable和IGoodStudent两个接口,使它们都包含Promote()方法。 (2)从Employee()类派生出Shixi类,使其包含存储实习期的字段months。从Emphoyee类和IPromotable接口类派生出Programmer类,使其有存储加班时间的hours字段,并通过实现接口中的Promote()方法将薪水提高到1.5倍。 (3)从Employee类以及IPromotable和IGoodWorker接口派生出Manager类,使其具有存储秘书名字的mishu字段,并通过实现IPromotable接口中的Promote()方法将薪水提高到1.8倍,通过实现IGoodWorker接口中的Promote()方法输出经理职位晋升。派生类中重写Print()方法,输出职员的姓名和薪水,平均加班时间、秘书、加新后的薪水等信息。 提示:两个接口包含相同名称的方法,注意体会显式接口实现的使用。程序运行结果如图1所示,类关系如图2所示。 代码: ``` using System; namespace ConsoleApp8 { public abstract class Employee { protected String Name; protected double salary; abstract public void print(); } public interface IPromotable { void Promote(); } public interface IGoodWorker { void Promote(); } public class Shixi : Employee { protected int months; public Shixi(String Name, int salary, int months) { this.Name = Name; this.salary = salary; this.months = months; } public override void print() { Console.WriteLine("实习生: "); Console.WriteLine("姓名: " + this.Name); Console.WriteLine("薪水: " + this.salary); Console.WriteLine("实习期(月): " + this.months); } } public class Programmer : Shixi, IPromotable { protected int hours; public Programmer(String Name, int salary, int hours):base(Name,salary,hours) { this.Name = Name; this.salary = salary; this.hours = hours; } public override void print() { Console.WriteLine("程序员"); Console.WriteLine("姓名:" + this.Name); Console.WriteLine("薪水:" + this.salary); Console.WriteLine("平均加班时间:" + this.hours); } public void Promote() { Console.WriteLine("加班后的薪水:" + this.salary * 1.5); } } public class Manager : Programmer, IPromotable, IGoodWorker { protected int mishu; public Manager(String Name, int salary,int mishu):base(Name,salary,mishu) { this.Name = Name; this.salary = salary; this.mishu = mishu; } public override void print() { Console.WriteLine("经理"); Console.WriteLine("姓名:" + this.Name); Console.WriteLine("薪水:" + this.salary); Console.WriteLine("秘书:" + this.mishu); } void IPromotable.Promote() { Console.WriteLine("加班后的薪水:" + this.salary * 1.8); } void IGoodWorker.Promote() { Console.WriteLine("经理是优秀的,所以获得职位的晋升"); } } class program { static void Main(string[] args) { Shixi shixi = new Shixi("赵丰", 5500, 2); shixi.print(); Console.WriteLine(); Programmer programmer = new Programmer("张强", 45000, 4); programmer.print(); IPromotable promotable = programmer; promotable.Promote(); Console.WriteLine(); Manager manager = new Manager("约翰", 120000, "玛丽"); manager.print(); IPromotable promotable1 = manager; IGoodWorker goodworker = manager; promotable1.Promote(); goodworker.Promote(); } } } ``` 问题:主方法里“玛丽” CS1503 参数 3: 无法从“string”转换为“int” 不知道哪里错了
C#引用C++ Dll类型转换问题
C++中*.h中的一个方法 int WINAPI SubmitSM( unsigned char byMsgType, // 短消息类型 int *FCS = NULL //返回:失败原因 ); 在C#中调用这个方法 public static extern int SubmitSM(byte byMsgType, ref int FCS); 提示报错:原因可能是托管的 PInvoke 签名与非托管的目标签名不匹配。请检查 PInvoke 签名的调用约定和参数与非托管的目标签名是否匹配。 我在网上查了原因,是参数不匹配。就是int *FCS = NULL 与ref int FCS不匹配。 如果写成ref int FCS=null,C#会提示ref不能赋初始值。 希望高手能帮帮我。
C#如何通过星星类扩展出流星类,流星通过重写星星的show方法显示出一颗移动的星星
![图片说明](https://img-ask.csdn.net/upload/201911/11/1573455421_114465.png)![图片说明](https://img-ask.csdn.net/upload/201911/11/1573455430_423065.png) star类可以显示出一颗星星,现在要新建一个流星类重写star的show方法,显示出一个移动的星星。。求助 ``主函数` using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Threading; using System.Collections; namespace 满天星星 { class Program { static void Main(string[] args) { Console.WriteLine("请输入星星数量:"); int num = Convert.ToInt32(Console.ReadLine()); Random r = new Random(); char[] shapes = { '!', '@', '#', '$', '%', '^', '&', '*' }; for (int i = 0; i < num; i++) { Star star = new Star(shapes[r.Next(8)], r.Next(52), r.Next(52), r.Next(15)); star.PrintStar(); } } } } ``` ``` star类 using System; using System.Collections; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace 满天星星 { class Star { public int x; public int y; public int yanse; public char shape; public Star() { shape = '*'; } public Star(char Z, int x, int y,int k) { this.x = x; this.y = y; this.yanse = k; this.shape = Z; } public virtual void PrintStar() { Console.SetCursorPosition(x, y); Console.ForegroundColor = (ConsoleColor)(int)yanse; Console.Write("{0}", shape); } } } ```
C#调用运行第三方程序 问题
在C#界面放一个button按钮,点击button按钮,打开一个第三方的程序的源码程序, 然后点击工具栏的运行按钮图标,让整个程序运行起来, 我现在可以做到打开程序, private static System.Diagnostics.Process p; p = new System.Diagnostics.Process(); p.StartInfo.FileName = "目标程序"; p.Start(); 但是怎么做到点击第三方环境的运行按钮,让程序跑起来? spy++检测不到句柄和标题, 或者是不是这个运行按钮有什么指令可以让他运行,不是F5
C#同一个类只能被有限个线程使用吗
我使用了一个post,get的类,多个线程分别声明使用一个它的对象进行http请求发送和response接收,可是我发现部分线程在开始发送http请求的时候就终止了,我把那个类复制了一份,改了个名字,让那些失败的线程使用这个新复制的类结果程序正常运行,于是就产生了这个问题,一个类只能被有限个线程访问吗?(该类不包含static成员,所有函数值处理http请求和return接收的数据)
C#调用C++和opencv生成的dll库文件,其中函数中带有指针
大家好,我用C#调用C++的dll,其中一个函数中有指针,参数的定义在C++中是一个结构体,但是我现在遇到的问题是无法获取托管类型的地址和大小,或无法声明指向它的指针,下面我把这个函数在C++中的定义和我自己转到C#中的定义给大家贴出来,大家帮帮忙,本人属于C++和C#新手。 C++ 1. int THFI_Create (short nChannelNum,THFI_Param* pParam) 功能:初始化THFaceImage SDK,只需在应用程序初始化时调用一次 参数: nChannelNum,通道数,用于多线程的通道,每个线程对应一个通道. 每个线程使用的通道ID从0到nChannelNum-1,如通道数为4,那么每个线程使用的合法通道ID为0,1,2,3 pParam,算法参数 返回值: Int整型,返回实际成功初始化的通道数 struct THFI_Param { int nMinFaceSize;//min face width size can be detected,default is 50 pixels int nRollAngle;//max face roll angle,default is 30(degree) bool bOnlyDetect;//only detect face or not(if it's true,only Detect API is enable,Feature API is disable),defaule is false(Detect API is enable,and Feature API is enable) DWORD dwReserved;//reserved value,must be NULL THFI_Param() { nMinFaceSize=50; nRollAngle=30; bOnlyDetect=false; dwReserved=NULL; } }; C# [StructLayout(LayoutKind.Sequential)] public struct THFI_Param { [FieldOffset(0)] public Int16 nMinFaceSize; [FieldOffset(2)] public Int16 nRollAngle; [FieldOffset(4)] public Boolean bOnlyDetect; [FieldOffset(6)] public UInt32? dwReserved; }; [DllImport("THFaceImage.dll", EntryPoint = "THFI_Create", CharSet = CharSet.Auto)] unsafe static extern int THFI_Create(Int16 nChannelNum, THFI_Param* pParam); THFI_Create显示错误 CS0208: 无法获取托管类型(“WindowsFormsApplication1.Form1.THFI_Param”)的地址和大小,或无法声明指向它的指针。
c#调用C++dll 返回值为结构体,其中包含string, 报错
c++ ``` struct ClientInfo { char adress[4]; }; extern "C" __declspec(dllexport) ClientInfo Test() { ClientInfo c; strcpy_s(c.adress, "1234"); return c; } ``` c# ``` [DllImport("ManagerAPI.dll")] public static extern ClientInfo Test(); [StructLayout(LayoutKind.Sequential, CharSet = CharSet.Ansi)] public struct ClientInfo { [MarshalAs(UnmanagedType.ByValTStr, SizeConst =4)] public string address; } ClientInfo c =Test(); Console.WriteLine(c.address); ``` 调用的时候老是报 方法类型签名与pinvoke不兼容 c++ 中的char[] 到底对应着c#中的什么类型。 求助
C#中基类的引用指向派生类时,不理解隐藏方法的输出结果
对于隐藏方法不明白的是: (1)当基类的引用指向派生类时,即 Car bike = new Bike("bike");bike的run为什么是用的基类 Car的方法呢? (2)当用派生类引用指向派生类时,即 Bike bike1 = new Bike("bike1");bike1的run这个时候才是用的派生类Bike的run方法. 但是对于方法重写的话,Car bike = new Bike("bike");Bike bike1 = new Bike("bike1");这两种方式都是调用的派生类中的方法。所以不太明白上述隐藏方法书输出的结果。谢谢指点。 ``` class Car { public string name; public void run() { Console.WriteLine(name+" is runing !!!!"); } virtual public void stopRun() { Console.WriteLine(name + "stop run !!!!"); } } class Automobile:Car { public Automobile(string name) { this.name = name; } new public void run() { Console.WriteLine(name + " is runing"); } override public void stopRun() { Console.WriteLine(name + " stop run"); } } class Bike : Car { public Bike(string name) { this.name = name; } new public void run() { Console.WriteLine(name + " is runing"); } override public void stopRun() { Console.WriteLine(name + " stop run"); } } class testHide { static void Main(string[] args) { Automobile automobile = new Automobile("automobile"); automobile.run(); //"automobile is runing" automobile.stopRun(); //"automobile stop run" Car bike = new Bike("bike"); car.run(); //"bike is runing !!!!" //对于这里的输出不太理解 car.stopRun();//"bike stop run" Bike bike1 = new Bike("bike1"); bike1.run(); //"bike1 is runing" bike1.stopRun();//"bike1 stop run" } } ```
C#中关于集合类的一个问题
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Collections; namespace ConsoleApplication1 { public class Cards { Hashtable htCards; ArrayList randomList; public Hashtable SetCards() //哈希表添加54张牌 { htCards = new Hashtable(54, 1); int i; string card = ""; for (i = 1; i <= 13; i++) { if (i <= 10) { card = "红桃" + i.ToString(); } else { switch (i) { case 11: card = "红桃J"; break; case 12: card = "红桃Q"; break; case 13: card = "红桃K"; break; } } htCards.Add(i, card); } for (i = 14; i <= 26; i++) { if (i <= 23) { card = "黑桃" + (i - 13).ToString(); } else { switch (i) { case 24: card = "黑桃J"; break; case 25: card = "黑桃Q"; break; case 26: card = "黑桃K"; break; } } htCards.Add(i, card); } for (i = 27; i <= 39; i++) { if (i <= 36) { card = "方片" + (i - 26).ToString(); } else { switch (i) { case 37: card = "方片J"; break; case 38: card = "方片Q"; break; case 39: card = "方片K"; break; } } htCards.Add(i, card); } for (i = 40; i <= 52; i++) { if (i <= 49) { card = "梅花" + (i - 39).ToString(); } else { switch (i) { case 50: card = "梅花J"; break; case 51: card = "梅花Q"; break; case 52: card = "梅花K"; break; } } htCards.Add(i, card); } htCards.Add(53, "小王"); htCards.Add(54, "大王"); return htCards; } public ArrayList SendCards() //发牌,生成13个不重复的随机数 { randomList = new ArrayList(); Random r = new Random(); for (int j = 0; j < 13; j++) { int index; index = r.Next(1, 54); htCards.Remove(index); while (!htCards.Contains (index)||randomList.Contains(index)) { index = r.Next(1, 54); } randomList.Add(index); } return randomList; } } class Program { static void Main(string[] args) { Cards cards = new Cards(); Hashtable hxCards = cards.SetCards(); int count = 0; for (int i = 0; i < 2; i++) { ArrayList indexList = cards.SendCards(); Console.WriteLine("第{0}位玩家的牌已发,如下:",i+1); foreach (int index in indexList) { if (count % 5 == 0) { Console.WriteLine(); } count++; Console.Write("{0}\t", hxCards[index]); } Console.WriteLine(); } Console.ReadLine(); } } } 程序用VS运行出来各种问题!!!各位大神帮我看看。![图片说明](https://img-ask.csdn.net/upload/201505/06/1430926576_137800.jpg)
C# 调用C 的dll参数为回调函数
C# 调用C 的dll参数为回调函数 C 代码: ``` typedef void (*LP_GET)(unsigned char *buf) ; typedef unsigned char (*LP_UARTA_INIT)(unsigned char no, int baudrate, LP_GET GetFun) ; ``` C# 代码: ``` public delegate void LP_GET(byte[] buf); public static extern char UARTA_Init(char no, int baudrate, LP_GET getFun); LP_GET lpGet = new LP_GET(LP_GET_GetFun); UARTA_Init('1', 2, lpGet); ``` 在C#我用委托,但是会报错,信息:尝试读取或写入受保护的内存。这通常指示其他内存已损坏。我觉得是不是参数类型不对啊。
C# windows from 对另一个页面的static数组的调用
出错label1.Text = Name_shezhi.name[1].ToString(); 未将对象的引用到对象的实例 另一个页面 public static string[] name=new string[1000];
老师 们看看 C# C#C#
要求输入的数在1-20 ; 输入一个数 ,求其阶乘 这是小生我的 ;老师看看错在那儿了 using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace ConsoleApplication10 { class Program { static void Main(string[] args) { int c; c = Convert.ToInt32(Console.ReadLine()); getways.jiecheng(c); Console.WriteLine(getways.z); } } class getways { public static int z; public static int jiecheng(int x) { if (x > 20) { Console.WriteLine("cuowu"); } if (x == 1) { return x; } z = x * getways.jiecheng(z - 1); return z; } } }
c#fileStream将绝对路径识别为相对路径
路径设置为C:\Users\lijunliang\source\repos\ConsoleApp12\ConsoleApp12\bin\Debug\netcoreapp3.1\worklist.csv 用filestream打开的时候不能识别,filestream总是认为是相对路径将“C:\Users\lijunliang\source\repos\ConsoleApp12\ConsoleApp12\bin\Debug\netcoreapp3.1\”补上导致抛出异常![图片说明](https://img-ask.csdn.net/upload/201912/30/1577674946_255468.png) ``` class Program { static void Main(string[] args) { //LisSystemApplication.Current.Prepare(); bool result = true; string lisFilePath = @"‪C:\Users\lijunliang\source\repos\ConsoleApp12\ConsoleApp12\bin\Debug\netcoreapp3.1\worklist.csv"; List<List<string>> lisContests = CSVFileHelper.LoadCSVFile(lisFilePath); Console.WriteLine(result); } } internal class CSVFileHelper { internal static List<List<string>> LoadCSVFile(string lisFilePath) { List<List<string>> samples = new List<List<string>>(); using (FileStream stream = new FileStream(lisFilePath,FileMode.Open,FileAccess.ReadWrite)) { using (StreamReader sr = new StreamReader(stream, Encoding.UTF8)) { while (sr.Peek() >= 0) { string[] recordResult = sr.ReadLine().Split(new char[] { ',' }); List<string> recordList = new List<string>(); recordList.AddRange(recordResult); samples.Add(recordList); } } } return samples; } } ```
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它是一个过程,是一个不断累积、不断沉淀、不断总结、善于传达自己的个人见解以及乐于分享的过程。
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过...
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
linux系列之常用运维命令整理笔录
本博客记录工作中需要的linux运维命令,大学时候开始接触linux,会一些基本操作,可是都没有整理起来,加上是做开发,不做运维,有些命令忘记了,所以现在整理成博客,当然vi,文件操作等就不介绍了,慢慢积累一些其它拓展的命令,博客不定时更新 free -m 其中:m表示兆,也可以用g,注意都要小写 Men:表示物理内存统计 total:表示物理内存总数(total=used+free) use...
比特币原理详解
一、什么是比特币 比特币是一种电子货币,是一种基于密码学的货币,在2008年11月1日由中本聪发表比特币白皮书,文中提出了一种去中心化的电子记账系统,我们平时的电子现金是银行来记账,因为银行的背后是国家信用。去中心化电子记账系统是参与者共同记账。比特币可以防止主权危机、信用风险。其好处不多做赘述,这一层面介绍的文章很多,本文主要从更深层的技术原理角度进行介绍。 二、问题引入 假设现有4个人...
程序员接私活怎样防止做完了不给钱?
首先跟大家说明一点,我们做 IT 类的外包开发,是非标品开发,所以很有可能在开发过程中会有这样那样的需求修改,而这种需求修改很容易造成扯皮,进而影响到费用支付,甚至出现做完了项目收不到钱的情况。 那么,怎么保证自己的薪酬安全呢? 我们在开工前,一定要做好一些证据方面的准备(也就是“讨薪”的理论依据),这其中最重要的就是需求文档和验收标准。一定要让需求方提供这两个文档资料作为开发的基础。之后开发...
网页实现一个简单的音乐播放器(大佬别看。(⊙﹏⊙))
今天闲着无事,就想写点东西。然后听了下歌,就打算写个播放器。 于是乎用h5 audio的加上js简单的播放器完工了。 演示地点演示 html代码如下` music 这个年纪 七月的风 音乐 ` 然后就是css`*{ margin: 0; padding: 0; text-decoration: none; list-...
Python十大装B语法
Python 是一种代表简单思想的语言,其语法相对简单,很容易上手。不过,如果就此小视 Python 语法的精妙和深邃,那就大错特错了。本文精心筛选了最能展现 Python 语法之精妙的十个知识点,并附上详细的实例代码。如能在实战中融会贯通、灵活使用,必将使代码更为精炼、高效,同时也会极大提升代码B格,使之看上去更老练,读起来更优雅。
数据库优化 - SQL优化
以实际SQL入手,带你一步一步走上SQL优化之路!
通俗易懂地给女朋友讲:线程池的内部原理
餐盘在灯光的照耀下格外晶莹洁白,女朋友拿起红酒杯轻轻地抿了一小口,对我说:“经常听你说线程池,到底线程池到底是个什么原理?”
经典算法(5)杨辉三角
杨辉三角 是经典算法,这篇博客对它的算法思想进行了讲解,并有完整的代码实现。
使用 Docker 部署 Spring Boot 项目
Docker 技术发展为微服务落地提供了更加便利的环境,使用 Docker 部署 Spring Boot 其实非常简单,这篇文章我们就来简单学习下。首先构建一个简单的 S...
英特尔不为人知的 B 面
从 PC 时代至今,众人只知在 CPU、GPU、XPU、制程、工艺等战场中,英特尔在与同行硬件芯片制造商们的竞争中杀出重围,且在不断的成长进化中,成为全球知名的半导体公司。殊不知,在「刚硬」的背后,英特尔「柔性」的软件早已经做到了全方位的支持与支撑,并持续发挥独特的生态价值,推动产业合作共赢。 而对于这一不知人知的 B 面,很多人将其称之为英特尔隐形的翅膀,虽低调,但是影响力却不容小觑。 那么,在...
面试官:你连RESTful都不知道我怎么敢要你?
干货,2019 RESTful最贱实践
刷了几千道算法题,这些我私藏的刷题网站都在这里了!
遥想当年,机缘巧合入了 ACM 的坑,周边巨擘林立,从此过上了"天天被虐似死狗"的生活… 然而我是谁,我可是死狗中的战斗鸡,智力不够那刷题来凑,开始了夜以继日哼哧哼哧刷题的日子,从此"读题与提交齐飞, AC 与 WA 一色 ",我惊喜的发现被题虐既刺激又有快感,那一刻我泪流满面。这么好的事儿作为一个正直的人绝不能自己独享,经过激烈的颅内斗争,我决定把我私藏的十几个 T 的,阿不,十几个刷题网...
白话阿里巴巴Java开发手册高级篇
不久前,阿里巴巴发布了《阿里巴巴Java开发手册》,总结了阿里巴巴内部实际项目开发过程中开发人员应该遵守的研发流程规范,这些流程规范在一定程度上能够保证最终的项目交付质量,通过在时间中总结模式,并推广给广大开发人员,来避免研发人员在实践中容易犯的错误,确保最终在大规模协作的项目中达成既定目标。 无独有偶,笔者去年在公司里负责升级和制定研发流程、设计模板、设计标准、代码标准等规范,并在实际工作中进行...
SQL-小白最佳入门sql查询一
不要偷偷的查询我的个人资料,即使你再喜欢我,也不要这样,真的不好;
redis分布式锁,面试官请随便问,我都会
文章有点长并且绕,先来个图片缓冲下! 前言 现在的业务场景越来越复杂,使用的架构也就越来越复杂,分布式、高并发已经是业务要求的常态。像腾讯系的不少服务,还有CDN优化、异地多备份等处理。 说到分布式,就必然涉及到分布式锁的概念,如何保证不同机器不同线程的分布式锁同步呢? 实现要点 互斥性,同一时刻,智能有一个客户端持有锁。 防止死锁发生,如果持有锁的客户端崩溃没有主动释放锁,也要保证锁可以正常释...
项目中的if else太多了,该怎么重构?
介绍 最近跟着公司的大佬开发了一款IM系统,类似QQ和微信哈,就是聊天软件。我们有一部分业务逻辑是这样的 if (msgType = "文本") { // dosomething } else if(msgType = "图片") { // doshomething } else if(msgType = "视频") { // doshomething } else { // doshom...
Nginx 原理和架构
Nginx 是一个免费的,开源的,高性能的 HTTP 服务器和反向代理,以及 IMAP / POP3 代理服务器。Nginx 以其高性能,稳定性,丰富的功能,简单的配置和低资源消耗而闻名。 Nginx 的整体架构 Nginx 里有一个 master 进程和多个 worker 进程。master 进程并不处理网络请求,主要负责调度工作进程:加载配置、启动工作进程及非停升级。worker 进程负责处...
“狗屁不通文章生成器”登顶GitHub热榜,分分钟写出万字形式主义大作
一、垃圾文字生成器介绍 最近在浏览GitHub的时候,发现了这样一个骨骼清奇的雷人项目,而且热度还特别高。 项目中文名:狗屁不通文章生成器 项目英文名:BullshitGenerator 根据作者的介绍,他是偶尔需要一些中文文字用于GUI开发时测试文本渲染,因此开发了这个废话生成器。但由于生成的废话实在是太过富于哲理,所以最近已经被小伙伴们给玩坏了。 他的文风可能是这样的: 你发现,...
程序员:我终于知道post和get的区别
是一个老生常谈的话题,然而随着不断的学习,对于以前的认识有很多误区,所以还是需要不断地总结的,学而时习之,不亦说乎
《程序人生》系列-这个程序员只用了20行代码就拿了冠军
你知道的越多,你不知道的越多 点赞再看,养成习惯GitHub上已经开源https://github.com/JavaFamily,有一线大厂面试点脑图,欢迎Star和完善 前言 这一期不算《吊打面试官》系列的,所有没前言我直接开始。 絮叨 本来应该是没有这期的,看过我上期的小伙伴应该是知道的嘛,双十一比较忙嘛,要值班又要去帮忙拍摄年会的视频素材,还得搞个程序员一天的Vlog,还要写BU...
加快推动区块链技术和产业创新发展,2019可信区块链峰会在京召开
11月8日,由中国信息通信研究院、中国通信标准化协会、中国互联网协会、可信区块链推进计划联合主办,科技行者协办的2019可信区块链峰会将在北京悠唐皇冠假日酒店开幕。   区块链技术被认为是继蒸汽机、电力、互联网之后,下一代颠覆性的核心技术。如果说蒸汽机释放了人类的生产力,电力解决了人类基本的生活需求,互联网彻底改变了信息传递的方式,区块链作为构造信任的技术有重要的价值。   1...
Java世界最常用的工具类库
Apache Commons Apache Commons有很多子项目 Google Guava 参考博客
程序员把地府后台管理系统做出来了,还有3.0版本!12月7号最新消息:已在开发中有github地址
第一幕:缘起 听说阎王爷要做个生死簿后台管理系统,我们派去了一个程序员…… 996程序员做的梦: 第一场:团队招募 为了应对地府管理危机,阎王打算找“人”开发一套地府后台管理系统,于是就在地府总经办群中发了项目需求。 话说还是中国电信的信号好,地府都是满格,哈哈!!! 经常会有外行朋友问:看某网站做的不错,功能也简单,你帮忙做一下? 而这次,面对这样的需求,这个程序员...
网易云6亿用户音乐推荐算法
网易云音乐是音乐爱好者的集聚地,云音乐推荐系统致力于通过 AI 算法的落地,实现用户千人千面的个性化推荐,为用户带来不一样的听歌体验。 本次分享重点介绍 AI 算法在音乐推荐中的应用实践,以及在算法落地过程中遇到的挑战和解决方案。 将从如下两个部分展开: AI算法在音乐推荐中的应用 音乐场景下的 AI 思考 从 2013 年 4 月正式上线至今,网易云音乐平台持续提供着:乐屏社区、UGC...
【技巧总结】位运算装逼指南
位算法的效率有多快我就不说,不信你可以去用 10 亿个数据模拟一下,今天给大家讲一讲位运算的一些经典例子。不过,最重要的不是看懂了这些例子就好,而是要在以后多去运用位运算这些技巧,当然,采用位运算,也是可以装逼的,不信,你往下看。我会从最简单的讲起,一道比一道难度递增,不过居然是讲技巧,那么也不会太难,相信你分分钟看懂。 判断奇偶数 判断一个数是基于还是偶数,相信很多人都做过,一般的做法的代码如下...
为什么要学数据结构?
一、前言 在可视化化程序设计的今天,借助于集成开发环境可以很快地生成程序,程序设计不再是计算机专业人员的专利。很多人认为,只要掌握几种开发工具就可以成为编程高手,其实,这是一种误解。要想成为一个专业的开发人员,至少需要以下三个条件: 1) 能够熟练地选择和设计各种数据结构和算法 2) 至少要能够熟练地掌握一门程序设计语言 3) 熟知所涉及的相关应用领域的知识 其中,后两个条件比较容易实现,而第一个...
Android 9.0 init 启动流程
阅读五分钟,每日十点,和您一起终身学习,这里是程序员Android本篇文章主要介绍Android开发中的部分知识点,通过阅读本篇文章,您将收获以下内容:一、启动流程概述一、 启动流程概述Android启动流程跟Linux启动类似,大致分为如下五个阶段。1.开机上电,加载固化的ROM。2.加载BootLoader,拉起Android OS。3.加载Uboot,初始外设,引导Kernel启动等。...
相关热词 c# 图片上传 c# gdi 占用内存 c#中遍历字典 c#控制台模拟dos c# 斜率 最小二乘法 c#进程延迟 c# mysql完整项目 c# grid 总行数 c# web浏览器插件 c# xml 生成xsd
立即提问