threads C#פולמוס

מישהו יוכל להמליץ לי על מדריך או ספר טוב (עדיף אלקטרוני ובחינם ^^) שמסביר על threads ב C#?

(ואח"כ אולי גם על sockets).

חיפשתי די הרבה (על sockets בעיקר) ולא הבנתי יותר מדי...

אני יודע שיש ב Microsoft הסבר על הספריות השונות אבל עדיין, מסובך לי.

 

אם להיות יותר ברור - מישהו יוכל לעזור לי איך מתחילים לכתוב קוד שבעזרתו מתקשרים בין שני מחשבים או אפילו על אותו מחשב עם שתי תוכנות שפועלות במקביל?

לא בדקתי:LightStar

בס"ד

 

http://inforall.net/watch/65/c-sharp-threads-delegates
לתקשור בין שני מחשבים אני ממליץ על signalr.

תודה רבה!דרך אגב, עד עכשיו עבדתי רק עם console..פולמוס


לתקשר בין מחשבים זה לא WCF?לבן כהה


תשובותעוקר הרים
  1. לרוב אין סיבה לעבוד ישירות עם threads, זה מסובך ומסוכן. יש כיום tasks.
    1. בקצרה tasks הם אבסטרקציה מעל threads, אבל מנוהלים בצורה הרבה יותר יעילה ונוחה.
    2. tasks פועלים עם thread pool, שזה אובייקט, שכשמו, מחזיק "בריכה" של threads ומקצה ומנהל אותם בצורה חכמה. MSDN
  2. לרוב, לתקשורת בין שתי תוכנות/ שרתים ב-C# משתמשים ב-WCF. יש הרבה מדריכים באינטרנט. וובמאסטר, MSDN.
    1. ניתן ב-WCF לאפשר גם פניות http (מדפדפן, ולא רק). לפעמים זו הדרך הכי נוחה.
  3. תלוי מה הצורך שלך. אבל הרבה פעמים אתה לא צריך מקביליות (לדוגמה - יצירת תקשורת עם כמה שרתים במקביל באמצעות tasks), אלא א-סינכרוניות (אתה שולח בקשה לשרת והקוד לא נתקע עד שאתה מקבל תשובה).
    1. ב-WCF ניתן לבחור בכל בקשה אם לעשות אותה סינכרונית או א-סינכרונית.
    2. יש תכונה חדשה יחסית בשם async await שמאפשרת לכתוב קוד א-סינכרוני אלגנטי. חשוב להבין מה זה עושה לפני שמשתמשים בזה.

 

זה על קצה המזלג, אם תמקד יותר את הצורך שלך אשמח להרחיב.

 

אני בעד Tasks. זה יחסית פשוטמשה

אני לא ממליץ כמו @עוקר הרים על WFC ואני חושב שזה רעיון רע.

לך על TCP פשוט, ואם זה על אותו מחשב -  Named Pipes זה גם אופציה לא רעה.

 

אפשרות נוספת אם אתה מעדיף לשחק עם כלים חיצוניים כמו סמארטפונים - WCF אבל כ-HTTP WebService, לא עם Remoting המזעזע.

TCP אמנם מצריך פחות הגדרותעוקר הרים

אבל אתה צריך בעצמך לבנות שכבה שתנהל את התקשורת, כולל טיפול בשגיאות, המרות ועוד.

את כל זה WCF חוסך ממך.

 

זה נכון חלקית. WCF עצמו הוא כאב ראש גדולמשה

ואם אתה עובד בצד השני עם מוצר שהוא לא כתוב ב-NET. (למשל לקוח HTML/CSS/JS, או במקרה הבעייתי יותר לקוח  Android Java / iOS Objective C וכל אלה), אז WCF מוסיף לך הרבה הרבה שכבות.

 

מזכיר את המימוש הבעייתי של WebServices מבוססי WSDL/XML מתחילת העשור הקודם. רעיון מגניב שנועד לעבוד חלק ולחסוך צרות למתכנתים, אבל מתגלה כצרה צרורה בכ"כ הרבה הזדמנויות שאי אפשר אפילו להתחיל לדבר על זה.

כשמדובר בין שפות שונותעוקר הרים

אז Rest WCF הוא כמובן הפתרון הנכון.

יצא לי כמה פעמים לעשות שירותים שנועדו לצריכה הן על ידי שרתים והן על ידי דפדפנים.

בדפדפן זה בדיוק כמו AJAX רגיל.

עבור תכנות אחרות, אם מדובר בשליחה של אובייקטים פשוטים אז אין בעיה שהם יצרכו את זה עם web client. אבל כשמדובר באוביקטים מורכבים, WCF הוא פיתרון טוב מאוד.

 

הסיבה להשתמש ב-WSDL היא שלפעמים מדובר בשליחה של אובייקטים מאוד מורכבים, ואתה רוצה להגדיר תקן מחייב לעבודה איתם. WSDL הוא הרע במיעוטו. עדיף בהרבה על סכימות XSL וכדומה...

REST WCF זה רעיון יותר טובמשה

(אם כי לרוב אני אעדיף להשתמש בסתם MVC function שתקבל/שתחזיר JSON מסוג כלשהו, אם אין סיבות מיוחדות לדרוש סביבה יותר מסובכת).

יש פה מערכת שמטפלת בכמה עשרות אלפי בקשות בשניה, ואני העדפתי סתם פעולת MVC שמחזירה JSON, זה יותר מהיר ויותר יעיל אם אין דרישות מיוחדות (וגם יותר קל לדחוף ל-cache אם זה העניין).

 

לגבי האובייקטים המורכבים - אני מכיר את הסרט הזה ואתה צודק חלקית, אבל נראה אותך מתחבר ל-WSDL של ASP.net ב-PHP, או ל-WSDL שכתוב ב-Java מלקוח שכתוב ב-NET. (ניסיתי את שניהם, היה זוועה).

כשזה בתוך אותה סביבה זה עובד נפלא, וממש שקוף למתכנת המתחיל.

תודה לכולם על התשובות. בהמשך לשאלהפולמוס

ביקשתם לדעת פרטים נוספים:

 

אז הרעיון הוא ליצור משחק מעל האינטרנט כמו שחמט. הנושא הגרפי אצל ה-CLIENT הוא נחמד אבל לא נדרשת גרפיקה ברמה גבוהה בשלב הראשון. צריך רק לראות כלים כמו כלי שחמט בדו מימד.

יוכלו לשחק גם ממחשבים וגם מפלפונים.

 

השרת המרכזי ינהל ניקוד, ינהל את מהלך המשחק, יקצוב זמן לכל שחקן. יאתר שחקנים ברמה דומה.

 

בשלב ראשון כדי לבחון האם הרעיון יתפוס מספיק להתחיל בלי פלפונים (אבל רצוי שתהיה אפשרות בהמשך להרחבה לפלפונים). 

 

השאלה האם יש סביבה שכבר מוכנה לנושאים  האלה, עבור השרת המרכזי.

האם יש סביבה חינמית ?

למשל כמו שיש מספר סביבות חינמיות שונות להקמת אתרים.

אם ככה, חפש RESTFUL HTTP API כלשהומשהאחרונה

WCF זה אופציה, לא יחידה.

 

אפשר גם סתם MVC Controller ולקוח שידבר איתו.

קורסי אקדמיית BI חינםTzachiGolan

12 שנים בתחום ה BI בתוך 5 קורסים חינמיים של כל הכלים שעבדתי איתם -

 

במהלך הקריירה שלי עבדתי עם כל שכבות עולם ה-Business Intelligence

מפיתוח ב-SQL Server דרך תהליכי ETL ו Data Warehouse ועד ניהול והובלת פרויקטי BI בענן

 

ריכזתי את כל הידע המעשי שצברתי לקורסים חינמיים ביוטיוב בדיוק כמו שעובדים BI בעולם האמיתי

 

אם אתם Data Analyst , BI Developer או אם אתם שואפים להיות BI System Analyst זה המקום לבנות בסיס חזק לקריירת BI

 

🔁 אם אתם מכירים מישהו שרוצה להיכנס לעולם ה-BI – שתפו איתו

 

🔗 לינק לערוץ : אקדמיית BI חינם מקצה לקצה ב YouTube

 

 

 

מישהו יכול לבדוק את הקוד הזה? בפייתוןאדיר לוייי

זה צריך להיות לתוכנה שמתרגמת שמות קבצים ומסדרת אותם

נעשה עם gpt

לטענתה הכל מושלם ןיציב אבל רוצה לשמוע שזה עבד מושלם בפועל

זה הקוד:


import os

import json

import shutil

import re

from pathlib import Path

from PySide6.QtWidgets import (

   QApplication, QWidget, QVBoxLayout, QPushButton,

   QFileDialog, QTableWidget, QTableWidgetItem, QMessageBox

)

from PySide6.QtCore import Qt


BASE_DIR = Path(__file__).parent

ARTISTS_FILE = BASE_DIR / "artists.json"

UNDO_FILE = BASE_DIR / "undo_log.json"


# ---------- Utils ----------


def load_artists():

   if ARTISTS_FILE.exists():

       with open(ARTISTS_FILE, "r", encoding="utf-8") as f:

           return json.load(f)

   return {}


def save_artists(data):

   with open(ARTISTS_FILE, "w", encoding="utf-8") as f:

       json.dump(data, f, ensure_ascii=False, indent=2)


def clean_name(name):

   name = re.sub(r"[_\-\.]", " ", name)

   name = re.sub(r"[\"\'`]", "", name)

   name = re.sub(r"\s+", " ", name)

   return name.strip()


def transliterate_hebrew(text):

   table = {

       "א": "a", "ב": "b", "ג": "g", "ד": "d", "ה": "h",

       "ו": "v", "ז": "z", "ח": "ch", "ט": "t",

       "י": "i", "כ": "k", "ל": "l", "מ": "m",

       "נ": "n", "ס": "s", "ע": "a", "פ": "p",

       "צ": "tz", "ק": "k", "ר": "r", "ש": "sh",

       "ת": "t", "ך": "k", "ם": "m", "ן": "n",

       "ף": "f", "ץ": "tz"

   }

   return "".join(table.get(c, c) for c in text)


# ---------- Main App ----------


class TuneMaster(QWidget):

   def __init__(self):

       super().__init__()

       self.setWindowTitle("TuneMaster – Safe Rename")

       self.resize(800, 500)


       self.layout = QVBoxLayout(self)


       self.btn_select = QPushButton("בחר תיקייה")

       self.btn_execute = QPushButton("בצע שינויים")

       self.btn_undo = QPushButton("בטל שינויים")


       self.table = QTableWidget(0, 3)

       self.table.setHorizontalHeaderLabels(["מקור", "חדש", "נתיב מלא"])

       self.table.horizontalHeader().setStretchLastSection(True)


       self.layout.addWidget(self.btn_select)

       self.layout.addWidget(self.table)

       self.layout.addWidget(self.btn_execute)

       self.layout.addWidget(self.btn_undo)


       self.btn_select.clicked.connect(self.select_folder)

       self.btn_execute.clicked.connect(self.execute)

       self.btn_undo.clicked.connect(self.undo)


       self.preview = []

       self.artists = load_artists()


   def select_folder(self):

       folder = QFileDialog.getExistingDirectory(self, "בחר תיקייה")

       if not folder:

           return


       self.preview.clear()

       self.table.setRowCount(0)


       for root, _, files in os.walk(folder):

           for f in files:

               path = Path(root) / f

               stem = path.stem

               ext = path.suffix


               clean = clean_name(stem)


               new_name = None

               for he, en in self.artists.items():

                   if he in clean:

                       new_name = clean.replace(he, en)

                       break


               if not new_name:

                   new_name = transliterate_hebrew(clean)


               new_full = new_name + ext

               if new_full != f:

                   self.preview.append((path, path.with_name(new_full)))


       for old, new in self.preview:

           row = self.table.rowCount()

           self.table.insertRow(row)

           self.table.setItem(row, 0, QTableWidgetItem(old.name))

           self.table.setItem(row, 1, QTableWidgetItem(new.name))

           self.table.setItem(row, 2, QTableWidgetItem(str(old)))


   def execute(self):

       if not self.preview:

           return


       undo_data = []

       for old, new in self.preview:

           if new.exists():

               continue

           shutil.move(str(old), str(new))

           undo_data.append({"from": str(new), "to": str(old)})


       with open(UNDO_FILE, "w", encoding="utf-8") as f:

           json.dump(undo_data, f, indent=2, ensure_ascii=False)


       QMessageBox.information(self, "בוצע", "השינויים בוצעו בהצלחה")


   def undo(self):

       if not UNDO_FILE.exists():

           QMessageBox.warning(self, "אין", "אין מה לבטל")

           return


       with open(UNDO_FILE, "r", encoding="utf-8") as f:

           undo_data = json.load(f)


       for item in undo_data:

           if Path(item["from"]).exists():

               shutil.move(item["from"], item["to"])


       UNDO_FILE.unlink()

       QMessageBox.information(self, "בוטל", "כל השינויים בוטלו")


# ---------- Run ----------


if __name__ == "__main__":

   app = QApplication([])

   win = TuneMaster()

   win.show()

   app.exec()

מצחיקנקדימון
אתה מודע לזה שאין סיכוינפשי תערוג

שמישהו עם ראש על הכתפיים יריץ קוד שמישהו אחר כתב.

נכון?


לא הבנתי מה הבעיה שלך להריץ אותו.

תוריד vc code ותריץ

ומעבר לזהמבולבלת מאדדדד
בפייתון הרווחים קריטיים.


אני לא חושבת שלהעתיק מפה יעבוד. 

אתה לא צריך אותנוultracrepidam

תכתוב "run python online" ותראה אופציות להרצה.

 

ואם אתה רוצה ממש להשקיע תוריד את התוכנות הנדרשות ותריץ עצמאית

זה לא יעבוד עם online pythonנפשי תערוג

כי הוא צריך לעבוד עם קבצים

ואיך הוא יראה שינוי בשם הקובץ?

כן אני רק אוודא שזה לא יסדר לי את הקבציםאדם פרו+

בצורה שאני לא רוצה..

ולא איכפת לי לבדוק את הקוד אם הוא עובד

זה תוכנה לסידור קבצי מוזיקה לנגן שלא תומך בעבריתאדם פרו+אחרונה

או משהו כזה.

מתרגמת את שמות הקבצים לאנגלית.

משרה ממשלתיתאונמר

כן או לא?

יתרונות חסרונות?

אין לי מושג מה זה אומר ואשמח לכל מידע שיש לכם.

בנוסף - כמה אני אמורה להגיד ציפיות שכר, אם אני ניגשת למכרז - יש לי 3 שנים ניסיון full stack.

 

תודה לכם🙏

העסקה ישירה או דרך מיקור-חוץ? אם העסקה ישירה, האםפ.א.

בחוזה אישי או הסכם עבודה קיבוצי? יש ועד עובדים?

 

משכורת גלובלית או לפי שעון נוכחות?
 

יש מאפיינים שונים להעסקה במשרה ממשלתית.  


 

התנאים במשרד החנוך אינם התנאים במשרד הביטחון, למשל.  

הייאונמר

מיקור חוץ.

מאמינה שלפי שעון נוכחות.

דרך מיקור חוץ השכר גבוה מאשר עובדי מדינה באותו תפקפ.א.

תפקיד.  


השכר הגבוה יותר מגלם את הזכויות והתנאים העודפים שיש לעובדים בקביעות באותו מקום.  


בתפקידי תכנות, הנדסה, מערכות מידע - השכר במיקור חוץ יכול להיות מאוד טוב.  


החסרון הבסיסי והגדול - חוץ מהשכר, אין שום תנאים נלווים שווים.  


ההעסקה דרך מיקור חוץ במשרה ממשלתית - לברר בזמן הצגת הצעת השכר האם המשרה והשכר נמצאים תחת מגבלת מכסת שעות שנתיות של המעסיק.  

לדוגמה האם זה לפי ממוצע 180 שעות בחודש כפול 12 חודשים, 2160 שעות שנתיות.  


אם זה כך באותה משרה, ביצוע שעות נוספות אומנם מקפיץ מאוד את השכר מאוד באותו חודש, באלפי שקלים אפילו, אך השעות הנוספות אוכלות מהעוגה השנתית של מכסת השעות ויתכן שהמכסה של 2160 שעות, מהדוגמה, יאזלו חודש לפני סוף השנה או שבועיים לפני, ואז צריך לשבת בבית עד לתחילת שנת התקציב הבאה של אותו משרד ממשלתי.  

אוקיי. תודה רבה!!אונמראחרונה
אני לא מבין בשכר בממשלהמשה

בגדול, זה נחשב מקומות עבודה יציבים יותר שמשלמים פחות.

תודה!אונמר
קוד לcmdפצל"פ

מישהו יכול לכתוב לי פה קוד לcmd (אני הולך לשמור אותו כקובץ bat בתיקייה הרלוונטית במחשב) שיהפוך את כל הסיומות של הקבצים שנמצאים בתיקייה של הסקריפט לאותיות גדולות?


למשל יש לי בתיקיה קבצים בשם

דוגמהא.rtf

דוגמהב.zip

ודוגמהג.doc


אחרי הקוד זה צריך להיראות ככה

דוגמהא.RTF

דוגמהב.ZIP

ודוגמהג.DOC


זה ממש יעזור לי

תודה רבה!

יהיה לך לדעתי יותר קל עם powershellמשה

בכיוון הזה

How to convert the content of the file into uppercase or lowercase?

 

במקרה הזה אתה בעברית אז לא צריך לפצל את הסיומת.

תודה!פצל"פאחרונה

רק לא כ"כ הבנתי מה שכתבת אחרי הקישור

וגם הוא מדבר שם (לפחות מה שאני הבנתי) על להמיר תוכן של קובץ, איך עושים את זה לשמות הקבצים? או שזה פשוט תוכן הקובץ של התיקיה הגדולה?

מדריך React Memongfxp

היי חברים, רציתי לעדכן שהעלתי סרטון חדש לYouTube - מדריך React Memo

Memo היא פונקציה (HOC) שמאפשרת לנו לדלג על רינדורים חוזרים של קומפוננטה כאשר הProps של הקומפוננטה לא משתנים

קישור לסרטון:

 

מה דעתכם?

איזה נושא תרצו את הסרטון הבא?

יש משהו דומה גם בVUE. יצא לי להשתמש בומשה
מה שם הפיצ'ר המקביל ב Vue?zoharelias
V-memoמשהאחרונה
Apiאפרת???

היי, אני צריכה ייעוץ דחוף ממי שמבין בזה.

אשמח לדבר בפרטי

API -+ ממשק המאפשר גישה תכנותית לספריה/תוכנה11111

זה יכול להיות יותר מידי דברים,

רצוי שתשאלי פה את השאלה על מנת שאחרים יוכלו להעזר בשאלה גם אחרים,

אבל בכל מקרה צריך שתגידי על איזה API את מדברת כי זה יכול להיות דברים שונים לחלוטין.

מה בדיוק צריכה ?Adi alon

יכולה להיכנס לכאן לקרוא יש כמה הסברים בנושא :

 

שיווק דיגיטלי - בלוג מקצועי בעולמות השיווק | A-WEB

 

בטח מאוחר מדימשהאחרונה

אבל לשאול שאלות אפשר.

היי חברה לגבי בריאות העיניים למתכנתים שביננוhameiri13

יש משהו שנשקרא "אור כחול" שכל המסכים פולטי והדבר הזה יכול 

להכביד על העיניים כשאנו משתמשים במכך למשך זמן רב ללא הפסקה.

 

ממליץ לקרוא כמה מאמרים בנושא:

שמירה על העיניים כשיושבים מול המחשב

ממליץ גם על יואב טלר. יש ל מדריך חינמי על איך יושבים בתכלס מול המחשב. בחור נחמד ומומחה!

עמוד ראשי – יואב טלר

 

שיהיה רק בריאות חברים !

הוספת גרפיקה בתכנותמתלמד123

שאלת בורות, אבל אני רוצה להבין ולא מצאתי תשובה לבד: נניח אני מפתח משחק בC++, איפה בדיוק נכנסת הגרפיקה? ראיתי שיש פקודות למשתנים לולאות וכו', איך אני מכניס תמונה שתזוז על פי התוכנה? אני מצייר אותה בקובץ נפרד ומכניס? אם כן איך ואיפה?

לא קריטי לי כל כך להיכנס לפרטים עכשיו, אבל אני נכנס לנושא אז אני רוצה לפחות להבין בגדול.

למה C++?אליסף א

אם אתה רוצה, חיפוש ביוטיוב יוביל אותך בקלות לסידרה של בניית מכונות משחק 



זוהי הדרך הארוכה שהיא קצרה

בכל אופן, ישנן שפות אחרות שיותר מתאימות לזה.

אם תכתוב מה אתה מתכנן אולי אוכל לכוון אותך

רק עבור ציור על המסךאליסף א

Write directly to screen with c++ - Stack Overflow

תקרא את התשובת שם 

 

יותר לעומקאליסף א

Module 3. Windows Graphics - Win32 apps

לא קראתי, אבל נראה שיש שם הרבה חומר.

ושוב אני שואל , למה C++?


כי זו השפה שאתה מכיר? 
אולי בפייטון יהיה לך יותר קל להתחיל.?


עוד סרטונים

https://www.youtube.com/watch?v=1KD4Ae0tX0g&list=PL-K0viiuJ2RctP5nlJlqmHGeh66-GOZR_


 

לפי מה ששמעתי זאת אחת השפות הטובות למשחקיםמתלמד123

הבנתי שבגרפיקה היא לא חזקה במיוחד, אבל הגרפיקה לא כל כך חשובה לי, יותר חשוב לי כל המשתנים והמעבר למה שרואים.

זה מה שהבנתי מאנשים שמלמדים פיתוח משחקים, אבל יש סיכוי שזה לא נכון, כמה אתה בטוח שC++ לא טובה?

אני חושב על משהו של אסטרטגיה בלי המון גרפיקה, לא יודע בדיוק מה...

 

השאלה מה אתה מנסה ללמודאליסף א

באיזה שלב אתה.

אתה יודע לתכנת ? 
בכמה שפות ?

כמה נסיון יש לך?

מה המטרה שלך? לכתוב משחק? או ללמוד לתכנת?

האם שמעת על unity? 
שזו פלטפורמה לכתיבת משחקים, כוללת תלת מימד.

אם המטרה היא ללמוד לתכנת
אז C++ היא בהחלט מקום טוב ללמוד בו, רק מעט קשוח. 

אם המטרה היא לכתוב משחק. 
אז יש פלפורטמות קלות יותר. ומתאימות יותר

יתרונה של C++ היא בקרבתה לחומרה, ולכן היא מהירה יותר. ולכן מנוע שתכתוב בה, יעבוד יותר טוב.

בהצלחה. 

אני רוצה ללמוד תכנותמתלמד123

ולא מחפש עכשיו תלת ממד.

תודה על התשובות.

תתחיל עם #c יהיה לך יותר.קלמשה
C++ קשוח.
אפשרות שניה, jsמשה
יש ממש ספריות למשחקים על בסיס canvas.
נכון, #C, או JS או כמובן פייתוןzohareliasאחרונה

למי שרוצה להתחיל ללמוד תכנות, אלו השפות הכי מומלצות, באופן כללי.

 

עם שלושתן אפשר לתכנת משחקים.

אתה צריך להוסיף אפשרות ל "לייק"אליסף א

הייתי עושה לך .

 

אולי יעניין אותך