<?xml version="1.0" encoding="UTF-8"?><rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>C# User Control Nedir arşivleri - Dinamik Network</title>
	<atom:link href="https://dinamiknetwork.com/e/c-user-control-nedir/feed/" rel="self" type="application/rss+xml" />
	<link>https://dinamiknetwork.com/e/c-user-control-nedir/</link>
	<description>Bilişim Dünyasına Profesyonel Yaklaşım</description>
	<lastBuildDate>Fri, 25 Aug 2023 13:32:04 +0000</lastBuildDate>
	<language>tr</language>
	<sy:updatePeriod>
	hourly	</sy:updatePeriod>
	<sy:updateFrequency>
	1	</sy:updateFrequency>
	<generator>https://wordpress.org/?v=5.8.12</generator>

<image>
	<url>https://dinamiknetwork.com/wp-content/uploads/2020/01/cropped-ikon-1-1-32x32.png</url>
	<title>C# User Control Nedir arşivleri - Dinamik Network</title>
	<link>https://dinamiknetwork.com/e/c-user-control-nedir/</link>
	<width>32</width>
	<height>32</height>
</image> 
	<item>
		<title>Bir Yazılım Projesine Başlamak- Tavsiyeler #4</title>
		<link>https://dinamiknetwork.com/bir-yazilim-projesine-baslamak-tavsiyeler-4/</link>
					<comments>https://dinamiknetwork.com/bir-yazilim-projesine-baslamak-tavsiyeler-4/#comments</comments>
		
		<dc:creator><![CDATA[Mustafa Bükülmez]]></dc:creator>
		<pubDate>Fri, 20 Dec 2019 06:00:22 +0000</pubDate>
				<category><![CDATA[Yazılım]]></category>
		<category><![CDATA[Bir Yazılım Projesine Başlamak]]></category>
		<category><![CDATA[C# User Control Nedir]]></category>
		<category><![CDATA[Code ToolBox]]></category>
		<category><![CDATA[Hızlı Kod Yazmak]]></category>
		<category><![CDATA[intelligence]]></category>
		<category><![CDATA[User Control]]></category>
		<category><![CDATA[Visual Studio Snippet Nedir?]]></category>
		<category><![CDATA[visual studio Snippets]]></category>
		<guid isPermaLink="false">https://dinamiknetwork.com/?p=896</guid>

					<description><![CDATA[<p>Bu yazım işin bir alaylısı olarak, tecrübelerimden derlediğim bir yazılım projesine başlamak – dikkat edilmesi gerekenler  konusunun 4. yazısıdır.  Bu yazıda göreceğiniz şeylerin her hangi&#46;&#46;&#46;</p>
<p>The post <a rel="nofollow" href="https://dinamiknetwork.com/bir-yazilim-projesine-baslamak-tavsiyeler-4/">Bir Yazılım Projesine Başlamak- Tavsiyeler #4</a> appeared first on <a rel="nofollow" href="https://dinamiknetwork.com">Dinamik Network</a>.</p>
]]></description>
										<content:encoded><![CDATA[<p>Bu yazım işin bir alaylısı olarak, tecrübelerimden derlediğim <strong>bir yazılım projesine başlamak – dikkat edilmesi gerekenler </strong> konusunun 4. yazısıdır.  Bu yazıda göreceğiniz şeylerin her hangi birini bir yerde bulmanızın imkansız olduğu düşünüyorum. Sayısız araştırmalar yaparak ve sayısız proje geliştirerek geçirdiğim, 5 yıldan fazla sürede elde ettiğim tüm püf noktaları paylaşıyor olacağım.</p>
<p>Önceki yazımda<a href="https://dinamiknetwork.com/bir-yazilim-projesine-baslamak-tavsiyeler-3/" target="_blank" rel="noopener noreferrer"><strong> Bir Yazılım Projesine Başlamak</strong>&#8211; Tavsiyeler #3</a>, <strong>kod yazım şekilleri</strong> ve <strong>az koda çok iş yaptırmak</strong> hakkında da konuşmuştuk. Bu yazının sohbet konusu ise <strong>Hızlı Kod Yazmak</strong>  üzerine olacak. Bu yazım önceki yazılarım ile bağlantılı olacak ve onlardan bir çok referans içerecek. Aslında önceki 3 yazım bu yazım için hazırlanmış oluyor.</p>
<p>&nbsp;</p>
<h2><strong>Bir Yazılım Projesine Başlamak- Tavsiyeler #4</strong></h2>
<h3><strong>Hızlı Kod Yazmak</strong></h3>
<p>Geldik işin zirvesi diyebileceğimiz yere. Bu yazım önceki yazıların kapsayıcısı olacak. Yani önceki 3 yazı olmadan bu yazı olmazdı.</p>
<p>Öncelikle kodlama mantığını öğrendik. Düzenli ve doğru bir kodlama mantığı ile güzel bir çözüm ürettik. Yazılımcılar olarak tabi bu kodlama mantığının canlı ortamda yürütebilecek şekilde programlanması gerekiyor. Zaten bizim için asıl olay bu. Öyle kodlar yazmalıyız ki projeyi kullanacak şirketteki çalışanlar, şirketlerine uygun kodlama mantığını projemizde uygulayabilsinler. Tamam biz mantığı öğrendik, tavsiye ettik ve kullanıldı ama yazdığımız program bu kodlama mantığını yürütebilecek mi?</p>
<p>Buradaki önceliğimiz öğrendiğimiz bu kodlama mantığını yürütebilecek yöntemleri yazmaktır / yazabilmektir. Öğrendiğimiz kodlama mantığını, öğrenmemiş olsaydık elbette gerekli yöntemleri yazamazdık.</p>
<p>Bu kodlama mantığını kolayca yazabilmemiz için gereken ilk şartı yerine getirdik. İkinci şart ise elbette Basit Düşünmek ve Çevresel Etkenleri Belirleyebilmektir. Bir yöntem yazmak zorundayız ama bunu ne kadar kompleks hale getirirsek o kadar zorlanacağız ve o kadar sıkıntı yaşayacağız. Çevresel Etkenlerden kastımızın da müşterilerimiz olduğunu zaten ikinci yazımdan biliyorsunuz. Bir mantık her şirket için geçerli olamaz. Elbette işin içinde keyfi durumlarda var.</p>
<p>Biz gruplama ayracını sadece nokta ( . ) olacak diye düşünebiliriz ama müşteri nokta ( . ) kullanmak istemeyebilir. <strong>&#8220;Arkadaşım bırak da onu biz seçelim.&#8221;</strong> deme ihtimalleri var.  Çevresel etkenleri denkleme ekledikten sonra olabildiğince basit düşünerek sonuca ulaşabiliriz. Burada kodlamalardaki ayraçları bile belirli tercihler içinden yapabilecekleri bir şekilde programlamak gerekecek.</p>
<p>Buraya kadar geldik. Her şeyimiz hazır. İş program kodlarını yazmaya geldiğinde üçüncü yazımı hatırlayalım. Az koda çok iş yapırmak&#8230; Öyle kodlar yazmalıyız ki hem olabildiğince kısa olsun hem de her türlü kodlama mantığını destekleyebilsin. Eh işte burası da sizin hayal gücünüze kalıyor.</p>
<p>İlk yazımız kodlama mantığı üzerine olduğu için senaryomuzda kodlama mantığı üzerinden ilerledi. Kodlama mantığını zaten çözdüğümüzü düşünelim ve diğer konulara geçelim artık.</p>
<h3></h3>
<p>&nbsp;</p>
<h3><strong>Tüm İmkanları Kullan!</strong></h3>
<p>Ben Visual Studio kullandığımdan dolayı anlatımlarım da onun üzerinden olacak. Visual Studio basit bir IDE değil. Bir çok özelliği var.</p>
<p>&nbsp;</p>
<h4><strong>User Control / Kullanıcı Denetimi (Nesnesi) Kullan!</strong></h4>
<p>Mesela üçüncü yazımda bahsettiğim <strong>User Control</strong> konusu&#8230; Gerçi başka IDE&#8217;lerde böyle bir şey var mı net olarak bilmiyorum ama tahmin ediyorum ki yok.  <strong>User Control</strong> konusu <strong>Hızlı Kod Yazmak</strong> için en önemli şeylerden birisidir. <strong>User Control</strong> &#8216;ü aktif şekilde kullanıyorsunuz varsayalım ve diğer konuya geçelim.</p>
<p><strong>User Control</strong> &#8216;leri sevin. Onu kullanın. O sizin en büyük yardımcılarınızdan birisidir.</p>
<p>&nbsp;</p>
<h4><strong>Code ToolBox / Kod Araç Kutusu (Kısayolu)  Kullan!</strong></h4>
<p>Yine üçüncü yazımda bundan bahsetmiştim. Kodları seçip toolbox&#8217;a atabiliyorsunuz. Kullanmak istediğinize ise çift tıklıyorsunuz yada sürükleyip istediğiniz yere bırakıyorsunuz. Tıpkı form nesnesi ekler gibi&#8230;</p>
<p>Düşünün&#8230;. Bir GridView nesnesini doldurmak, kolonlara biçimlendirme vermek, bazı kolonları gizleyip göstermek için kodlar yazdınız. Her seferinde bu kodları <em>&#8220;Daha önce nerde kullanmıştım yaaa?&#8221;</em> şeklinde form form gezerek aramak mı kolay yoksa toolbox&#8217;tan sürükleyip bırakmak mı?</p>
<p>Direk kendimden örnek vereyimm. Benim toolbox&#8217;umda 5 tane GridView güncelleme metodu var. Ben genelde forma aldığım nesnelerin hepsini mutlaka isimlendiririm ama girdview, groupbox gibi nesneleri isimlendirmiyorum. Bu yüzden toolbox&#8217;uma aldığım GridView güncelleme metodları birebir aynı, tek fark nesne isimleri. Bunlara Toolbox&#8217;ta verdiğim isimler (rename yapabiliyorsunuz) ve metodların isimleri GridUpdate1, GridUpdate2, GridUpdate3, GridUpdate4, GridUpdate5 şeklinde. Her metod 55 satır koddan oluşuyor ve  yaklaşık 45 kere nesne adı geçiyor. Neden sadece bir metod yapıp forma eklediğim ikinci grid için, GridUpdate1 metodunaki GridView1&#8217;leri GridView2 yapmak için uğraşıp zaman kaybedeyim. CTRL+H (bul ve değiştir) yapabilirim ama yine de zaman kaybı&#8230;</p>
<p>Şimdi burada <em>&#8220;Amma da büyüttün. Ne olacak sanki?&#8221;</em> diye düşünebilirsiniz. Bu normal. Çünkü bende en başta her seferinde uğraşıyordum. Neredeyse her formumda bir grid olduğunu düşünürsek her seferinde uğraşmak çok sinir bozucu oluyor. Hatta olursa bir forma 6 tane grid eklemem gerekirse toolbox&#8217;a GridUpdate6 metodu da eklenir. 😉 😀</p>
<ul>
<li>GridUpdate1 metodunun içindeki kodlar GridView1* nesnesini doldurup biçimlendiriyor.</li>
<li>GridUpdate2 metodunun içindeki kodlar GridView2* nesnesini doldurup biçimlendiriyor.</li>
<li>GridUpdate3 metodunun içindeki kodlar GridView3* nesnesini doldurup biçimlendiriyor.</li>
<li>GridUpdate4 metodunun içindeki kodlar GridView4* nesnesini doldurup biçimlendiriyor.</li>
<li>GridUpdate5 metodunun içindeki kodlar GridView5* nesnesini doldurup biçimlendiriyor.</li>
</ul>
<blockquote><p><strong>Bilgi</strong>: Ben projelerime DevExpress kullanıyorum. GridView nesnesi de DevExpress&#8217;e ait bir nesnedir. Her yazılımcının mutlaka incelemesini öneriririm.</p></blockquote>
<p>Kodlar için ayrılan toolbox&#8217;u kullanın. Onu sevin. O sizin en büyük yardımcılarınızdan birisidir.</p>
<p>&nbsp;</p>
<h4><strong>Snippets / Kod Parçacıklarını Kullan!</strong></h4>
<p><strong>Snippets nedir</strong> önce ona bakalım.</p>
<h5><strong>Visual Studio Snippet Nedir?</strong></h5>
<p>Kısaca, kısayol tuşlarının birleşimini kullanarak bir kod dosyasına eklenebilen yeniden kullanılabilir kod blokları diyebiliriz. Yani biraz farklı bir şekilde, ToolBox&#8217;a eklediğimiz kodlar gibi&#8230; Ancak bunları bir kısayol tuşuna bağlayabiliyoruz. Varsayılan olarak bir çok <strong>Snippets</strong> var.</p>
<p>Örnek</p>
<p><strong>Visual Studio</strong> &#8216;da bir kod sayfasında <strong>for</strong> yazıp <strong>TAB+TAB</strong> yaptığınızda For döngüsünü oluşturan kodları otomatik tamamlar. Aşağıdaki gibi.</p>
<pre class="prettyprint lang-csharp" data-start-line="1" data-visibility="visible" data-highlight="" data-caption="">// for yazdınız ve TAB + TAB yaptınız....
// geri kalan kısmını otomatik oluşturdu...


for (int i = 0; i &lt; length; i++)
{

}</pre>
<p>Yada foreach yazdınız <strong>TAB+TAB </strong>yaptınız. Aşağıdaki gibi otomatik getirdi. <em>(Aslında foreach yazmamıza bile gerek yok. Aşağıdaki görsele bakın.)</em></p>
<pre class="prettyprint lang-csharp" data-start-line="1" data-visibility="visible" data-highlight="" data-caption="">    foreach (var item in collection)
            {

            }</pre>
<p>Aşağıdaki görsele dikkat edin.</p>
<p><img wpfc-lazyload-disable="true" loading="lazy" class="alignnone size-full wp-image-899" src="https://dinamiknetwork.com/wp-content/uploads/2019/12/Bir-Yazılım-Projesine-Başlamak-.png" alt="Bir Yazılım Projesine Başlamak" width="849" height="274" srcset="https://dinamiknetwork.com/wp-content/uploads/2019/12/Bir-Yazılım-Projesine-Başlamak-.png 849w, https://dinamiknetwork.com/wp-content/uploads/2019/12/Bir-Yazılım-Projesine-Başlamak--768x248.png 768w" sizes="(max-width: 849px) 100vw, 849px" /></p>
<p>for yazdım ve <strong>intelligence</strong> bana zaten gösteriyor.</p>
<p><em>Malesef VS güncelleme yaptıktan sonra Türkçe oldu ve yoğunluğumdan düzeltme şansım olmadı. Ama aslında net olarak anlayabilmemiz için yani sadece bu görseli Türkçe olarak alabilmiş olmam tek güzel şey oldu. 😀  (sekme dediği TAB tuşu 😀 )</em></p>
<p>Mavi olarak seçili satırın en solundaki simgeye dikkat edin. O simge bir <strong>Snippets</strong> olduğunun göstergesidir.</p>
<p>Şimdi düşünürsek neden elle bir for döngüsü kodu yazmaya çalışayım? Neden bununla vakit kaybedeyim ki? Kaldı ki <strong>Visual Studio</strong> bana, bunun gibi kendime özel <strong>snippets</strong> uygulayabilme şansı da vermişken neden kullanmayayım?</p>
<p>Visual Studio&#8217;da bir dile ait tüm <strong>Snippet</strong> &#8216;leri görüntülemek için; <strong>Tools (Araçlar) &gt; Snippet Manager (Kod Parçacıkları Yöneticisi)  yada CTRL + K +B (Önce K sonra B)</strong> yapabilirsiniz.</p>
<p><img wpfc-lazyload-disable="true" loading="lazy" class="alignnone size-full wp-image-900" src="https://dinamiknetwork.com/wp-content/uploads/2019/12/Bir-Yazılım-Projesine-Başlamak-2-1.jpg" alt="Bir Yazılım Projesine Başlamak" width="619" height="475" /></p>
<p><strong>Snippets</strong> &#8216;e (Kod Parçacıklarına) aşağıdaki yollardan erişebilirsiniz.</p>
<ul>
<li><span class="sxs-lookup"><span data-stu-id="69521-111">Menüden, <strong>Edit</strong> &gt; <strong>IntelliSense</strong> &gt; <strong>Insert Snippet</strong></span></span></li>
<li><span class="sxs-lookup"><span data-stu-id="69521-112">Kod sayfasın da sağ tık yapıp, <strong>Snippet</strong> &gt; <strong>Insert Snippet</strong></span></span></li>
<li><span class="sxs-lookup"><span data-stu-id="69521-113"><strong>Ctrl</strong>+<strong>K</strong>,<strong>Ctrl</strong>+<strong>X </strong>Kısayol tuşlarını kullanarak</span></span></li>
</ul>
<p><a href="https://docs.microsoft.com/tr-tr/visualstudio/ide/code-snippets?view=vs-2019" target="_blank" rel="noopener noreferrer">Buradan</a> daha fazla bilgi alabilirsiniz.</p>
<p>Var olanları düzenleyebilir, kendinize özel olarak ekleyebilirsiniz.</p>
<p><strong>Snippets</strong> &#8216;leri sevin. Onu kullanın. O sizin en büyük yardımcılarınızdan birisidir.</p>
<p>&nbsp;</p>
<h3><strong>Bir Yazılım Projesine Başlamak &#8211; Hızlı Kod Yazmak için Sonuç Olarak</strong></h3>
<p>Bir Yazılım Projesine Başlamak başlığı altında, çevresel etkenleri denkleme dahil ettik. Olabilecek varyasyonları ve gelecekte sorun olabilecek neredeyse her şeyi kullanıcılardan aldık. Olabildiğince basit düşünerek kağıt üzerine projenin taslağını hazırladık. Neyi nasıl yapacağımızı belirledik. Sonrasında kod yazım şekillerine değindik ve az koda nasıl çok iş hatta daha çok iş yaptırabiliriz gördük&#8230;</p>
<blockquote><p><em>Paldır küldür başladığınız bir projenizi düşünün&#8230; Bu bilgileri aldıktan sonra, o projenizi tekrar yazsaydınız tahminen ne kadar sürede yazardınız? Tahminen zamandan ne kadar kar ederdiniz? Tahminen ne kadar daha az sorun yaşardınız?&#8230; </em></p></blockquote>
<p>Bitti mi? Hayır&#8230; Daha bitmedi. Daha seriye eklenecek en az iki yazı daha var. Buraya kadar olanlar bizim için olmazsa olmaz şeylerdi. Her yazılımcının mutlaka bilmesi gerek diye düşündüğüm şeylerdi.</p>
<p>Bu yazıdan sonra proje içi kullanıcı yetkilendirme konusunda bakacağız ki bu konu her proje için geçerli olmuyor. Bazı projeler küçük çaplıdır ve basit bir mantık iş görür. Belkide yetkilendirme yapmanıza bile gerek yoktur. Daha kapsamlı projeler için de olmazsa olmazdır. Ama bu konu  önceki yazılar ile çok bağdaşık sayılmaz.</p>
<p>Son konumuz da öyle. Aslında yazı serisinden biraz bağımsız bir konu ama yine de her yazılımcının bilmesi gereken bir konu diye düşünüyorum. Sonuçta en basitinden C# bir derya deniz&#8230; Hiçbir Allah&#8217;ın kulu ben C# &#8216;ta uzmanım diyemez. Diyenlere itimat etmeyin.</p>
<blockquote><p><em>Ben C#&#8217;ta uzmanım = Ben  pasifik okyanusunun her metresinde yüzdüm, yüzebiliyorum. </em></p></blockquote>
<p>Mecazen değil. Direk olarak böyle bir şey&#8230;</p>
<p>&nbsp;</p>
<hr />
<p>Evet arkadaşlar<strong> Bir Yazılım Projesine Başlamak </strong>&#8211; Tavsiyeler #4  yazımda bu kadar olsun. Hızlı kod yazmak hakkında konuştuk.</p>
<p>Eğer ilginizi çekebildiysem o zaman takipte kalın. Yeni bir yazının ne zaman geleceği belli değil.</p>
<p>Yazılım konusunda daha fazla içerik için <a href="https://dinamiknetwork.com/k/yazilim/" target="_blank" rel="noopener noreferrer">tıklayabilirsiniz</a>.</p>
<p>&nbsp;</p>
<hr />
<p>Bana destek olmak isterseniz <strong><a href="https://www.buymeacoffee.com/mustafabukulmez" target="_blank" rel="noopener">bir kahve ısmarlayabilirsiniz</a></strong> veya <strong><a href="https://linktr.ee/mustafabukulmez" target="_blank" rel="noopener">diğer hesaplarımdan</a></strong> takip edebilirsiniz.</p>
<p>The post <a rel="nofollow" href="https://dinamiknetwork.com/bir-yazilim-projesine-baslamak-tavsiyeler-4/">Bir Yazılım Projesine Başlamak- Tavsiyeler #4</a> appeared first on <a rel="nofollow" href="https://dinamiknetwork.com">Dinamik Network</a>.</p>
]]></content:encoded>
					
					<wfw:commentRss>https://dinamiknetwork.com/bir-yazilim-projesine-baslamak-tavsiyeler-4/feed/</wfw:commentRss>
			<slash:comments>2</slash:comments>
		
		
			</item>
		<item>
		<title>Bir Yazılım Projesine Başlamak- Tavsiyeler #3</title>
		<link>https://dinamiknetwork.com/bir-yazilim-projesine-baslamak-tavsiyeler-3/</link>
					<comments>https://dinamiknetwork.com/bir-yazilim-projesine-baslamak-tavsiyeler-3/#comments</comments>
		
		<dc:creator><![CDATA[Mustafa Bükülmez]]></dc:creator>
		<pubDate>Sat, 14 Dec 2019 17:00:08 +0000</pubDate>
				<category><![CDATA[Yazılım]]></category>
		<category><![CDATA[Az Koda Çok İş Yaptırmak]]></category>
		<category><![CDATA[Basit Düşünmek]]></category>
		<category><![CDATA[Bir Yazılım Projesine Başlamak]]></category>
		<category><![CDATA[C# User Control Nedir]]></category>
		<category><![CDATA[Kod Yazım Şekli]]></category>
		<category><![CDATA[proje geliştirmede çevresel etkenler]]></category>
		<category><![CDATA[User Control Kullanmak]]></category>
		<guid isPermaLink="false">https://dinamiknetwork.com/?p=850</guid>

					<description><![CDATA[<p>Bu yazım işin bir alaylısı olarak, tecrübelerimden derlediğim bir yazılım projesine başlamak – dikkat edilmesi gerekenler  konusunun 3. yazısıdır.  Bu yazıda göreceğiniz şeylerin her hangi&#46;&#46;&#46;</p>
<p>The post <a rel="nofollow" href="https://dinamiknetwork.com/bir-yazilim-projesine-baslamak-tavsiyeler-3/">Bir Yazılım Projesine Başlamak- Tavsiyeler #3</a> appeared first on <a rel="nofollow" href="https://dinamiknetwork.com">Dinamik Network</a>.</p>
]]></description>
										<content:encoded><![CDATA[<p>Bu yazım işin bir alaylısı olarak, tecrübelerimden derlediğim <strong>bir yazılım projesine başlamak – dikkat edilmesi gerekenler </strong> konusunun 3. yazısıdır.  Bu yazıda göreceğiniz şeylerin her hangi birini bir yerde bulmanızın imkansız olduğu düşünüyorum. Sayısız araştırmalar yaparak ve sayısız proje geliştirerek geçirdiğim, 5 yıldan fazla sürede elde ettiğim tüm püf noktaları paylaşıyor olacağım.</p>
<p>&nbsp;</p>
<p>Önceki yazımda<a href="https://dinamiknetwork.com/bir-yazilim-projesine-baslamak-tavsiyeler-2/" target="_blank" rel="noopener noreferrer"><strong> Bir Yazılım Projesine Başlamak</strong>&#8211; Tavsiyeler #2</a>, sadece <strong>Basit düşünmek</strong> üzerine değil<strong> proje geliştirmede çevresel etkenler </strong>hakkında da konuşmuştuk. Bu yazının sohbet konusu ise <strong>Kod Yazım Şekli ve Az Koda Çok İş Yaptırmak</strong> üzerine olacak. Elbette bu yazıda yazılım sektöründeki yazım kuralları vs hakkında olmayacak.</p>
<p>Mesela, <em>&#8220;Değişken adları her zaman küçük harf ile başlamak zorundadır!&#8221;</em> bu yazıda bu tarz şeyler yok. Hiçbir yazımda da olmayacak!</p>
<p>Peki, ben nasıl kod yazıyorum? Kod yazarken nelere dikkat ediyorum? Tüm bunları bu yazıda göreceksiniz.</p>
<p>&nbsp;</p>
<h2><strong>Bir Yazılım Projesine Başlamak- Tavsiyeler #3</strong></h2>
<p>Öncelikle şu mantığı aklınıza kazımanızı istiyorum.</p>
<blockquote><p><strong><em>&#8220;</em><em>Aynı kodları iki kere yazıyorsan bir hata var.&#8221; </em></strong></p></blockquote>
<p>Örnek vermek gerekirse, Access Veri Tabanı ile çalışan bir uygulama geliştiriyorsunuz. Access Veri Tabanına bağlantı kodlarını yazdınız. Form Load eventinde öğrenciler tablosundan verileri almak istiyor ve bir gridde göstermek istiyorsunuz.</p>
<pre class="prettyprint lang-csharp" data-start-line="1" data-visibility="visible" data-highlight="" data-caption="">OleDbConnection con = new OleDbConnection("Provider=Microsoft.ACE.Oledb.12.0;Data Source=okul.accdb");
OleDbDataAdapter da = new OleDbDataAdapter("SElect *from ogrenciler", con);
DataSet  ds = new DataSet();
con.Open();
da.Fill(ds, "ogrenci");
dataGridView1.DataSource = ds.Tables["ogrenci"];
con.Close();</pre>
<p>Amacımıza ulaşmak için bu kadar çok kod yazmalıyız. Formumuza birde liste güncelle butonu koymuş olsak ve o butonun click eventinde yine yukarıdaki kodların aynısını yazmak zorundayız.</p>
<p>Başka formlarda, başka listeleri göstermek için yine yukarıdaki kodları yazmalıyız. Yani ne zaman gridde veri göstermek istersek yukarıdaki 7 satır kodu tekrar tekrar yazmalıyız. Ayrıca verileri okuyup nesnelerde göstermek ya da kayıt güncelleme öncesi verileri, nesnelere yazmayı da hesaba katabilirsiniz. Verileri bir datatable&#8217;ye yükleyip nesnelere yazmak içinde yukarıdaki kodları kullanırsınız.</p>
<ul>
<li><em>Mantıklı mı? <strong>Cevap: Hayır</strong></em></li>
<li><em>Doğru bir yol mu? <strong>Cevap : Hayır</strong></em></li>
<li>Hızlı kod yazmanızı sağlar mı? <em><strong>Cevap : Hayır</strong></em></li>
<li>Projenizi hızlı bitirebilmenizi sağlar mı? <em><strong>Cevap : Hayır</strong></em></li>
<li>Bugları ve çıkan hataları ayıklamak kolay mı? <em><strong>Cevap : Hayır</strong></em></li>
<li>Upgrade* (Sürüm yükseltme vs.) yapmayı hızlandırır mı? <em><strong>Cevap : Hayır</strong></em></li>
<li><em>Kod yazmak böyle mi olmalı? <strong>Cevap: Hayır</strong></em></li>
<li><em>Ne kadar çok satır o kadar iyi mi?<strong> Cevap: Hayır</strong></em></li>
<li><em>Yazılımcının iyisi, kaç satır kod yazdığı ile mi belirlenir? <strong>Cevap: Hayır</strong></em></li>
</ul>
<p><em><strong><span style="color: #ff0000">Update*</span> = Güncellemek, Değiştirmek&#8230;  </strong></em><em><strong><span style="color: #ff0000">Upgrade*</span> = Sürüm Yükseltmek, Seviye Yükseltmek&#8230;</strong></em></p>
<p>Bir de Access Veri Tabanında veri işlemleri var. Ekleme, Silme, Güncelleme işlemleri için de ortalama yukarıdaki kadar kod yazacağız. Şimdi düşünün, kullandığınız veri tabanı değiştiğinde ne yapacaksınız? Ya da Connection String cümlenizi değiştirmek istediğinizde? Her nerede yukarıdaki kodları yazdıysanız tek tek oralara gidip gerekeli değişiklikleri yapacaksınız. Büyük bir proje ise ne kadar büyük bir hammalık yapacaksınız hayal edebiliyor musunuz?</p>
<p>Bu kodları yazarken kaybettiğiniz zamanda tuzu biberi&#8230; Bu yazıyı tamamen okuduktan sonra projenizi açın ve sık kullandığınız kodlarınızı class&#8217;lara çekin. Çok geç olmadan&#8230;</p>
<p>Peki böyle sıkıntılara düşmemek için ne yapacağız?. <strong>Az Koda Çok İş Yaptırmak Tabi ki!</strong></p>
<blockquote><p>Ne demiş <strong>Arşimet</strong> <em>&#8220;Bana yeterince uzun bir kaldıraç ve sağlam bir dayanak noktası verin, dünyayı yerinden oynatayım.&#8221;</em></p></blockquote>
<p>Bizde bu mantıkla  class ve user contol kullanarak dünyalar yazacağız. 😀  İşte bu yazının size katmayı hedeflediği şeyler şuanda başlıyor.</p>
<p>&nbsp;</p>
<h3><strong>Metod Kullan! Class Kullan!</strong></h3>
<p>Burada yapılması gereken şey Metod ve Class kullanmaktır. Yukarıdaki örnekte olan kodları ve diğer işlemler için gerekli kodları bir Class dosyasında toplarsınız. Yapacağımız Class&#8217;ın adı <strong>MyAccessClass</strong> olsun ve verileri listeleme için kullanacağımız metodumuzun adı da <strong>ShowTable </strong>(Gerid dönüşü DataTable dönen bir metod) olsun. Bu Class&#8217;ımızı ve Metod&#8217;umuzu hazırladıktan sonra kullanım şekli aşağıdaki gibi olacaktır.</p>
<pre class="prettyprint lang-csharp" data-start-line="1" data-visibility="visible" data-highlight="" data-caption="">dataGridView1.DataSource = MyAccessClass.ShowTable("Select * from ogrenciler);</pre>
<p>7 satırdan 1 satıra düşürdük. Yüzlerce formda listeleme yaptığımızı hayal edersek&#8230; Ne büyük bir kolaylık değil mi? Şimdi yukarıdaki sorulara tekrar dönelim ve düşünelim. Neden cevapların Hayır olduğunu daha net anladınız değil mi? Sadece verileri girdde gösterme değil, verileri ekrana doldurmak için verileri datatableye yüklerken, yada veriyi güncellemek amacı ile formdaki nesnelere yüklemek için verileri datatableye yüklerken de aşağıdaki kod satırını kullanırız.</p>
<pre class="prettyprint lang-csharp" data-start-line="1" data-visibility="visible" data-highlight="" data-caption="">DataTable dt_ogrenciler = MyAccessClass.ShowTable("Select * from ogrenciler);</pre>
<p>Aynı şekilde onlarca örnek verebilirim.</p>
<p>Mesela, Mail Gönderme işlemi&#8230; Sık sık kullanırız değil mi? 10, 15 satırlık bir kod bloğudur mail gönderme kodları. Proje de onlarca yerde kullandığımızı düşünsenize&#8230; KORKUNÇ!</p>
<p>&nbsp;</p>
<h3>Tek Nesnede Farklı İşlemler!</h3>
<p>Genellikle kayıt yaptığımız ekranlarda hem kayıt etme hemde kayıt güncelleme işlemi yaparız. Ve yine genellikle ekranda hem Kaydet hemde Güncelle butonları koyarız. Bir buton kayıt eder, diğeri ise günceller&#8230; <em>Ama bu doğru yöntem mi?<strong> Cevap: Hayır! </strong></em></p>
<p>O halde ne yapmalıyız? Nasıl bir yol izlemeliyiz ki tek buton kullanarak hem kayıt yapalım (insert) hemde güncelleme (update) yapalım.</p>
<p>Kaydı güncellemek istediğimizde, ilgili kaydın bilgilerini ekrana doldururuz. Bu doldurma esnasında bir değişken olarak yada ekrana bir nesne koyarak o nesneye, kaydın ID&#8217;sini de yazın. Form Load&#8217;da bu değişkeni 0 (sıfır) olarak ayarlayın yada nesneye 0 (sıfır) yazın. Kaydet butonunun click eventine bir IF koyarak şunu yapın.</p>
<p>Eğer bu ID verisi 0 (sıfır) değil ise güncelleme kodlarını, eğer bu ID verisi 0 (sıfır) ise kaydetme kodlarını çalıştırın. Örnek kod&#8230;</p>
<pre class="prettyprint lang-csharp" data-start-line="1" data-visibility="visible" data-highlight="" data-caption="">// değişken ise
if(ogrenci_ID == 0)
{
    // kaydetme kodları
}
else
{
    // güncelleme kodları
}

// nesne ise
if(Convert.ToInt32(txt_Ogrenci_ID.Text) == 0)
{
    // kaydetme kodları
}
else
{
    // güncelleme kodları
}
</pre>
<p>Bu basit bir örnekti. Şimdi biraz daha komplex bir örnek vereyim.</p>
<p>Diyelim ki ekranda 3 tane <em>(yada 10 tane fark etmez)</em> DataGridView var. Her birine sağ tık menüsü (Context Menü Strip) eklemek istiyorsunuz. Bu sağ tık menüsüne de &#8220;Listeyi Yenile&#8221;, &#8220;Dışarı Aktar&#8221; ve daha fazlasını eklemek istiyorsunuz. Normal şartlarda forma 3 tane Context Menü Strip nesnesi eklemeniz gerekiyor değil mi? (10 tane DataGridView varsa 10 tane eklenecek. Oww!)</p>
<ul>
<li>Üstelik her birine aynı menüleri ekleyeceksiniz.</li>
<li>Belki bir tanesine bir kaç tane daha fazla menü ekleyeceksiniz.</li>
<li>Belki 3 DataGridView içinde aynı sayıda ama farklı menüler ekleyeceksiniz.</li>
</ul>
<p>Şimdi size tek bir Context Menü Strip &#8216;i 3 DataGridView için nasıl kullanabilirsiniz onu anlatacağım.</p>
<p>Forma bir tane Context Menü Strip eklediniz ve bu nesneye istediğiniz menüleri de eklediniz. Tüm farklı menüleri, sırayla ekleyin.</p>
<p>İlk olarak DataGridView&#8217;leri doldurduğunuz kodları birer metod içinde alın ve bu metoları da Context Menu Strip &#8216;deki &#8220;Listeyi Yenile&#8221; menüsünün click eventine ekleyin. Kodlar öyle görünecek.</p>
<pre class="prettyprint lang-csharp" data-start-line="1" data-visibility="visible" data-highlight="" data-caption=""> private void listeyiYenileToolStripMenuItem_Click(object sender, EventArgs e)
        {
            grid1_Guncelle();
            grid2_Guncelle();
            grid3_Guncelle();
        }</pre>
<p>Bu en basiti idi. Şimdi gelelim &#8220;Dışarı Aktar&#8221; kodlarına. Elbette burada dışarı aktarma kodları vermeyeceğim.</p>
<p>Buradan sonra anlatacaklarım diğer konu başlığına giriyor. Bu yüzden devamını diğer başlığımızın altında vereceğim.</p>
<p>&nbsp;</p>
<h3><strong>Birçok Nesneye Tek Event!</strong></h3>
<p>Şimdi burada yapacağımız şey şu&#8230;.</p>
<p>Sağ tıkladığımız DataGridView&#8217;i elimize almamız gerekiyor. Hangi DataGridView üzerinde sağ tık yaptık bulmalıyız. Şimdi bunun için bir <strong>MouseDown</strong> eventi yazacağız ve formdaki tüm DataGridView&#8217;lere aynı eventi atayacağız.</p>
<pre class="prettyprint lang-csharp" data-start-line="1" data-visibility="visible" data-highlight="" data-caption="">        DataGridView grid; 
        private void dataGridView_MouseDown(object sender, MouseEventArgs e)
        {
            if (e.Button == MouseButtons.Right)
            {
                grid = sender as DataGridView;
            }
        }</pre>
<p>Bir DataGridView nesnesi tanımladık. Sağ tıklayacağımız tüm DataGridView&#8217;leri bu tanımladığımız yeni DataGridView&#8217;e atayacağız.  DataGridView üzerinde faremizden bir tuşa bastığımızda yukarıdaki event çalışır. Bizde, if ile eğer sağ tık yaptıysak; hangi DataGridView tıkladıysak, tanımladığımız DataGridView&#8217;e  sağ tıkladığımız DataGridView&#8217;i yüklüyoruz.</p>
<blockquote><p><strong>NOT</strong>: Burada sağ tıkladığımız DataGridView tamamen tanımladığımız gride yüklenir. Eğer içinde veri varsa, verilerde yüklenir.</p></blockquote>
<p>Sağ tıkladığımız DataGridView&#8217;i artık bildiğimize göre artık kodlarımızı yazabiliriz. Context Menu Strip&#8217;e eklediğimiz &#8220;Dışa Aktar&#8221; menüsünün click eventine geliyoruz ve kodlarımızı yazıyoruz.</p>
<pre class="prettyprint lang-csharp" data-start-line="1" data-visibility="visible" data-highlight="" data-caption="">      private void dışaAkarToolStripMenuItem_Click(object sender, EventArgs e)
        {
            Disari_Aktar(grid);
        }

        void Disari_Aktar(DataGridView grid)
        {
            // dışarı aktarma kodları
        }</pre>
<p>Burada gördüğünüz gibi her DataGridView için tek tek &#8220;Dışa Aktarma&#8221; kodları yazmadık. Sadece bir kere yazdık ve tüm DataGridView&#8217;ler için kullanacağız.</p>
<blockquote><p><strong><span style="color: #ff0000">DİKKAT: Tabi bu sadece bir senaryo ve örnektir. Gerçekten böyle bir işlemi asla formlar içinde tutmam. Bu kodların yeri direk olarak Class dosyasıdır. Konuyu açıklamak için örnek olması açısından bu şekilde anlatıyorum.</span></strong></p></blockquote>
<p><span style="color: #000000">Yukarıda DataGridView&#8217;lere özel menüler varsa demiştik. </span></p>
<p><span style="color: #000000">Örneğin, DataGridView1 için XXXX menüsü, DataGridView2 için ZZZZ menüsü, DataGridView3 içinde YYYY özel menüsü olsun. Bunların hepsini de Context Menu Strip&#8217;e ekledik. Context Menu Strip&#8217;in Opening Eventine gelelim ve menüleri, sağ tıkladığımız DataGridView&#8217;e göre gösterip gizleyelim.</span></p>
<pre class="prettyprint lang-csharp" data-start-line="1" data-visibility="visible" data-highlight="" data-caption="">        private void contextMenuStrip1_Opening(object sender, CancelEventArgs e)
        {

            switch (grid.Name)
            {
                case "dataGridView1":
                    XXXX_ToolStripMenuItem.Visible = true; // Context Menu'ye eklediğimiz XXXX menüsünün adı bu şekilde olur.
                    YYYY_ToolStripMenuItem.Visible = false; // Context Menu'ye eklediğimiz YYYY menüsünün adı bu şekilde olur.
                    ZZZZ_ToolStripMenuItem.Visible = false; // Context Menu'ye eklediğimiz ZZZZ menüsünün adı bu şekilde olur.
                    break;
                case "dataGridView2":
                    XXXX_ToolStripMenuItem.Visible = false;
                    YYYY_ToolStripMenuItem.Visible = true;
                    ZZZZ_ToolStripMenuItem.Visible = false;
                    break;
                case "dataGridView3":
                    XXXX_ToolStripMenuItem.Visible = false;
                    YYYY_ToolStripMenuItem.Visible = false;
                    ZZZZ_ToolStripMenuItem.Visible = true;
                    break;
            }
        }</pre>
<blockquote><p>İlk başlığımız nedi?<strong> Az koda çok iş yaptır</strong> idi değil mi? Mantığımız neydi? <em><strong>&#8220;Aynı kodları iki kere yazıyorsan bir hata var.&#8221; </strong> </em>Şimdi yukarıdaki kodları mantığımıza uyduralım.</p>
<pre class="prettyprint lang-csharp" data-start-line="1" data-visibility="visible" data-highlight="" data-caption="">        private void contextMenuStrip1_Opening(object sender, CancelEventArgs e)
        {
            XXXX_ToolStripMenuItem.Visible = false; // Context Menu'ye eklediğimiz XXXX menüsünün adı bu şekilde olur.
            YYYY_ToolStripMenuItem.Visible = false; // Context Menu'ye eklediğimiz YYYY menüsünün adı bu şekilde olur.
            ZZZZ_ToolStripMenuItem.Visible = false; // Context Menu'ye eklediğimiz ZZZZ menüsünün adı bu şekilde olur.

            switch (grid.Name)
            {
                case "dataGridView1":
                    XXXX_ToolStripMenuItem.Visible = true;
                    break;
                case "dataGridView2":
                    YYYY_ToolStripMenuItem.Visible = true;
                    break;
                case "dataGridView3":
                    ZZZZ_ToolStripMenuItem.Visible = true;
                    break;
            }
        }</pre>
<p>Daha kısa değil mi? Ve minimum kod tekrarı&#8230; Her menü için 3 satır yazdık. İkincisinde 2 satır yazdık. Ben burada Switch kullandım. İf kullansaydık kodları daha da kısaltabilirdik ama ben performans açısından iyi olduğu için Switch kullanmayı tercih ettim.</p></blockquote>
<p><em>&#8220;Neden önce gizledik sonra açtık?&#8221;</em> sorularınızı duyar gibiyim. Açıklayayım. Direk Context Menu Strip üzerinden visible özelliklerini false yaparsak ya da load eventinde yazarsak ve sağ tıklama ile  visible true yaparsak; DataGridView1&#8217;e sağ tıkladığımızda XXXX_ToolStripMenuItem görünür olur. DataGridView2&#8217;ye sağ tıkladığımızda hem XXXX_ToolStripMenuItem  hemde YYYY_ToolStripMenuItem görünür olur. Yani sadece DataGridView1&#8217;de görünmesini istediğimiz özellik, DataGridView2 içinde açık kalmış olur. Çünkü sadece bir kere gizledik. Ancak her seferinde tüm menüleri gizler sadece ilgili menüyü açarsak bu sorun yaşanmaz.</p>
<p>&nbsp;</p>
<h3><strong>User Control Kullan!</strong></h3>
<p><strong>User Control Nedir? </strong>Visual Studio&#8217;da User Control adında bir obje var. Bir form gibi projeye ekliyorsunuz. Bunun en büyük özelliği ise, bir bakıma kendinize özel nesneler tasarlamanızı sağlıyor.</p>
<p><img wpfc-lazyload-disable="true" loading="lazy" class="alignnone size-full wp-image-862" src="https://dinamiknetwork.com/wp-content/uploads/2019/12/C-User-Control-Kullanımı.jpg" alt="Bir Yazılım Projesine Başlamak" width="573" height="394" /></p>
<p>&nbsp;</p>
<p>Yukarıdaki görselde gördüğünüz gibi bir forma benziyor. Şimdi bir senaryoya göre inceleyelim.</p>
<p>Projemizde sürekli kullanıcı seçim, personel seçim, cari seçim, stok seçim gibi işlemler kullanıyoruz. Her seferinde forma bir label, iki textbox ve buton eklemek zorunda kalıyoruz. Butona tıkladığımızda kullanıcı, personel, cari ya da stok listesini açıyoruz. Listeden bir satıra çift tıkladığımızda satırdaki Kod ve Ad bilgisini alıp textboxlara yazıyoruz.</p>
<p>Böyle bir senaryo da (ben sürekli kullanıyorum bu senaryoyu) her seferinde aynı işlemleri yapmak zorunda kalıyoruz. Şimdi bunları bir kere yapsak ve sürekli kullansak nasıl olur? Sanki bir Class yazmışız gibi&#8230; Hatta yaptığımız bu şey ToolBox&#8217;ta dursa oradan bir textbox ekler gibi forma eklesek ve ekstra bir kod yazmak zorunda kalmasak?</p>
<p>İşte bu soruların cevabı olan şeyi anlatıyorum şu anda. <strong>User Control Kullanmak</strong>!</p>
<p>Hadi senaryomuza göre bir tasarım yapalım. Yukarıda forma eklediğimiz user control&#8217;ü düzenleyelim.</p>
<p><img wpfc-lazyload-disable="true" loading="lazy" class="alignnone size-full wp-image-863" src="https://dinamiknetwork.com/wp-content/uploads/2019/12/C-User-Control-Kullanımı-2.jpg" alt="C-User-Control-Kullanımı-2" width="569" height="89" /></p>
<p>UserControl&#8217;ü tasarladık ve kodlarımızı yazmış olalım. User Controllerin Toolbox&#8217;a gelmesi için projeyi bir kere build etmemiz gerekiyor. Sonrasında toolbox&#8217;tan çekip alabileceğiz.</p>
<p>UserControl&#8217;e eklediğimiz tüm nesnelerin Public olarak ayarlanması gerekiyor. Nesneleri seçin ve Properties kısmından Modifiers özelliklerini Public yapın.</p>
<p>Şimdi toolboxtan aldığımız user control nesnemizi forma ekleyelim.</p>
<p><img wpfc-lazyload-disable="true" loading="lazy" class="alignnone size-full wp-image-865" src="https://dinamiknetwork.com/wp-content/uploads/2019/12/C-User-Control-Kullanımı-3.jpg" alt="az koda çok iş yaptırmak" width="338" height="295" /></p>
<p><img wpfc-lazyload-disable="true" loading="lazy" class="alignnone size-full wp-image-864" src="https://dinamiknetwork.com/wp-content/uploads/2019/12/C-User-Control-Kullanımı-4.jpg" alt="C-User-Control-Kullanımı-4" width="850" height="315" srcset="https://dinamiknetwork.com/wp-content/uploads/2019/12/C-User-Control-Kullanımı-4.jpg 850w, https://dinamiknetwork.com/wp-content/uploads/2019/12/C-User-Control-Kullanımı-4-768x285.jpg 768w" sizes="(max-width: 850px) 100vw, 850px" /></p>
<p>UserControldeki nesnelere de</p>
<pre class="prettyprint lang-csharp" data-start-line="1" data-visibility="visible" data-highlight="" data-caption="">string kod = userControl11.txt_kulkod.Text;
string Ad = userControl11.txt_kul_adi.Text;</pre>
<p>Şeklinde ulaşabiliriz.</p>
<p>Görsellerde gördüğünz gibi. Kendimize özel bir nesne tasarladık ve formumuza eklemiş olduk.Ne kadar harika değil mi? Ne kadar güzel? O kadar kod yazmaktan kara geçtiğimizden geçtim. Bu kadar nesneyi forma ekle, adlarını değiştirme vs ile uğraşmak zorunda bile değiliz artık.</p>
<p>Her formda ekle sil vs. butonlar kullanırız. Bir user control yapalım ve bunda da sadece butonlar olsun. Ekle, Sil, Yazdır, Kapat butonlarını ekleyelim. Iconlarını verelim. Sonra forma sürükleyip bırakalım ve bütün butonlar proje genelinde aynı formatta olsun. Çok hoş olmaz mı?</p>
<p>&nbsp;</p>
<h3><strong>Bir Yazılım Projesine Başlamak &#8211; Tavsiyeler 3 &#8211; Az Koda Çok İş Yaptırmak</strong></h3>
<p>Bu yazımda anlattığım noktaları kullanmaya başladığınızda bir proje yazım hızınızın nasıl arttığına tanık olacaksınız. Sık kullanacağınız işlemleri bir class içerisine almak bazen, sıkıntılı bir sürçe olabiliyor. Ancak bir kere o sıkıntıyı çekip güzel bir class hazırladığınızda genel anlamda kazanacağınız hızı düşünün. O ana takılmayıp genele odaklanın. Üzerine birde sık kullandığınız işlemleri UserControl olarak hazırladığınızı düşünün. Forma sürükle bırak yaptınız ve kullanıcı seçme işlemi tamam. Başka bir user control çekip bıraktınız işlem butonları tamam&#8230;</p>
<p>Biliyorsunuzdur, Visual Studio&#8217;da kodları toolbox&#8217;ta saklayabiliyorsunuz.  Kod ekranında ToolBox&#8217;u açtığınızda orası kodlarınızı saklamanız için boştur. Bir kodu bloğunu seçip oraya atarsanız, kodlara bir kısa yol vermiş olursunuz. Oradan bir kod bloğuna çift tıkladığınızda kaydettiğiniz kodları tek seferde alabilirsiniz.  Bende o toolbox&#8217;daki neredeyse bütün kodlar bir kaç satırlık kodlardır ve sürekli kullandığım bütün kodlar oradadır.</p>
<p>Bazen bir formu toolbox&#8217;taki kodlara ve nesnelere çift tıklayarak hazırlıyorum. Çünkü lazım olan her şey zaten  toolbox&#8217;ta duruyor. 😉</p>
<p>&nbsp;</p>
<p>NOT: Projeleriniz her yerden ulaşabilmek için <a href="https://github.com/" target="_blank" rel="noopener noreferrer">Github</a> kullanmayı düşünebilirsiniz. Ücretini öderseniz sadece siz ve izin verdikleriniz, ücretsiz kullanmak isterseniz herkes projelerinizi görebilir ve  katkı sağlayabilir.</p>
<hr />
<p>Evet arkadaşlar<strong> Bir Yazılım Projesine Başlamak</strong>&#8211; Tavsiyeler #3  yazımda bu kadar olsun. Kod Yazım Şekli ve az koda çok iş yaptırmak hakkında konuştuk.</p>
<p>Eğer ilginizi çekebildiysem o zaman takipte kalın. Yeni bir yazının ne zaman geleceği belli değil.</p>
<p>Yazılım konusunda daha fazla içerik için <a href="https://dinamiknetwork.com/k/yazilim/" target="_blank" rel="noopener noreferrer">tıklayabilirsiniz</a>.</p>
<p>&nbsp;</p>
<hr />
<p>Bana destek olmak isterseniz <strong><a href="https://www.buymeacoffee.com/mustafabukulmez" target="_blank" rel="noopener">bir kahve ısmarlayabilirsiniz</a></strong> veya <strong><a href="https://linktr.ee/mustafabukulmez" target="_blank" rel="noopener">diğer hesaplarımdan</a></strong> takip edebilirsiniz.</p>
<p>The post <a rel="nofollow" href="https://dinamiknetwork.com/bir-yazilim-projesine-baslamak-tavsiyeler-3/">Bir Yazılım Projesine Başlamak- Tavsiyeler #3</a> appeared first on <a rel="nofollow" href="https://dinamiknetwork.com">Dinamik Network</a>.</p>
]]></content:encoded>
					
					<wfw:commentRss>https://dinamiknetwork.com/bir-yazilim-projesine-baslamak-tavsiyeler-3/feed/</wfw:commentRss>
			<slash:comments>2</slash:comments>
		
		
			</item>
	</channel>
</rss>
