Compare commits
3 commits
26fc0263c7
...
183939309e
Author | SHA1 | Date | |
---|---|---|---|
183939309e | |||
fad3634a3d | |||
a26546e8a4 |
4 changed files with 188 additions and 8 deletions
|
@ -17,9 +17,20 @@ namespace DT1 {
|
||||||
}
|
}
|
||||||
|
|
||||||
public class StudentClass {
|
public class StudentClass {
|
||||||
public Func<Student, string, bool> studentSelector = /* TO BE DONE */
|
public Func<Student, string, bool> studentSelector = (student, surname) =>
|
||||||
public GradeCalc gradeCalculator = /* TO BE DONE */
|
{
|
||||||
public Func<Student, bool> passedSelector = /* TO BE DONE */
|
return string.Compare(student.LastName, surname, true) == 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
public GradeCalc gradeCalculator = (grades) =>
|
||||||
|
{
|
||||||
|
return Math.Round(((grades.Average() / 100 * 5) + 1) * 2, MidpointRounding.AwayFromZero) / 2;
|
||||||
|
};
|
||||||
|
|
||||||
|
public Func<Student, bool> passedSelector = (student) =>
|
||||||
|
{
|
||||||
|
return student.Year == GradeLevel.FourthYear && student.Grade >= 4;
|
||||||
|
};
|
||||||
|
|
||||||
#region data
|
#region data
|
||||||
public List<Student> students = new List<Student> {
|
public List<Student> students = new List<Student> {
|
||||||
|
@ -70,15 +81,16 @@ namespace DT1 {
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<Student> SearchStudent(Func<Student, string, bool> select, String lastName) {
|
public List<Student> SearchStudent(Func<Student, string, bool> select, String lastName) {
|
||||||
List<Student> result = new List<Student>();
|
List<Student> result = new() { };
|
||||||
foreach (Student s in students) {
|
foreach (Student s in students) {
|
||||||
if (select(s, lastName)) result.Add(s);
|
if (select(s, lastName)) result.Add(s);
|
||||||
}
|
}
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
public IEnumerable<Student> QueryPassed(Func<Student,bool> passed) {
|
public IEnumerable<Student> QueryPassed(Func<Student,bool> passed)
|
||||||
return /* TO BE DONE */
|
{
|
||||||
|
return students.Where(passed);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void show(String titel, List<Student> students) {
|
static void show(String titel, List<Student> students) {
|
||||||
|
@ -101,7 +113,10 @@ namespace DT1 {
|
||||||
|
|
||||||
}
|
}
|
||||||
public static class ListUtils {
|
public static class ListUtils {
|
||||||
public static IEnumerable<T> ... /* TO BE DONE */
|
public static IEnumerable<T> What<T>(this IList<T> list, Func<T, bool> selector)
|
||||||
|
{
|
||||||
|
return list.Where(selector);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
|
@ -4,7 +4,7 @@
|
||||||
<OutputType>Exe</OutputType>
|
<OutputType>Exe</OutputType>
|
||||||
<TargetFramework>net8.0</TargetFramework>
|
<TargetFramework>net8.0</TargetFramework>
|
||||||
<ImplicitUsings>enable</ImplicitUsings>
|
<ImplicitUsings>enable</ImplicitUsings>
|
||||||
<Nullable>enable</Nullable>
|
<Nullable>disable</Nullable>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
|
|
||||||
</Project>
|
</Project>
|
||||||
|
|
165
Tasks/DT2/DT2.cs
Normal file
165
Tasks/DT2/DT2.cs
Normal file
|
@ -0,0 +1,165 @@
|
||||||
|
/*
|
||||||
|
* Created by SharpDevelop.
|
||||||
|
* User: Karl Rege
|
||||||
|
* Date: 26.02.2021
|
||||||
|
* Time: 16:15
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using System.IO;
|
||||||
|
using System.Web;
|
||||||
|
using System.Net;
|
||||||
|
using System.Net.Security;
|
||||||
|
using System.Diagnostics;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
using System.Threading;
|
||||||
|
using System.Buffers;
|
||||||
|
|
||||||
|
namespace DT2 {
|
||||||
|
public enum CallMode { Sync, Async, AsyncTimeout };
|
||||||
|
|
||||||
|
public class UrlTester {
|
||||||
|
public event Action<string> PageStart;
|
||||||
|
public event Action<string, int> PageLoaded;
|
||||||
|
public event Action<string, int, int> LoadSummary;
|
||||||
|
public event Action<string> Timeout;
|
||||||
|
|
||||||
|
public void SetupEvents() {
|
||||||
|
IDictionary<string, Stopwatch> sw = new Dictionary<string, Stopwatch>();
|
||||||
|
PageStart = url => { Console.WriteLine(url + " ..."); sw.Add(url, Stopwatch.StartNew()); };
|
||||||
|
PageLoaded += (url, size) => {
|
||||||
|
sw[url].Stop();
|
||||||
|
Console.WriteLine(url + " " + size + " bytes " + (int)sw[url].Elapsed.TotalMilliseconds + " ms");
|
||||||
|
sw.Remove(url);
|
||||||
|
};
|
||||||
|
Timeout = (url) => {
|
||||||
|
sw[url].Stop(); Console.WriteLine(url + " Timeout"); sw.Remove(url);
|
||||||
|
};
|
||||||
|
LoadSummary += (s, size, time) => { Console.WriteLine(s + ": " + size + " bytes " + time + " ms"); };
|
||||||
|
}
|
||||||
|
|
||||||
|
public List<string> UrlList = new List<string> {
|
||||||
|
"https://www.zhaw.ch",
|
||||||
|
"https://waikiki.zhaw.ch/~rege",
|
||||||
|
"https://www.zhaw.ch/de/linguistik/",
|
||||||
|
"https://www.zhaw.ch/de/psychologie/",
|
||||||
|
"https://www.zhaw.ch/de/archbau/",
|
||||||
|
"https://www.zhaw.ch/de/gesundheit/",
|
||||||
|
"https://www.zhaw.ch/de/lsfm/",
|
||||||
|
// very slow sites
|
||||||
|
/*
|
||||||
|
"http://www.airkoryo.com.kp/",
|
||||||
|
"http://www.manmulsang.com.kp/",
|
||||||
|
"http://tourismdprk.gov.kp/",
|
||||||
|
"http://www.kut.edu.kp/"
|
||||||
|
*/
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
public void IgnoreCertificateValidation() {
|
||||||
|
System.Net.ServicePointManager.Expect100Continue = true;
|
||||||
|
System.Net.ServicePointManager.ServerCertificateValidationCallback
|
||||||
|
+= new RemoteCertificateValidationCallback((sender, certificate, chain, policyErrors) => true);
|
||||||
|
}
|
||||||
|
|
||||||
|
public virtual int GetPageSize(string url) {
|
||||||
|
// The downloaded resource ends up in the variable named content.
|
||||||
|
byte[] byteContent;
|
||||||
|
// Initialize an HttpWebRequest for the current URL.
|
||||||
|
var webReq = (HttpWebRequest)WebRequest.Create(url);
|
||||||
|
//if (PageStart != null) PageStart (url);
|
||||||
|
Stopwatch sw = Stopwatch.StartNew();
|
||||||
|
// Send the request to the Internet resource and wait for
|
||||||
|
// the response.
|
||||||
|
using (WebResponse response = webReq.GetResponse()) {
|
||||||
|
// Get the stream that is associated with the response.
|
||||||
|
using (Stream responseStream = response.GetResponseStream()) {
|
||||||
|
using (StreamReader sr = new StreamReader(responseStream)) {
|
||||||
|
String content = sr.ReadToEnd();
|
||||||
|
byteContent = Encoding.UTF8.GetBytes(content);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return byteContent.Length;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int GetUrlSync(string url) {
|
||||||
|
PageStart(url);
|
||||||
|
int size = GetPageSize(url);
|
||||||
|
PageLoaded(url, size);
|
||||||
|
return size;
|
||||||
|
}
|
||||||
|
|
||||||
|
public async Task<int> GetUrlAsync(string url) {
|
||||||
|
PageStart(url);
|
||||||
|
int size = await Task.Run(() => GetPageSize(url));
|
||||||
|
PageLoaded(url, size);
|
||||||
|
return size;
|
||||||
|
}
|
||||||
|
|
||||||
|
public async Task<int> GetUrlAsyncTimeout(string url, int millis) {
|
||||||
|
int size;
|
||||||
|
PageStart(url);
|
||||||
|
Task<int> task = Task.Run(() => GetPageSize(url));
|
||||||
|
|
||||||
|
try {
|
||||||
|
size = await task.WaitAsync(TimeSpan.FromMilliseconds(millis));
|
||||||
|
PageLoaded(url, size);
|
||||||
|
}
|
||||||
|
catch (TimeoutException)
|
||||||
|
{
|
||||||
|
Timeout(url);
|
||||||
|
size = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
return size;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public void GetAllUrls(List<string> urlList, CallMode callMode) {
|
||||||
|
// get a list of web addresses.
|
||||||
|
int totalSize = 0;
|
||||||
|
Stopwatch sw = Stopwatch.StartNew();
|
||||||
|
|
||||||
|
Action<Func<string, Task<int>>> asyncRunner = (implementation) =>
|
||||||
|
{
|
||||||
|
Task<int[]> task = Task.WhenAll(urlList.Select((url) => implementation(url)));
|
||||||
|
task.Wait();
|
||||||
|
totalSize = task.Result.Sum();
|
||||||
|
};
|
||||||
|
|
||||||
|
if (callMode == CallMode.Sync) {
|
||||||
|
Console.WriteLine("\nCalling Sync");
|
||||||
|
foreach (var url in urlList) {
|
||||||
|
totalSize += GetUrlSync(url);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (callMode == CallMode.Async) {
|
||||||
|
Console.WriteLine("\nCalling Async");
|
||||||
|
asyncRunner.Invoke(GetUrlAsync);
|
||||||
|
}
|
||||||
|
else if (callMode == CallMode.AsyncTimeout) {
|
||||||
|
Console.WriteLine("\nCalling Async Timeout");
|
||||||
|
asyncRunner.Invoke((url) => GetUrlAsyncTimeout(url, 100));
|
||||||
|
}
|
||||||
|
LoadSummary("Total", totalSize, (int)sw.Elapsed.TotalMilliseconds);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void Main(string[] args) {
|
||||||
|
Console.WriteLine("Starting ...");
|
||||||
|
UrlTester urlTester = new UrlTester();
|
||||||
|
urlTester.IgnoreCertificateValidation();
|
||||||
|
ThreadPool.SetMinThreads(urlTester.UrlList.Count * 2, urlTester.UrlList.Count * 2);
|
||||||
|
urlTester.SetupEvents();
|
||||||
|
urlTester.GetAllUrls(urlTester.UrlList, CallMode.Sync);
|
||||||
|
urlTester.GetAllUrls(urlTester.UrlList, CallMode.Async);
|
||||||
|
urlTester.GetAllUrls(urlTester.UrlList, CallMode.AsyncTimeout);
|
||||||
|
Console.Write("Press any key to continue ...\n");
|
||||||
|
Console.ReadKey(true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
BIN
Tasks/DT2/DT2.pdf
Normal file
BIN
Tasks/DT2/DT2.pdf
Normal file
Binary file not shown.
Loading…
Reference in a new issue