Diskuze: Jak byste zkrátili tento kod? Nevím si rady
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.
Člen
Zobrazeno 17 zpráv z 17.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.
No přímo špatně na tom nic není ale ve všech těch podmínkách testuješ jestli je vybranej metr a něco. To je dost zbytečné a taky nepřehledné lepší způsob by byl použít jednu podmínku jestli je to metr nazačátku a potom pomocí switche testovat ostatní podmínky.
if (delka_comboBox1.SelectedItem.ToString() == "metr")
{
switch(delka_comboBox2.SelectedItem.ToString())
{
case "kilometr":
delka_vysledek_label.Text = Convert.ToString(delka / 1000);
break;
}
}
a tímhle stylem pro zbytek. Dálé není vhodné používat diakritiku, maximálně v komentářích.
A možná ještě drobnost která není chybou ale většinou se v C# používá pro názvy syntaxe že první písmeno je malé a každé další na začátku slova velké například pokud by si měl proměnnou ahoj jak se mas tak bys jí zapsal jako ahojJakSeMas, s tím že to neplatí pro názvy metod tam jsou všechna začáteční písmena velká. Ale jak říkám není to chyba jenom taková zvyklost.
private void delka_comboBox2_SelectedIndexChanged(object sender, EventArgs e)
{
int delka = Convert.ToInt32(delka_numericUpDown1.Value);
if (delka_comboBox1.SelectedItem.ToString() == "metr")
{
switch (delka_comboBox2.SelectedItem.ToString())
{
case "kilometr":
delka_vysledek_label.Text = Convert.ToString(delka / 1000);
break;
case "milimetr":
delka_vysledek_label.Text = Convert.ToString(delka * 1000);
break;
case "centimetr":
delka_vysledek_label.Text = Convert.ToString(delka * 100);
break;
case "decimetr":
delka_vysledek_label.Text = Convert.ToString(delka * 10);
break;
case "metr":
delka_vysledek_label.Text = Convert.ToString(delka);
break;
}
}
}
hosi hosi stydte se
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
var data = new Ratio[]
{
new Ratio("metr", 1),
new Ratio("milimetr", 0.001m),
new Ratio("kilometr", 1000),
new Ratio("centimetr", 0.01m),
new Ratio("decimetr", 0.1m)
};
delka_comboBox1.Items.AddRange(data);
delka_comboBox2.Items.AddRange(data);
}
private void delka_button_Click(object sender, EventArgs e)
{
Ratio from = delka_comboBox1.SelectedItem as Ratio;
Ratio to = delka_comboBox2.SelectedItem as Ratio;
delka_vysledek_label.Text = (delka_numericUpDown1.Value * from.Ration / to.Ration).ToString();
}
}
public class Ratio
{
public string Name { get; private set; }
public decimal Ration { get; private set; }
public Ratio(string name, decimal ratio)
{
Name = name;
Ration = ratio;
}
public override string ToString()
{
return Name;
}
}
Díky moc pjanusi, tohle mi moc pomohlo a sadlomaslox taky díky, ale tohle je na mě ještě moc složitý
Doporučil bych ti dělat to v konzoli. Nemusíš se soustředit na "hlouposti" okolo a můžeš se soustředit rovnou na logiku.
@ostrozan Díky moc za postřeh, měl jsem už vygumovanou hlavu a nevěděl, kde to přepsat, díky!
Já osobně se teda nestydím - tvoje řešení je jedno z několika které
se nabízí , ale vytasit ho na začátečníka je jako jít s kanónem na
vrabce tobě, mně a spoustě
dalších příjde jako triviální, ale věř mu, že mu z toho jde hlava kolem
a univerzálním typem var bych mu taky ještě hlavu nemotal.
Myslím, že i když by ho použil, tak ještě dlouhou dobu nebude vědět "vo
co gou".
A proto řešení Ondřeje považuju v tomto případě jako nejlepší.
Musím ale dodat, že tazatel by se samozřejmě měl časem dobrat i
takovýchto postupů a tys mu ukázal, jak že by to mnělo vypadat.
Když už jsem se do diskuse pustil, nedá mi to abyc ti (i dalším začátečníkům) nedoporučil ještě jednu věc i když je mimo téma:
Jestli se chceš tvorbou aplikací zabývat vážněji, pouštět se so složitějších projektů - co nejdřív přejdi z Windows Forms na WPF.
A proč?
Máš pravdu, ale tím by se měl zabývat do hloubky, až se bude orientovat v OOP a bude dobře ovládat základní konstrukce.
Ale to se přece nevylučuje - C# je společný pro oboje a stejně ve
zdejším tutoriálu C# jsou příklady pro konzoli - a počítám tedy, že
základy oop má už za sebou, když už se pustil do oken -já jen píšu, že
pro okenní aplkace je WPF vhodnější nástroj pro kohokoliv, tedy i pro
začátečníky.
To že je na vyšší úrovni, neznamená že je náročnější na učení než
WF.
Zobrazeno 17 zpráv z 17.