“使用 /main 编译以指定包含入口点的类型。”
Posted
技术标签:
【中文标题】“使用 /main 编译以指定包含入口点的类型。”【英文标题】:"Compile with /main to specify the type that contains the entry point." 【发布时间】:2012-04-11 10:43:20 【问题描述】:根据下面的代码,我收到以下消息。我相当确定“为什么”我得到它,我只是不知道如何重新排列代码以移动/删除/替换导致错误的语句之一。
在 "static void Main(string[] args)" 下有一堆代码,我从 http://support.microsoft.com/kb/816112 出于从自动增量获取 ID 的目的,因此当其余代码填充 Access 数据库时,我可以让它自动增量。任何帮助表示赞赏。并且欢迎使用更简单的代码获得结果的建议!
namespace WindowsFormsApplication1
public partial class Form1 : Form
OleDbConnection vcon = new OleDbConnection(@"Provider=Microsoft.ACE.OLEDB.12.0;data source=C:\Hazardous Materials\KinneyDatabase.accdb");
public Form1()
InitializeComponent();
private void Form1_Load(object sender, EventArgs e)
vcon.Open();
try
StreamReader sr = new StreamReader(@"C:\Hazardous Materials\cities.txt");
string line = sr.ReadLine();
StreamReader sr2 = new StreamReader(@"C:\Hazardous Materials\drugs.txt");
string line2 = sr2.ReadLine();
StreamReader sr3 = new StreamReader(@"C:\Hazardous Materials\strengths.txt");
string line3 = sr3.ReadLine();
while (line != null)
comboBox1.Items.Add(line);
line = sr.ReadLine();
while (line2 != null)
comboBox2.Items.Add(line2);
line2 = sr2.ReadLine();
while (line3 != null)
comboBox3.Items.Add(line3);
line3 = sr3.ReadLine();
textBox2.Text = "Date";
catch (System.Exception ex)
MessageBox.Show("Error: " + ex.Message);
private static OleDbCommand cmdGetIdentity;
[STAThread]
static void Main(string[] args)
// Open Connection
OleDbConnection vcon = new OleDbConnection(@"Provider=Microsoft.ACE.OLEDB.12.0;data source=C:\Hazardous Materials\KinneyDatabase.accdb");
vcon.Open();
// If the test table does not exist then create the Table
string strSQL;
strSQL = "CREATE TABLE AutoIncrementTest " +
"(ID int identity, Description varchar(40), " +
"CONSTRAINT AutoIncrementTest_PrimaryKey PRIMARY KEY (ID))";
// Command for Creating Table
OleDbCommand cmdJetDB = new OleDbCommand(strSQL, vcon);
cmdJetDB.ExecuteNonQuery();
// Create a DataAdaptor With Insert Command For inserting records
OleDbDataAdapter oleDa = new OleDbDataAdapter("Select * from AutoIncrementTest", vcon);
// Command to Insert Records
OleDbCommand cmdInsert = new OleDbCommand();
cmdInsert.CommandText = "INSERT INTO AutoIncrementTest (Description) VALUES (?)";
cmdInsert.Connection = vcon;
cmdInsert.Parameters.Add(new OleDbParameter("Description", OleDbType.VarChar, 40, "Description"));
oleDa.InsertCommand = cmdInsert;
// Create a DataTable
DataTable dtTest = new DataTable();
oleDa.Fill(dtTest);
DataRow drTest;
// Add Rows to the Table
drTest = dtTest.NewRow();
drTest["Description"] = "This is a Test Row 1";
dtTest.Rows.Add(drTest);
drTest = dtTest.NewRow();
drTest["Description"] = "This is a Test Row 2";
dtTest.Rows.Add(drTest);
// Create another Command to get IDENTITY Value
cmdGetIdentity = new OleDbCommand();
cmdGetIdentity.CommandText = "SELECT @@IDENTITY";
cmdGetIdentity.Connection = vcon;
// Delegate for Handling RowUpdated event
oleDa.RowUpdated += new OleDbRowUpdatedEventHandler(HandleRowUpdated);
// Update the Data
oleDa.Update(dtTest);
// Drop the table
cmdJetDB.CommandText = "DROP TABLE AutoIncrementTest";
cmdJetDB.ExecuteNonQuery();
// Release the Resources
cmdGetIdentity = null;
cmdInsert = null;
cmdJetDB = null;
vcon.Close();
vcon = null;
// Event Handler for RowUpdated Event
private static void HandleRowUpdated(object sender, OleDbRowUpdatedEventArgs e)
if (e.Status == UpdateStatus.Continue && e.StatementType == StatementType.Insert )
// Get the Identity column value
e.Row["ID"] = Int32.Parse(cmdGetIdentity.ExecuteScalar().ToString());
System.Diagnostics.Debug.WriteLine(e.Row["ID"]);
e.Row.AcceptChanges();
private void button1_Click(object sender, EventArgs e)
if (comboBox1.SelectedIndex <= 0)
MessageBox.Show("All fields must be filled out to submit the form");
else if (comboBox2.SelectedIndex <= 0)
MessageBox.Show("All fields must be filled out to submit the form");
string addRemove = "";
//string toFrom = "";
if (radioButton1.Checked)
addRemove = "add";
//toFrom = "to";
else if (radioButton2.Checked)
addRemove = "remove";
//toFrom = "from";
float mgTotal = (float.Parse(textBox1.Text) * float.Parse(comboBox3.Text));
MessageBox.Show("You have entered the following information: \n\n"
+ "\n" + "Location: " + float.Parse(comboBox1.Text)
+ "\n" + "Medication: " + comboBox2.Text
+ "\n" + "Quantity " + textBox2.Text
+ "\n" + "Strength " + float.Parse(comboBox3.Text)
+ "\n" + "Initials: " + textBox3.Text
+ "\n" + "Add or Remove: " + addRemove
+ "\n" + "Date: " + textBox2.Text);
private void button2_Click(object sender, EventArgs e)
new Form2().Show();
private void button3_Click(object sender, EventArgs e)
Application.Exit();
private void toolStripMenuItem1_Click(object sender, EventArgs e)
MessageBox.Show("Produced for use by HealthDirect© \n Scripted by Geoff Bertollini. March 2012");
private void comboBox1_SelectedIndexChanged(object sender, EventArgs e)
private void comboBox2_SelectedIndexChanged(object sender, EventArgs e)
comboBox3.SelectedIndex = comboBox2.SelectedIndex;
private void textBox2_TextChanged(object sender, EventArgs e)
var date = DateTime.Now.ToString("MM/dd/yyyy");
textBox2.Text = date;
private void label4_Click_1(object sender, EventArgs e)
private void exitToolStripMenuItem1_Click(object sender, EventArgs e)
Application.Exit();
private void button4_Click(object sender, EventArgs e)
string addRemove = "";
string toFrom = "";
if (radioButton1.Checked)
addRemove = "added";
toFrom = "to";
else if (radioButton2.Checked)
addRemove = "removed";
toFrom = "from";
float mgTotal = (float.Parse(textBox1.Text) * float.Parse(comboBox3.Text));
string vsql = string.Format("insert into Log values " +
"('0','1',2,3,'4',#5#,'6','7')",
comboBox1.Text,
comboBox2.Text,
float.Parse(textBox1.Text),
float.Parse(comboBox3.Text),
textBox3.Text,
textBox2.Text,
addRemove,
"1"
);
OleDbCommand vcom = new OleDbCommand(vsql, vcon);
vcom.ExecuteNonQuery();
MessageBox.Show("Date: " + textBox2.Text + "\n Initials: " + textBox3.Text
+ "\n" + "You have " + addRemove + " " + mgTotal + " milligrams " + "\n"
+ "of " + comboBox2.Text + "\n" + toFrom + " the inventory of \n" + comboBox1.Text);
vcom.Dispose();
【问题讨论】:
【参考方案1】:为了在 C# 中实现 Lox,我必须手动执行此操作。为了从命令行“使用/main
编译”,我使用了
csc /main:Lox.AstPrinter AstPrinter.cs Expr.cs Token.cs TokenType.cs
或者,更一般地说,如果您想在 Acme
命名空间中编译类 Foo
,这也取决于文件 A.cs、B.cs 和 C.cs:
csc /main:Acme.Foo A.cs B.cs C.cs Foo.cs
【讨论】:
【参考方案2】:没有一个答案是直截了当的。
项目的属性对话框,通过右键单击项目访问,有一个应用程序选项卡。在这个选项卡上有一个“启动对象”的下拉列表——只需选择 Visual Studio 应该定位的正确类文件。只要该类文件中有一个 Main 静态 void 事件,它就会以它为目标。确保 Main 大写。这行不通:
static void main(string[] args) ... 代码 ...
这是一张图片:
在 web 项目中,您可以右键单击 ASPX 文件并将其设置为启动页面,非常相似。为什么 Visual Studio 隐藏此设置没有意义,但您就是这样做的。
【讨论】:
【参考方案3】:如果您使用 Visual Studio 编译/调试您的应用程序,您应该在项目的属性中设置程序的入口点。 首页 -> 申请 启动对象 -> YourNameSpace.WindowsApplication1.Form1
无需为此重新排列代码。 但是,查看提供的代码,我看不到您启动 Form1 的任何点。 Main 方法内部缺少启动 Form1 的代码。 类似的东西
Application.Run(new Form1());
【讨论】:
【参考方案4】:编译器抱怨它找不到实现应用程序入口点的类型(即Main
方法),可能是因为您的程序集中有多个类型使用compatibleMain
方法。
解决此问题的一种方法是使用/main
选项,如/main:Form1
。当然,如果问题在于存在多个Main
方法,那么更好的解决方案是简单地删除您不打算使用的方法。
【讨论】:
如前所述。 . . “我相当确定“为什么”我会得到它。我只是不知道如何重新排列代码以移动/删除/替换导致错误的语句之一。” @Geo:第二段没有回答吗? 你能给我举个例子来说明你将如何按照你的建议去做吗?我只用 C# 自学编程了大约 2 个半星期,我可以用一个接我!我在一个网站上看到了一些关于你所建议的内容,老实说,我有点困惑。但是有了例子,我很快就学会了!关于您建议的语法的提示?也就是说,如果我不想咄咄逼人的话。 :-) 如果我知道将所有其他东西放在哪里,我会删除其中一个,所以它仍然可以完成我已经完成的工作,而不会后退一步。该程序会将组合框和文本框写入 Access 数据库。到目前为止,一切都很好。但是当我向表中添加一个自动递增字段时,它不会自行更新。这就是我添加“static void Main(string[] args)”部分的原因。但是当我从微软网站(上面提供的链接)添加建议的代码时,我不得不删除一些东西。 (重复的程序数据)。帮我欧比旺克诺比。你是我唯一的希望!哈哈以上是关于“使用 /main 编译以指定包含入口点的类型。”的主要内容,如果未能解决你的问题,请参考以下文章