program APICall;
{$APPTYPE CONSOLE}
uses
Windows,
SysUtils;
type
PStringInfo = ^TStringInfo;
TStringInfo = packed record
iRefCount : Integer;
iLenCount : Integer;
pStringAddr : Pointer;
end;
procedure ShowStringInfo(const s: String);
var
p: PStringInfo;
begin
p := Pointer(s);
Dec(Integer(p), 8);
WriteLN(Format(' String: %s', [s]));
WriteLn(Format(' p.RefCount: %d', [p^.iRefCount]));
WriteLn(Format(' p.LenCount: %d', [p^.iLenCount]));
end;
var
bMethod: Byte;
s, s2: String;
begin
WriteLN('Welche Methode soll für den Typecast verwendet werden (1-3)?');
ReadLN(bMethod);
if not (bMethod in [1..3]) then
begin
WriteLN('Ungültige Eingabe');
ReadLN;
Exit;
end;
WriteLN;
WriteLN('Der Variable "s" wird ein Wert zugewiesen');
WriteLN(' s := ''Das ist ein Buffer für GetWindowsDirectory''');
s := '''Das ist ein Buffer für GetWindowsDirectory''';
WriteLN;
WriteLn('Der eingegebene Text wird einer zweiten Variable zugewiesen');
WriteLN(' s2 := s;');
s2 := s;
WriteLN;
WriteLN('Inhalt von s:');
ShowStringInfo(s);
WriteLN(Format(' Pointer(s): 0x%p', [Pointer(s)]));
WriteLN(Format(' @s: 0x%p', [@s]));
WriteLN;
WriteLn('Inhalt von s2:');
ShowStringInfo(s2);
WriteLN(Format(' Pointer(s2): 0x%p', [Pointer(s2)]));
WriteLN(Format(' @s2: 0x%p', [@s2]));
WriteLN;
WriteLN('Das Windows-Verzeichnis wird nun in die Variable "s" eingelesen...');
case bMethod of
1 :
begin
WriteLN(' GetWindowsDirectory(PChar(s), Length(s));');
GetWindowsDirectory(PChar(s), Length(s));
end;
2 :
begin
WriteLN(' GetWindowsDirectory(@s[1], Length(s));');
GetWindowsDirectory(@s[1], Length(s));
end;
3 :
begin
WriteLN(' GetWindowsDirectory(Pointer(s), Length(s));');
GetWindowsDirectory(Pointer(s), Length(s));
end;
end;
WriteLN;
WriteLn('Inhalt von s:');
ShowStringInfo(s);
WriteLN(Format(' Pointer(s): 0x%p', [Pointer(s)]));
WriteLN(Format(' @s: 0x%p', [@s]));
WriteLN;
WriteLn('Inhalt von s2:');
ShowStringInfo(s2);
WriteLN(Format(' Pointer(s2): 0x%p', [Pointer(s2)]));
WriteLN(Format(' @s2: 0x%p', [@s2]));
WriteLN;
ReadLN;
end.

Variable Api Call
Abonnieren
Posts (Atom)
Beliebte Posts
-
Windows Key Sniffer 0.82 - Update 08/2024 Der Windows Key Sniffer hat mir im Laufe der Zeit viel Arbeit erspart und unterstützt, viele Wi...
-
Network Source Code Update Source Code Network Update : https://asciigen.blogspot.com/p/network.html Send Message 1.0 Source Server Client ...
-
Windows Defender Bypass Version 0.75 - Update 11/2024 Den Windows 10-eigenen Virenschutz Defender kann man auf mehreren Wegen abschalt...
-
ASCii GIF Animator Update Version 0.68 (32 bit) - 11/2024 Bei dieser überarbeiteten Version ist die Kompatibilität zu den verschiedenen...
-
MD5 Hacker v.0.26 - Update 08.2024 MD5 Hashs sollten eigentlich nicht entschlüsselt werden können. Jedoch gibt es Tools, mit welchen auch ...
-
Host Editor Version 0.65 - Update 01/2025 Hosts File Editor allows for the easy editing of host files and backup creation. Create your ...
-
Dir Sniffer Version 0.11 - Update 02/2025 Dir Sniffer ist ein kleines aber nützliches Tool um herauszufinden, was ihr Programm auf ihrem...
-
Oldskool Font Generator v.0.29 - Update 11/2023 Das Tool stell 508 Bitmap Fonts zu Verfügung. Eigene Fonts können integriert werden, sie...
-
Hard Crypter 0.19 - Update 12/2023 Mit diesem Tool können Sie jede beliebige Datei auf dem Windows-System verschlüsseln. Die Byte-Erse...
Keine Kommentare:
Kommentar veröffentlichen