为什么我的c#类函数返回显示为红色曲线?

为什么我的c#类函数返回显示为红色曲线?,c#,C#,我做VB.net程序员已经有好几年了。由于软件公司将默认SDK改为C,我最近被迫学习C。我不介意挑战。我确实对我目前正在使用的这个数组函数有问题。我想我已经正确地调用了变量,并且我的If语句结构正确。我唯一的问题是在代码块末尾的返回变量下面有一条红色的曲线。红色的波形表示我有错误或返回语法不正确。我看不出我哪里做错了,所以我请求第二个意见 下面是代码类。这个类所做的是从一个表单接收一个整数,它应该返回一个带4到5位小数的双精度整数 using System; using Syst

我做VB.net程序员已经有好几年了。由于软件公司将默认SDK改为C,我最近被迫学习C。我不介意挑战。我确实对我目前正在使用的这个数组函数有问题。我想我已经正确地调用了变量,并且我的If语句结构正确。我唯一的问题是在代码块末尾的返回变量下面有一条红色的曲线。红色的波形表示我有错误或返回语法不正确。我看不出我哪里做错了,所以我请求第二个意见

下面是代码类。这个类所做的是从一个表单接收一个整数,它应该返回一个带4到5位小数的双精度整数

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Text;
    using System.Threading.Tasks;
    using static System.Math;

    namespace CarterCalculationTools
    {
        public class FcmValue
        {
            public int FcmVal(int[] NeeNum)
            {
                var arrFcmVal = new double[61];
                double fcmResult;

                arrFcmVal[6] = 6276;
                arrFcmVal[7] = 7014.48155;
                arrFcmVal[8] = 7553.5088;
                arrFcmVal[9] = 7927.82976;
                arrFcmVal[10] = 8210.66384;
                arrFcmVal[11] = 8407.07949;
                arrFcmVal[12] = 8544.72716;
                arrFcmVal[13] = 8649.93887;
                arrFcmVal[14] = 8707.52206;
                arrFcmVal[15] = 8750.81112;
                arrFcmVal[16] = 8771.81307;
                arrFcmVal[17] = 8777.41987;
                arrFcmVal[18] = 8770.4081;
                arrFcmVal[19] = 8755.49639;
                arrFcmVal[20] = 8735.9733;
                arrFcmVal[21] = 8712.949;
                arrFcmVal[22] = 8679.01338;
                arrFcmVal[23] = 8644.57568;
                arrFcmVal[24] = 8611.92784;
                arrFcmVal[25] = 8575.37948;
                arrFcmVal[26] = 8542.55544;
                arrFcmVal[27] = 8495.9123;
                arrFcmVal[28] = 8451.60508;
                arrFcmVal[29] = 8409.80863;
                arrFcmVal[30] = 8370.20725;
                arrFcmVal[31] = 8334.23982;
                arrFcmVal[32] = 8293.85668;
                arrFcmVal[33] = 8252.51027;
                arrFcmVal[34] = 8214.39145;
                arrFcmVal[35] = 8177.75277;
                arrFcmVal[36] = 8135.08678;
                arrFcmVal[37] = 8095.31568;
                arrFcmVal[38] = 8058.21202;
                arrFcmVal[39] = 8023.5711;
                arrFcmVal[40] = 7986.15127;
                arrFcmVal[41] = 7949.5622;
                arrFcmVal[42] = 7915.15875;
                arrFcmVal[43] = 7882.78926;
                arrFcmVal[44] = 7852.31547;
                arrFcmVal[45] = 7822.26029;
                arrFcmVal[46] = 7786.75829;
                arrFcmVal[47] = 7753.07449;
                arrFcmVal[48] = 7721.09674;
                arrFcmVal[49] = 7690.72174;
                arrFcmVal[50] = 7661.85424;
                arrFcmVal[51] = 7634.40623;
                arrFcmVal[52] = 7608.29631;
                arrFcmVal[53] = 7578.34532;
                arrFcmVal[54] = 7547.26788;
                arrFcmVal[55] = 7517.52062;
                arrFcmVal[56] = 7489.03351;
                arrFcmVal[57] = 7461.74129;
                arrFcmVal[58] = 7435.58307;
                arrFcmVal[59] = 7410.50192;
                arrFcmVal[60] = 7386.44464;
                arrFcmVal[64] = 7291.45697;     

                if (Enumerable.Range(6,60).Contains(FcmVal(NeeNum)))
                {   fcmResult = arrFcmVal[FcmVal(NeeNum)];

                }
                else if (FcmVal(NeeNum) == 64)
                {
                    fcmResult = arrFcmVal[FcmVal(NeeNum)];
                }

                else
                {                         
                   fcmResult = -1;
                }
                return fcmResult;
            }
        }
    }
=更新= 下面是用SQL表中的数据填充文本框的完成代码:

public void FcmValue()
    {
        string ConString = ConfigurationManager.ConnectionStrings["ConString"].ConnectionString;
        string str = "SELECT [fcmVal] FROM [CalcTools].[dbo].[FcmValue] WHERE [neeNumCount] = @neeNumCount";
        using (SqlConnection con = new SqlConnection(ConString))
        {
            //using (SqlCommand cmd = new SqlCommand("sp_frmNeedleCalc_FcmValue", con))
            using (SqlCommand cmd = new SqlCommand(str, con))
            {
                cmd.Parameters.AddWithValue("@neeNumCount", nudNeeNum.Value);

                if (con != null && con.State == ConnectionState.Closed)
                {
                    con.Open();
                }
                SqlDataReader rdr = cmd.ExecuteReader();

                while (rdr.Read())
                {
                    string fcmFactor = rdr["fcmVal"].ToString();
                    txtFcmFactor.Text = fcmFactor;
                }
                con.Close();
            }
        }
    }

方法返回一个int,fcmResult是double类型。红色扭曲出现是因为无法将double隐式转换为int。您的方法应该返回double。

错误消息是什么?检查错误列表窗格或将鼠标悬停在红色曲线上。当方法返回
int
时,您正试图返回一个
double
。检查这一行:
public int FcmVal(int[]NeeNum)
您能否正确解释需求,并尝试返回double值,并检入数组索引。此操作完全无效。请尝试生成它。读取错误。你不必猜测,它会准确地告诉你它认为什么是错的。是的,这就是为什么红色曲线出现现在我知道了!谢谢我目前正在改变我在“如果,那么其他”中的条件,以便与替身一起工作。我将发布完成的代码,以便其他人受益。请参阅原始问题中的更新以查看完成的代码。