MENU
Start
Hauptseite
Angebote im Überblick
Zahlen über uns
Kernkompetenzen
Softwareentwicklung
Beratung
Firmen-Schulungen
Offene Seminare
Online-Maßnahmen
Vorträge
Coaching
Support
Fachbücher
Fachartikel
Konditionen
Themen
Kernkompetenzen
Aktuelle Themen
Web & Cloud
Apps / Mobilplattformen
Benutzeroberflächen / User Experience
.NET
JavaScript / TypeScript
Java
Programmiersprachen
Entwicklungswerkzeuge
Scripting
Softwareengineering
Datenbanken / Reporting / BI
Betriebssysteme & Virtualisierung
Microsoft Server-Produkte
Windows & Office für Anwender
Soft Skills & IT-Recht
Beratung
Beratungsthemen
Coaching
Softwareentwicklung
Technischer Support
Unsere Top-Berater
Referenzkunden
Angebotsanfrage
Individuelle Schulungen
1042 Schulungsthemen
Agendakonfigurator
Weiterbildungsphilosophie
Didaktische Konzepte
Vor Ort oder online
Unsere Top-Trainer
Referenzkunden
Teilnehmerfeedback
Angebotsanfrage
Offene Seminare
.NET-Akademie
.NET/C#-Basisseminar
WPF
WinUI
.NET MAUI
Blazor
WebAPI & gRPC
Entity Framework Core
Unit Testing / TDD
PowerShell
Infotage
Wissen
Übersicht
Fachbücher
Fachartikel
Konferenzvorträge
Konferenzen/Events
Spickzettel
Lexikon/Glossar
Programmcodebibliothek
Fallbeispiele
Versionshistorie
Weblog
Downloads
Newsletter
Community-/Leserportal
Registrierung
.NET/C#/Visual Studio
.NET 10.0
.NET 9.0
.NET 8.0
ASP.NET (Core)/Blazor
PowerShell
Über uns
Kontakt
Selbstdarstellung
Kernkompetenzen
Dr. Holger Schwichtenberg
Top-Experten
Leitung & Kundenteam
Referenzkunden
Kundenaussagen
Referenzprojekte
Partner
Konditionen
Stellenangebote
Weitere Websites
Impressum
Datenschutzerklärung, Haftung, Urheberrecht, Barrierefreiheit
Suche
Themenkatalog
Tag Cloud
Volltextsuche
Site Map
FAQs
Erklärung des Begriffs: File-based App
Zur Stichwortliste unseres Lexikons
Was ist
File-based App
?
Seit
.NET 10.0
können Entwicklerinnen und Entwickler einzelne C#-Dateien direkt übersetzen und starten – ohne dass es eine Projektdatei geben muss.
Microsoft nennt das Feature File-based Apps. Voraussetzung ist, dass das
.NET Software Development Kit
(SDK)
www.dotnet-lexikon.de/NET
Software_Development_Kit/lex/285 Version 10.0 oder höher installiert ist. Eine Installation der
.NET Runtime
www.dotnet-lexikon.de/NET
Runtime/lex/444 reicht dafür nicht!
Damit kann C# nun auch als Skriptsprache zum Einsatz kommen, z.B. für Skripte im Rahmen von Entwicklungsprojekten, wo man bisher
PowerShell
oder
bash
eingesetzt hat. Es gab dafür aber schon vorher Ansätze außerhalb von Microsoft:
CS-Script
github.com/oleg-shilo/cs-script
DOTNET-Script
github.com/dotnet-script/dotnet-script
Cake
cakebuild.net
DOTNET Scripting Host
(DSH)
www.IT-Visions.de/scripting/dotnetscripting/dsh
C#-Scripting im
.NET 10.0
SDK ist möglich mit dem
.NET SDK
CLI
-Befehl dotnet run:
dotnet run .\Dateiname.cs
Alternativ ist die direkte Ausführung einer C#-Datei auch ohne Angabe des Wortes "run" möglich:
dotnet .\Dateiname.cs
Starten einzelner C#-Dateien unter
Linux
und macOS
Auf
Linux
und macOS kann man eine einzelne C#-Datei als File-based App direkt starten, auch ohne Voranstellung von "dotnet".
Dazu verwendet man eine sogenannte
Hash-Bang
-Zeile (oder
Shebang
-Zeile) am Anfang der C#-Datei:
#!/usr/bin/env dotnet
Dann macht man diese Datei ausführbar mit diesem Kommandozeilenbefehl:
chmod +x Dateiname.cs
Ein Start ist dann ohne Erwähnung von dotnet möglich:
./Dateiname.cs
Es ist nicht einmal notwendig, dass die Datei auf .cs endet (siehe nächste Abbildung).
Ein solch direkter Start einer einzelnen C#-Datei – ohne „dotnet“ davor zu schreiben – ist unter Windows jedoch nicht möglich.
Klasse Program und Main()-
Methode
in File-based Apps
Eine File-based App kann Top-Level-Statements oder einen klassischen .NET-Einsprungpunkt besitzen.
Eine File-based App kann die in
C# 9.0
(im Rahmen von
.NET 5.0
) eingeführten Top-Level-Statements
www.dotnet-lexikon.de/lex/12051
besitzen. Das wird der Regelfall sein, d.h. die Ausführung der Datei beginnt bei der ersten Zeile.
Console.WriteLine(
System.Runtime.InteropServices
.RuntimeInformation.FrameworkDescription);
Console.WriteLine($"Kompilierungsmodus: {(
System.Runtime.CompilerServices
.RuntimeFeature.IsDynamicCodeSupported ? "JIT" : "
AOT
")}");
Neben der Verwendung von Top-Level-Statements ist auch der klassische Stil mit class Program und Main()-
Methode
in den File-based Apps möglich:
class Program
{
static void Main(string[] args)
{
Console.WriteLine(
System.Runtime.InteropServices
.RuntimeInformation.FrameworkDescription);
Console.WriteLine($"Kompilierungsmodus: {(
System.Runtime.CompilerServices
.RuntimeFeature.IsDynamicCodeSupported ? "JIT" : "
AOT
")}");
}
}
Übergabe von Parametern in File-based Apps
File-based Apps können auch Kommandozeilenparameter empfangen.
Die Verwendung von Parametern ist sowohl in Verbindung mit class Program und Main()-
Methode
möglich als auch bei der Verwendung von Top-Level-Statements, da auch dort die
Variable
args durch den Compiler zur Verfügung gestellt wird.
Listing: Erweitertes Hello-World-Beispiel mit Parametern
using System; // nicht notwendig, Standardnamensräume sind immer dabei, da <ImplicitUsings>enable</ImplicitUsings> gesetzt ist
var conf = args.FirstOrDefault() ?? "diesem Vortrag";
Console.WriteLine(
System.Runtime.InteropServices
.RuntimeInformation.FrameworkDescription);
Console.WriteLine($"Hallo liebe Teilnehmerinnen und Teilnehmer bei \e[4;33;5m{conf}\e[0m!");
Console.WriteLine($"Kompilierungsmodus: {(
System.Runtime.CompilerServices
.RuntimeFeature.IsDynamicCodeSupported ? "JIT" : "
AOT
")}");
NuGet-Pakete und Einstellungen für File-based Apps
Informationen, die bei normalen .NET-Projekten in der Projektdatei (
.csproj
) liegen, setzt man in File-based Apps mit einer Präprozessor-
Direktive
.
Für Informationen, die üblicherweise in der
.csproj
-Projektdatei liegen, hat Microsoft für File-based Apps eine eigene Syntax beginnend mit der Raute # (Präprozessor-
Direktive
n) gefolgt von einem Doppelpunkt (dies ist aus der Sicht des C#-Compilers eine zu ignorierende
Direktive
) eingeführt:
Festlegung des SDKs: #:sdk Microsoft.NET.Sdk.Web. Bei der Angabe des SDKs kann man ab Preview 6 auch die Versionsnummer nach @ angeben, z.B. #:sdk
Aspire
.AppHost.Sdk@9.3.1
Referenz auf ein NuGet-Paket: #:package Spectre.Console@0.48.*
Referenz auf Projekte: #:project ./ClassLib/ClassLib
.csproj
Build-Eigenschaften, z.B. Versionsnummer: #:property Version=1.1.2 (vor Preview 6 noch ohne Gleichheitszeichen, sondern mit Leerzeichen als Trennung)
File-based Apps verwenden im Standard den Native
AOT
-Compiler. Dies kann man mit #:property PublishAot=false ausschalten. Dann wird der
Just-in-Time-Compiler
verwendet.
Weitere Features von Files-based Apps
Man kann unter Dateiname.settings.json im gleichen Ordner eine Settings-Datei für die File-based App anlegen.
Man kann unter Dateiname.run.json im gleichen Ordner ein Launch-Profile für die File-based App anlegen.
Man kann dotnet build Dateiname.cs oder dotnet restore Dateiname.cs ausführen.
Man kann solche File-based Apps mit dotnet publish Dateiname.cs zu einer ausführbaren Datei (.
EXE
) übersetzen
Innerhalb einer File-based App können Entwicklerinnen und Entwickler seit Preview 6 den Standort der Datei mit AppContext.GetData("EntryPointFileDirectoryPath") und den ganzen Pfad zur ausgeführten C#-Datei mit AppContext.GetData("EntryPointFilePath") bestimmen. Das funktioniert allerdings nur mit File-based Apps, nicht in normalen, projektbasierten C#-Anwendungen.
Es gibt aber in
.NET 10.0
noch keine Möglichkeit, in einer File-based App eine andere .cs-Datei direkt einzubinden. Das ist geplant für
.NET 11.0
.
Beispiel einer File-based App
Das Listing zeigt ein Beispiel einer File-based App mit zwei referenzierten NuGet-Paketen.
#!/usr/bin/env dotnet
#region Einstellungen für File-based App
//
www.nuget.org/packages/humanizer/
#:package Humanizer@2.14.1
//
www.nuget.org/packages/Spectre.Console/
#:package Spectre.Console@0.*
#:property LangVersion=preview
#:property Version=1.2.0
#:project ./ClassLibrary/ClassLibrary
.csproj
#endregion
using Spectre.Console;
using Humanizer;
var title = "C# Script v" +
System.Reflection
.
Assembly
.GetExecuting
Assembly
().GetName().Version +
" mit " +
System.Runtime.InteropServices
.RuntimeInformation.FrameworkDescription + "\n" +
AppContext.GetData("EntryPointFilePath");
// Header
AnsiConsole.Write(
new
Panel
(title)
.Header("[yellow]File-based App[/]", Justify.Center)
.Border(BoxBorder.Rounded)
.BorderStyle(new Style(foreground: Color.Green))
.Padding(1, 1, 1, 1)
);
// Parameter auflisten
foreach (var arg in args)
{
Console.WriteLine($"Argument: {arg}");
}
Console.WriteLine();
// Daten
(Data net80, Data net90, Data net10) = GetData();
// Textausgabe in Wochen
var dotNet8Released = DateTimeOffset.Parse(net80.Release);
TimeSpan dotNet8Since = DateTimeOffset.Now - dotNet8Released;
Console.WriteLine($"It has been {dotNet8Since.Humanize()} since .NET {net80.Version} was released.");
var dotNet9Released = DateTimeOffset.Parse(net90.Release);
TimeSpan dotNet9Since = DateTimeOffset.Now - dotNet9Released;
Console.WriteLine($"It has been {dotNet9Since.Humanize()} since .NET {net90.Version} was released.");
var dotNet10Released = DateTimeOffset.Parse(net10.Release);
TimeSpan dotNet10Since = DateTimeOffset.Now - dotNet10Released;
Console.WriteLine($"{dotNet10Since.Humanize()} since .NET {net10.Version} release.");
Console.WriteLine();
// Zeichne Balken für die Anzahl der Tage seit der Veröffentlichung
var bar = new BarChart()
.Width(100)
.AddItem("Days since
.NET 8.0
release", dotNet8Since.TotalDays, Color.Red)
.AddItem("Days since
.NET 9.0
release", dotNet9Since.TotalDays, Color.
Blue
)
.AddItem("Days since
.NET 10.0
release", dotNet10Since.TotalDays, Color.Purple);
AnsiConsole.Write(bar);
Console.WriteLine();
// Lokale Funktion
static (Data, Data, Data) GetData()
{
var net80 = new Data
{
Version = "8.0",
Release = "2023-11-14"
};
var net90 = new Data
{
Version = "9.0",
Release = "2024-11-12"
};
var net10 = new Data
{
Version = "10.0",
Release = "2025-11-11"
};
return (net80, net90, net10);
}
// Datenklasse
class Data
{
public required string Version { get; set; }
public string Release { get; set; }
}
Querverweise zu anderen Begriffen im Lexikon
System.Runtime.CompilerServices
System.Runtime.InteropServices
.NET Software Development Kit (.NET SDK)
DOTNET Scripting Host (DSH)
Just-in-Time-Compiler
System.Reflection
.NET Runtime
PowerShell (PS)
Hash-Bang
.NET 11.0
.NET 10.0 (.NET 10)
Direktive
.NET 8.0 (.NET 8)
Variable
Assembly
.NET 5.0 (.NET 5)
.NET 9.0 (.NET 9)
Methode
Shebang
Aspire
Linux
Panel
Blue
.NET Software Development Kit (.NET SDK)
.NET-Projektdatei (.csproj)
CSharp 9.0 (C# 9.0)
Bourne-again shell (bash)
Ahead-of-Time-Compilation (AOT)
Common Language Infrastructure (CLI)
Executable (EXE)
Beratung & Support
Anfrage für Beratung/Consulting zu FILE-BASED APP
Gesamter Beratungsthemenkatalog
Technischer Support zum FILE-BASED APP
Schulungen
Anfrage für eine individuelle Schulung zum Thema FILE-BASED APP
Gesamter Schulungsthemenkatalog
Fachbücher
Der Oracle DBA – Das Handbuch für Oracle On-Prem und Oracle Cloud
.NET 11.0 Update: Die Neuerungen in .NET 11.0 gegenüber .NET 10.0
Microsoft Copilot für Entscheider: Strategie, Governance und DSGVO-Compliance für CISOs, IT-Leiter und Datenschutzbeauftragte
SQL Server Performance & Troubleshooting: Reale Probleme, echte Lösungen — vom Hardware-Fundament bis zum Ausführungsplan
Blazor 10.0: Moderne Webanwendungen und hybride Cross-Platform-Apps mit .NET 10.0, C# 14.0 und Visual Studio 2026
C# 14.0 Crashkurs
C# 14.0 Crashkurs
Endlich barrierefrei
Moderne Datenzugriffslösungen mit Entity Framework Core 10.0
42 Wege, um liebevoll in der IT zu scheitern
PHP and MySQL: The Comprehensive Guide
.NET 10.0 Update: Die Neuerungen in .NET 10.0 gegenüber .NET 9.0
.NET 10.0 Update: Die Neuerungen in .NET 10.0 gegenüber .NET 9.0
Blazor 9.0: Moderne Webanwendungen und hybride Cross-Platform-Apps mit .NET 9.0, C# 13.0 und Visual Studio 2022
C# 13.0 Crashkurs
C# 13.0 Crashkurs
Cross-Plattform-Apps mit .NET MAUI entwickeln
Moderne Datenzugriffslösungen mit Entity Framework Core 9.0
Digitale Barrierefreiheit für alle!
Gemeinsam für Inklusion: Kurzgeschichten über digitale Menschenrechtsverletzungen
Data Modeling with Microsoft Power BI
.NET 9.0 Update: Die Neuerungen in .NET 9.0 gegenüber .NET 8.0
PowerShell 7 und Windows PowerShell 5 – das Praxishandbuch
C# und .NET 8 – Grundlagen, Profiwissen und Rezepte
PHP 8 und MySQL: Das umfassende Handbuch zu PHP 8 (Neuauflage zu PHP 8.3)
.NET 8.0 Update: Die Neuerungen in .NET 8.0 gegenüber .NET 7.0
Concurrency with Modern C++: What every professional C++ programmer should know about concurrency
C++20: Get the Details
Blazor 8.0: Moderne Webanwendungen und hybride Cross-Platform-Apps mit .NET 8.0, C# 12.0 und Visual Studio 2022
Moderne Datenzugriffslösungen mit Entity Framework Core 8.0
C# 12.0 Crashkurs
C# 12.0 Crashkurs
Self-Service AI mit Power BI
App-Entwicklung für Mobile und Desktop: Software Engineering mit .NET MAUI und Comet für iOS, Android, Windows und macOS
Requirements Engineering für die agile Softwareentwicklung: Methoden, Techniken und Strategien
Cross-Plattform-Apps mit .NET MAUI entwickeln
Blazor 7.0: Blazor WebAssembly, Blazor Server und Blazor Hybrid
C# 11.0 Crashkurs
C# 11.0 Crashkurs
HTML5 und CSS3: Start ohne Vorwissen - mit umfangeichen Download Material (Sonderausgabe)
Moderne Datenzugriffslösungen mit Entity Framework Core 7.0
PowerShell 7 und Windows PowerShell 5 – das Praxishandbuch
ASP.NET Core Security
Digitale Barrierefreiheit für alle!
C# und .NET 6 – Grundlagen, Profiwissen und Rezepte
C++ Core Guidelines Explained: Best Practices for Modern C++
Vue.js 3 Crashkurs
Handbuch für Softwareentwickler: Das Standardwerk für professionelles Software Engineering
Moderne Datenzugriffslösungen mit Entity Framework Core 6.0
Blazor 6.0: Blazor WebAssembly, Blazor Server und Blazor Desktop
Alle unsere aktuellen Fachbücher
E-Book-Abo für ab 99 Euro im Jahr