Fetstil Fetstil Kursiv Understrykning linje färgläggning tabellverk Punktlista Nummerlista Vänster Centrerat högerställt Utfyllt Länk Bild htmlmode
  • Forum & Blog
    • Forum - översikt
      • .Net
        • asp.net generellt
        • c#
        • vb.net
        • f#
        • silverlight
        • microsoft surface
        • visual studio .net
      • databaser
        • sql-server
        • databaser
        • access
        • mysql
      • mjukvara klient
        • datorer och komponenter
        • nätverk, lan/wan
        • operativsystem
        • programvaror
        • säkerhet, inställningar
        • windows server
        • allmänt
        • crystal reports
        • exchange/outlook
        • microsoft office
      • mjukvara server
        • active directory
        • biztalk
        • exchange
        • linux
        • sharepoint
        • webbservers
        • sql server
      • appar (win/mobil)
      • programspråk
        • c++
        • delphi
        • java
        • quick basic
        • visual basic
      • scripting
        • asp 3.0
        • flash actionscript
        • html css
        • javascript
        • php
        • regular expresssion
        • xml
      • spel och grafik
        • DirectX
        • Spel och grafik
      • ledning
        • Arkitektur
        • Systemutveckling
        • krav och test
        • projektledning
        • ledningsfrågor
      • vb-sektioner
        • activeX
        • windows api
        • elektronik
        • internet
        • komponenter
        • nätverk
        • operativsystem
      • övriga forum
        • arbete karriär
        • erbjuda uppdrag och tjänster
        • juridiska frågor
        • köp och sälj
        • matematik och fysik
        • intern information
        • skrivklåda
        • webb-operatörer
    • Posta inlägg i forumet
    • Chatta med andra
  • Konto
    • Medlemssida
    • Byta lösenord
    • Bli bonsumedlem
    • iMail
  • Material
    • Tips & tricks
    • Artiklar
    • Programarkiv
  • JOBB
  • Student
    • Studentlicenser
  • KONTAKT
    • Om pellesoft
    • Grundare
    • Kontakta oss
    • Annonsering
    • Partners
    • Felanmälan
  • Logga in

Hem / Forum översikt / inlägg

Posta nytt inlägg


Utmaningen v22

Postades av 2007-05-30 09:33:28 - Pelle Johansson, i forum pellesoft info/nyheter, Tråden har 10 Kommentarer och lästs av 1052 personer

<info>Tillsammans med chefen så har vi bestämt att vi skall kontrollera varandras källkod mellan varven och det är toppen för då kan vi finna problem mycket snabbare. I morgon skall vi göra en ny kodgranskning enligt chefen och jag är lite fundersam på följande kod.

Vi har två checkboxar och beroende på vad vi väljer så skall olika värden skrivas till en fil. Väljs ingen är värdet 0. Väljs den första är värdet 1. Väljs den andra är värdet 2. Väljs båda är värdet 3. Jag tycker inte att det är riktigt optimalt så utmaningen är att skriva den kortaste och effektivaste motsvarigheten för samma problem.
</info>

// Kontrollera vilken av de 2 som är valda
        if (chkConsolidation1.Checked == true && chkConsolidation2.Checked == true) {
            w.IniWriteValue("Plan_LogiX", "Consolidation", "3");
        }
        else if (chkConsolidation1.Checked == true && chkConsolidation2.Checked == false) {
            w.IniWriteValue("Plan_LogiX", "Consolidation", "1");
        }
        else if (chkConsolidation1.Checked == false && chkConsolidation2.Checked == true) {
            w.IniWriteValue("Plan_LogiX", "Consolidation", "2");
        }
        else if (chkConsolidation1.Checked == false && chkConsolidation2.Checked == false) {
            w.IniWriteValue("Plan_LogiX", "Consolidation", "0");
        }


Obs! Posta era förslag i denna tråd.


Svara

Sv: Utmaningen v22

Postades av 2007-05-30 09:43:00 - Thomas Vanhaniemi

Denna är tydlig, men går att göra kortare om man vill...

int value = 0;
value += chkConsolidation1.Checked ? 1 : 0;
value += chkConsolidation2.Checked ? 2 : 0;
w.IniWriteValue("Plan_LogiX", "Consolidation", value.ToString());


Svara

Sv: Utmaningen v22

Postades av 2007-05-30 10:14:46 - Jan Eriksson

Sitter med VB.NET så därför bli min lösning.

Dim ValueInteger As Integer = 0
ValueInteger += IIf(chkConsolidation1.Checked, 1, 0)
ValueInteger += IIf(chkConsolidation2.Checked, 2, 0)
w.IniWriteValue("Plan_LogiX", "Consolidation", ValueInteger.ToString)


Svara

Sv:Utmaningen v22

Postades av 2007-05-30 10:19:58 - Jan Eriksson

        Dim ValueInteger As Integer = IIf(chkConsolidation1.Checked, 1, 0) + IIf(chkConsolidation2.Checked, 2, 0)
        w.IniWriteValue("Plan_LogiX", "Consolidation", ValueInteger.ToString)

En kortare variant...


Svara

Sv: Utmaningen v22

Postades av 2007-05-30 10:36:20 - Andreas Hillqvist

Effektivaste är väl att skriva:

if (chkConsolidation1.Checked)
{
    if (chkConsolidation2.Checked) 
        w.IniWriteValue("Plan_LogiX", "Consolidation", "3");
    }
    else 
    {
        w.IniWriteValue("Plan_LogiX", "Consolidation", "1");
    }
}
else
{
    if (chkConsolidation2.Checked) 
        w.IniWriteValue("Plan_LogiX", "Consolidation", "2");
    }
    else 
    {
        w.IniWriteValue("Plan_LogiX", "Consolidation", "0");
    }
}

Innebär bara två conditional jumps, eller nåt. ;-)
Däremot är det lätt att göra fel i koden.

Vill man skriva det kort:
string x = chkConsolidation1.Checked ? (chkConsolidation2.Checked ? "3" : "1") : 
(chkConsolidation2.Checked ? "2" : "0");
w.IniWriteValue("Plan_LogiX", "Consolidation", x);


Men man förlorar nog mycket läsbarhet.

Den lösning jag gillar bäst är nog:
int x = 0;

if (chkConsolidation1.Checked) 
    x+=1;

if (chkConsolidation2.Checked)
    x+=2;

w.IniWriteValue("Plan_LogiX", "Consolidation", x.ToString());

Vilket i bästa fall kan spara in bägge additionerna.


Jag ifrågasätter behovet av att optimera, då detta är kod som troligen bara spara av någon inställning.
Skillnaden mellan original koden och den förändrade koden kommer inte uppmärksammas av användaren på något sätt.
Då koden anropas en gång i samband med sparning och det sker antagligen ingen iteration.

Därför handlar det mer om att åstadkomma lättläst kod som är enkel att underhålla.


Svara

Sv: Utmaningen v22

Postades av 2007-05-30 12:13:01 - Martin Adrian

[Flags]
public enum FileType {
  None = 0x00,
  Consolidation1 = 0x01,
  Consolidation2 = 0x02
};

FileType filtyp = FileType.None;
if (chkConsolidation1.Checked) filtyp |= FileType.Consolidation1;
if (chkConsolidation2.Checked) filtyp |= FileType.Consolidation2;
w.IniWriteValue("Plan_LogiX", "Consolidation", ((int)filtyp).ToString());


Svara

Sv: Utmaningen v22

Postades av 2007-05-30 13:23:09 - Lars Gottfridsson

 w.IniWriteValue("Plan_LogiX", "Consolidation", (Math.Abs(chkConsolidation1.Checked + (chkConsolidation2.Checked * 2))).ToString)


Svara

Sv:Utmaningen v22

Postades av 2007-05-31 10:35:32 - Per Hultqvist

Lars, har du testat den? Trodde inte .Net tillät konvertering från boolean till int...Annars var min första tanke också något liknande:

(int)chkConsolidation1.Checked + ((int)chkConsolidation2.Checked * 2))

Men som sagt jag trodde inte den skulle fungera och orkade inte testa.


Svara

Sv: Utmaningen v22

Postades av 2007-05-31 11:24:18 - Lars Gottfridsson

Jag gör det i smyg! (ang. vad dot.net tillåter) ;-)
den är ful, men den funkar......


Svara

Nyligen

  • 14:24 CBD regelbundet?
  • 14:23 CBD regelbundet?
  • 14:22 Har du märkt några verkliga fördel
  • 09:09 Vill du köpa medicinska tester?
  • 12:47 Vem beviljar assistansen – kommune
  • 14:17 Någon med erfarenhet av hemstädnin
  • 14:14 Bör man använda sig av en båtförme
  • 14:12 Finns det någon intressant hundblo

Sidor

  • Hem
  • Bli bonusmedlem
  • Läs artiklar
  • Chatta med andra
  • Sök och erbjud jobb
  • Kontakta oss
  • Studentlicenser
  • Skriv en artikel

Statistik

Antal besökare:
Antal medlemmar:
Antal inlägg:
Online:
På chatten:
4 569 615
27 953
271 709
5 644
0

Kontakta oss

Frågor runt konsultation, rådgivning, uppdrag, rekrytering, annonsering och övriga ärenden. Ring: 0730-88 22 24 | pelle@pellesoft.se

© 1986-2013 PelleSoft AB. Last Build 4.1.7169.18070 (2019-08-18 10:02:21) 4.0.30319.42000
  • Om
  • Kontakta
  • Regler
  • Cookies