Улучшения кода - C#

Узнай цену своей работы

Формулировка задачи:

Здравствуйте! не могли бы что то по советовать по улучшению данного кода начал изучать не так давно,буду очень вам благодарен !
Листинг программы
  1. for (int i = 0; i < textBox; i++)
  2. {
  3. idauth = textBox1.Lines[i].Split(':');
  4. if (idauth.Count() != 2)
  5. {
  6. MessageBox.Show("Неверный Формат!", "Error", MessageBoxButtons.OK, MessageBoxIcon.Error);
  7. Invoke((Action)delegate() { button2.Enabled = true; textBox1.ReadOnly = false; });
  8. return;
  9. }
  10.  
  11. for (j = 0, http = "0"; j < 3 && (http == "0"); j++)
  12. {
  13. http = get("http://" + soc + "/prison/universal.php?key=" + idauth[1] + "&method=getInfo&user=" + idauth[0]);
  14. }
  15.  
  16. if (http == "0")
  17. {
  18. error++;
  19. BeginInvoke((Action)delegate()
  20. {label19.Text = "" +error;});
  21. Thread.Sleep(29000);
  22. continue;
  23. }
  24. if (http.IndexOf("<result>0</result>") != -1)
  25. {
  26. {
  27. MessageBox.Show("Неверный id или Auth_Key ", "Error", MessageBoxButtons.OK, MessageBoxIcon.Error);
  28. Invoke((Action)delegate()
  29. { button2.Enabled = true; textBox1.ReadOnly = false; });
  30.  
  31. return;
  32. }
  33. }
  34.  
  35. milk = testint( Regex.Match(http, "<milk>(.*?)</milk>").Groups[1].Value);
  36. milk1 += testint(Regex.Match(http, "<milk>(.*?)</milk>").Groups[1].Value);
  37. pac = testint(Regex.Match(http, "<category id=\"1\">(.*?)</category>").Groups[1].Value);
  38. pac1 += testint(Regex.Match(http, "<category id=\"1\">(.*?)</category>").Groups[1].Value);
  39. blat = testint(Regex.Match(http, "<category id=\"2\">(.*?)</category>").Groups[1].Value);
  40. blat1 += testint(Regex.Match(http, "<category id=\"2\">(.*?)</category>").Groups[1].Value);
  41. avto = testint(Regex.Match(http, "<category id=\"3\">(.*?)</category>").Groups[1].Value);
  42. avto1 += testint(Regex.Match(http, "<category id=\"3\">(.*?)</category>").Groups[1].Value);
  43. skaner1++;
  44.  
  45. Invoke((Action)delegate()
  46. {
  47. dataGridView1.Rows.Add(idauth[0]+":"+idauth[1],pac.ToString(),blat.ToString(),avto.ToString(),milk.ToString());
  48. label16.Text = "" + skaner1;
  49. label14.Text = "" +milk1;
  50. label11.Text = "" + pac1;
  51. label12.Text = "" + blat1;
  52. label13.Text = ""+avto1;
  53. });
  54.  
  55. }

Решение задачи: «Улучшения кода»

textual
Листинг программы
  1. public partial class Form1 : Form
  2.     {
  3.         public Form1()
  4.        
  5.             InitializeComponent();
  6.             radioButton10.Checked = true;
  7.             button5.Enabled = false;
  8.             button6.Enabled = false;
  9.             textBox1.Enabled = false;
  10.             button3.Enabled = false;
  11.            
  12.         }
  13.  
  14.         Thread potok;//Для Хранения Потока
  15.         string http;
  16.         string[] idauth;
  17.         int j = 0;//
  18.         private static object[] data = null;//Для комбо бокса
  19.         public string soc = "";
  20.         int error = 0;
  21.         string log = "";
  22.         string pok;//Для покупки
  23.         int ot = 0;
  24.         int skaner1 = 0;
  25.         int pac = 0;
  26.         int blat = 0;
  27.         int avto = 0;
  28.        
  29.         int milk = 0;
  30.  
  31.         int milk1 = 0;
  32.         int pac1 = 0;
  33.         int blat1 = 0;
  34.         int avto1 = 0;
  35.  
  36.         int kupleno = 0;
  37.        
  38.         private void button2_Click(object sender, EventArgs e)
  39.         {
  40.             textBox1.Text = textBox1.Text.Trim();
  41.             button2.Enabled = false;
  42.             if (textBox1.Text == "") { MessageBox.Show("Введите id:Auth_Key", "Error", MessageBoxButtons.OK, MessageBoxIcon.Error); button2.Enabled = true; return; }
  43.             textBox1.ReadOnly = true;
  44.             button5.Enabled = true;
  45.             obnulit();
  46.             dataGridView1.Rows.Clear();
  47.             potok = new Thread(skaner); potok.Start();
  48.         }
  49.  
  50.         void skaner()
  51.         {
  52.             int textBox = textBox1.Lines.Count();
  53.                                
  54.             for (int i = 0; i < textBox; i++)
  55.             {
  56.                 idauth = textBox1.Lines[i].Split(':');
  57.  
  58.                 if (idauth.Count() != 2)
  59.                 {
  60.                     MessageBox.Show("Неверный Формат!!! id:Auth_Key  Пример: 248307947:dd267e861d17a3ad339191faf9ba8f79", "Error", MessageBoxButtons.OK, MessageBoxIcon.Error);
  61.                     Invoke((Action)delegate() { button2.Enabled = true; textBox1.ReadOnly = false; });
  62.                     return;
  63.                 }
  64.  
  65.                 for (j = 0, http = "0"; j < 3 && (http == "0"); j++)
  66.                 {
  67.  
  68.                     http = get("http://" + soc + "/prison/universal.php?key=" + idauth[1] + "&method=getInfo&user=" + idauth[0]);
  69.                 }
  70.  
  71.                 if (http == "0")
  72.                 {
  73.                     error++;
  74.                     BeginInvoke((Action)delegate()
  75.                     {label19.Text  = "" +error;});
  76.                     Thread.Sleep(29000);
  77.                     continue;
  78.  
  79.                 }
  80.  
  81.                 if (http.IndexOf("<result>0</result>") != -1)
  82.                 {
  83.                     {
  84.                         MessageBox.Show("Неверный id или Auth_Key ", "Error", MessageBoxButtons.OK, MessageBoxIcon.Error);
  85.                         Invoke((Action)delegate()
  86.                         { button2.Enabled = true; textBox1.ReadOnly = false; });
  87.  
  88.                         return;
  89.                     }
  90.                 }
  91.              
  92.                 milk1 += milk = testint(Regex.Match(http, "<milk>(.*?)</milk>").Groups[1].Value);                
  93.                 pac1 += pac = testint(Regex.Match(http, "<category id=\"1\">(.*?)</category>").Groups[1].Value);                
  94.                 blat1 += blat = testint(Regex.Match(http, "<category id=\"2\">(.*?)</category>").Groups[1].Value);                
  95.                 avto1 +=  avto = testint(Regex.Match(http, "<category id=\"3\">(.*?)</category>").Groups[1].Value);
  96.                 skaner1++;
  97.                      
  98.                 Invoke((Action)delegate()
  99.                 {
  100.                     dataGridView1.Rows.Add(idauth[0]+":"+idauth[1],pac.ToString(),blat.ToString(),avto.ToString(),milk.ToString());
  101.                     label16.Text = "" + skaner1;
  102.                     label14.Text = "" +milk1;
  103.                     label11.Text = "" + pac1;
  104.                     label12.Text = "" + blat1;
  105.                     label13.Text = ""+avto1;
  106.  
  107.                 });          
  108.             }
  109.  
  110.             Invoke((Action)delegate()
  111.             {
  112.                 button2.Enabled = true;
  113.                 textBox1.ReadOnly = false;
  114.                 button5.Enabled = false;
  115.             });
  116.         }
  117.  
  118.         /// <Обнуляем переменные и лейбалы>
  119.         ///
  120.         /// </summary>
  121.         void obnulit()
  122.         {
  123.             Invoke((Action)delegate()
  124.             {
  125.                 label16.Text = "0";
  126.                 label11.Text = "0";
  127.                 label12.Text = "0";
  128.                 label13.Text = "0";
  129.                 label14.Text = "0";
  130.                 label19.Text = "0";
  131.                 label24.Text = "0";
  132.                 label28.Text = "0";
  133.            
  134.             });
  135.             skaner1 = 0;            
  136.             pac = 0;            
  137.             blat = 0;            
  138.             avto = 0;                        
  139.             error = 0;
  140.             pac1 = 0;
  141.             blat1 = 0;
  142.             avto1 = 0;
  143.             milk = 0;
  144.             milk1 = 0;
  145.             ot = 0;
  146.             kupleno = 0;
  147.         }
  148.       /// <Тест инт>
  149.         ///
  150.         /// </summary>
  151.         /// <param name="tom"></param>
  152.         /// <returns></returns>
  153.         private static int testint(string tom)
  154.         {
  155.             try      
  156.             {        
  157.             return Convert.ToInt32(tom);
  158.             }        
  159.             catch { return 0; }
  160.         }

ИИ поможет Вам:


  • решить любую задачу по программированию
  • объяснить код
  • расставить комментарии в коде
  • и т.д
Попробуйте бесплатно

Оцени полезность:

7   голосов , оценка 4.143 из 5

Нужна аналогичная работа?

Оформи быстрый заказ и узнай стоимость

Бесплатно
Оформите заказ и авторы начнут откликаться уже через 10 минут