Sometimes when my office computer is running for a few days, it could happen that the DNS resolution will not work correctly because of cached DNS entries. In my case the symptoms are:
1.) a access by name will not work (ping hostname will fail)
2.) interesting point: nslookup hostname works
3.) ping IP from nslookup works
A quickfix: ipconfig /flushdns
One thing just makes me wondering: why does nslookup return the correct ip?
2012/09/03
Linux x86_64 - execute 32 bit applications
If you get the error
no such file or directory
when trying to execute a program under linux x86_64, it could be, that you are trying to run a 32 bit application without having ia32-libs installed.
Check if you have a x86_64 bit system installed
> uname -i
x86_64
This error can be solved by installing the ia32-libs. Under ubuntu this is done by the following command:
> sudo apt-get install ia32-libs
no such file or directory
when trying to execute a program under linux x86_64, it could be, that you are trying to run a 32 bit application without having ia32-libs installed.
Check if you have a x86_64 bit system installed
> uname -i
x86_64
This error can be solved by installing the ia32-libs. Under ubuntu this is done by the following command:
> sudo apt-get install ia32-libs
TFS 2010 - The path already mapped in workspace
Today I tried to map a source control path for Microsofts Team Foundation Server 2010 on a client. Unfortunately I got the error message
The path <path> already mapped in workspace XYZ
It seemed there was already another workspaces mapped to this path. A
tf workspaces /owner:* /collection:http://XYZ:8080/tfs/COLLECTION
revealed that my suggestion was correct. I deleted the workspace by
tf workspace /delete /collection:http://XYZ:8080/tfs/COLLECTION workspacename
I thought ok, this should be it. Another try, but it failed! Some searching around in the internet showed that some people was experiencing the problem in TFS 2010 beta. It was solved by deleting the file:
C:\Users\[USER]\AppData\Local\Microsoft\Team Foundation\2.0\Cache\versioncontrol.config
or C:\Documents and Settings\[USER]\Local Settings\Application Data\Microsoft\Team Foundation\2.0\Cache on WinXP Machines
The problem occurs, because the client caches the workspace mapping and even if you delete the workspace it can occure that the mapping still remains in the Versioncontrol.config. On TFS 2010 the path is not under folder "2.0" but "3.0". You don't have to delete the whole file, you should just delete the unwanted WorkspaceInfo element:
C:\Users\USERNAME\AppData\Local\Microsoft\Team Foundation\3.0\Cache\VersionControl.config
Sources
http://koenwillemse.wordpress.com/2009/10/29/local-folder-already-mapped-in-workspace/
http://social.msdn.microsoft.com/Forums/en-US/tfsgeneral/thread/e1dbd863-a0a7-4fd1-8b5e-387467efe596
The path <path> already mapped in workspace XYZ
It seemed there was already another workspaces mapped to this path. A
tf workspaces /owner:* /collection:http://XYZ:8080/tfs/COLLECTION
revealed that my suggestion was correct. I deleted the workspace by
tf workspace /delete /collection:http://XYZ:8080/tfs/COLLECTION workspacename
I thought ok, this should be it. Another try, but it failed! Some searching around in the internet showed that some people was experiencing the problem in TFS 2010 beta. It was solved by deleting the file:
C:\Users\[USER]\AppData\Local\Microsoft\Team Foundation\2.0\Cache\versioncontrol.config
or C:\Documents and Settings\[USER]\Local Settings\Application Data\Microsoft\Team Foundation\2.0\Cache on WinXP Machines
The problem occurs, because the client caches the workspace mapping and even if you delete the workspace it can occure that the mapping still remains in the Versioncontrol.config. On TFS 2010 the path is not under folder "2.0" but "3.0". You don't have to delete the whole file, you should just delete the unwanted WorkspaceInfo element:
C:\Users\USERNAME\AppData\Local\Microsoft\Team Foundation\3.0\Cache\VersionControl.config
<versioncontrolserver> <servers> <serverinfo repositoryguid="SOME-GUID" uri="http://HOST:8080/tfs/PROJECT"> <workspaceinfo comment="" computer="COMPUTERNAME1" lastsavedcheckintimestamp="0001-01-01T00:00:00Z" name="WORKSPACE_NAME1" ownername="USERNAME1"> <mappedpaths> <mappedpath path="WORKSPACEPATH"></mappedpath> </mappedpaths> </workspaceinfo> <workspaceinfo comment="" computer="COMPUTERNAME2" lastsavedcheckintimestamp="0001-01-01T00:00:00Z" name="WORKSPACE_NAME2" ownername="USERNAME2"> <mappedpaths></mappedpaths> </workspaceinfo> </serverinfo> </servers> </versioncontrolserver>
Sources
http://koenwillemse.wordpress.com/2009/10/29/local-folder-already-mapped-in-workspace/
http://social.msdn.microsoft.com/Forums/en-US/tfsgeneral/thread/e1dbd863-a0a7-4fd1-8b5e-387467efe596
2012/08/09
Dynamic methods for accessing fields
A few weeks ago I was facing some performance issues with a DeepCopy class I wrote. The goal of this class is to provide a faster way for deep-copying an object graph rather than serializing and deserializing with BinaryFormatter. The performance analysis of my code showed that getting or setting a field via FieldInfo.GetValue and FieldInfo.SetValue was very slow. So I searched for a possibility to access fields in a faster way. I found some interesting things, but not exactly what i was looking for.
The Idea
I got the basic idea from this page:
Jachman Wordpress - 2000% faster using dynamic method calls/
It describes a way of accessing properties with dynamic methods. The difference between properties and fields is that for accessing a property you have to call it's get- or set-method, when accessing a field the C# compiler will use special IL instructions to get or set the value.
Jachman Wordpress - 2000% faster using dynamic method calls/
It describes a way of accessing properties with dynamic methods. The difference between properties and fields is that for accessing a property you have to call it's get- or set-method, when accessing a field the C# compiler will use special IL instructions to get or set the value.
Analyse the IL code (Getter)
The fastest way to access a field is to directly access it:public class FieldAccessorsExample { public string _field1; public int _field2; } // access var instance = new SomeClass(); var value = instance._someField;
To get high performance getters and setters, we should have some methods which will imitate the direct access. I thought of something like this:
public static object Getter(object source) { return ((FieldAccessorsExample)source)._field1; }
After compiling the code above, we can view the IL code with ILDisassembler from Visual Studio. To understand the IL code, I found the documentation of the OpCodes class very helpful.
.method public hidebysig static object Getter(object source) cil managed { // Code size 12 (0xc) .maxstack 8 IL_0000: ldarg.0 IL_0001: castclass FieldSetterGetter.FieldAccessorsExample IL_0006: ldfld string FieldSetterGetter.FieldAccessorsExample::_field1 IL_000b: ret } // end of method FieldAccessorsExample::Getter
For accessing value types the method looks a little bit different.
.method private hidebysig static object ValueTypeGetter(object source) cil managed { // Code size 17 (0x11) .maxstack 8 IL_0000: ldarg.0 IL_0001: castclass FieldSetterGetter.FieldAccessorsExample IL_0006: ldfld int32 FieldSetterGetter.FieldAccessorsExample::_field2 IL_000b: box [mscorlib]System.Int32 IL_0010: ret } // end of method FieldAccessorsExample::ValueTypeGetter
With this as the basic template I created the method which will generate our get-function.
public static Func<object, object> GetGetter(FieldInfo fieldInfo) { // create a method without a name, object as result type and one parameter of type object // the last parameter is very import for accessing private fields var method = new DynamicMethod(string.Empty, typeof(object), new []{ typeof(object) }, fieldInfo.Module, true); var il = method.GetILGenerator(); il.Emit(OpCodes.Ldarg_0); // load the first argument onto the stack (source of type object) il.Emit(OpCodes.Castclass, fieldInfo.DeclaringType); // cast the parameter of type object to the type containing the field il.Emit(OpCodes.Ldfld, fieldInfo); // store the value of the given field on the stack. The casted version of source is used as instance if(fieldInfo.FieldType.IsValueType) il.Emit(OpCodes.Box, fieldInfo.FieldType); // box the value type, so you will have an object on the stack il.Emit(OpCodes.Ret); // return the value on the stack return (Func<object, object>)method.CreateDelegate(typeof(Func<object, object>)); }
Analyse the IL code (Setter)
Now we will just do the same for the set-function. First a simple function which could set the value on a given instance.public void Setter(object target, object value) { ((FieldAccessorsExample)target)._field1 = (string)value; }
The IL code generated by the compiler is:
.method public hidebysig static void Setter(object target, object 'value') cil managed { // Code size 18 (0x12) .maxstack 8 IL_0000: ldarg.0 IL_0001: castclass FieldSetterGetter.FieldAccessorsExample IL_0006: ldarg.1 IL_0007: castclass [mscorlib]System.String IL_000c: stfld string FieldSetterGetter.FieldAccessorsExample::_field1 IL_0011: ret } // end of method FieldAccessorsExample::Setter
Or the following for value types:
.method public hidebysig static void ValueTypeSetter(object target, object 'value') cil managed { // Code size 18 (0x12) .maxstack 8 IL_0000: ldarg.0 IL_0001: castclass FieldSetterGetter.FieldAccessorsExample IL_0006: ldarg.1 IL_0007: unbox.any [mscorlib]System.Int32 IL_000c: stfld int32 FieldSetterGetter.FieldAccessorsExample::_field2 IL_0011: ret } // end of method FieldAccessorsExample::ValueTypeSetter
From this we can create the function, which will return our setter function:
public static Action<object, object> GetSetter(FieldInfo fieldInfo) { var method = new DynamicMethod(string.Empty, null, new[] { typeof(object), typeof(object) }, fieldInfo.Module, true); var il = method.GetILGenerator(); il.Emit(OpCodes.Ldarg_0); // load the first argument onto the stack (source of type object) il.Emit(OpCodes.Castclass, fieldInfo.DeclaringType); // cast the parameter of type object to the type containing the field il.Emit(OpCodes.Ldarg_1); // push the second argument onto the stack (this is the value) if (fieldInfo.FieldType.IsValueType) il.Emit(OpCodes.Unbox_Any, fieldInfo.FieldType); // unbox the value parameter to the value-type else il.Emit(OpCodes.Castclass, fieldInfo.FieldType); // cast the value on the stack to the field type il.Emit(OpCodes.Stfld, fieldInfo); // store the value on stack in the field il.Emit(OpCodes.Ret); // return return (Action<object, object>)method.CreateDelegate(typeof(Action<object, object>)); }
Usage
If you put the two functions above in a factory class, the usage could look like this:
var getter = FieldAccessorFactory.GetGetter(fieldInfo); var setter = FieldAccessorFactory.GetSetter(fieldInfo); var oldValue = getter(instance); setter(instance, "newvalue");
Some helpful informations can also be found by searching with google for "open delegates" in C#.
This page explains the basics.
Performance
10,000,000 Reads
With Reflection: 3.77 sec
With DynamicMethod: 0.17 sec
Factor: 21.910,000,000 Writes
With Reflection: 5,14 sec
With DynamicMethod: 0.25Factor: 20.7
If you have any suggestions or questions, comment.
2012/08/08
Setup blogger with syntax highlighting
Before I will post the first source code I was looking how to setup syntax highlighting with blogger.com. For anyone who would like to know:
http://mlawire.blogspot.de/2009/07/blogger-syntax-highlighting.html
Very simple :)
EDIT 2012/08/14:
It wasn't as simple as I thought. After digging arount a little i found how to do it properly.
This links helped me out:
http://derkan.blogspot.de/2011/11/adding-syntaxhighlighter-to-blogger.html
Basically you have to copy the content of the css files you will use under Templates->Customize->Advanced->Add Css
I used the files
https://github.com/alexgorbatchev/SyntaxHighlighter/blob/master/styles/shCore.css
https://github.com/alexgorbatchev/SyntaxHighlighter/blob/master/styles/shCoreDefault.css
After clicking Apply to Blog you can add the code from the derkan blog to your post. I modified the code for my needs like this:
The invisible div forces the load of all scripts, you wan't to use. Without this div it could happen, that you would get an error saying: brush XYZ not found.
Infos about the autoloader script you can find here.
http://mlawire.blogspot.de/2009/07/blogger-syntax-highlighting.html
Very simple :)
EDIT 2012/08/14:
It wasn't as simple as I thought. After digging arount a little i found how to do it properly.
This links helped me out:
http://derkan.blogspot.de/2011/11/adding-syntaxhighlighter-to-blogger.html
Basically you have to copy the content of the css files you will use under Templates->Customize->Advanced->Add Css
I used the files
https://github.com/alexgorbatchev/SyntaxHighlighter/blob/master/styles/shCore.css
https://github.com/alexgorbatchev/SyntaxHighlighter/blob/master/styles/shCoreDefault.css
After clicking Apply to Blog you can add the code from the derkan blog to your post. I modified the code for my needs like this:
<div style="display:none"> <pre class="brush:js"></pre> <pre class="brush:csharp"></pre> </div>
<script type="text/javascript"> function loadScript(url, callback){ var script = document.createElement("script") script.type = "text/javascript"; if (script.readyState){ //IE script.onreadystatechange = function(){ if (script.readyState == "loaded" || script.readyState == "complete"){ script.onreadystatechange = null; callback(); } }; } else { //Others script.onload = function(){ callback(); }; } script.src = url; document.getElementsByTagName("head")[0].appendChild(script); } loadScript("http://alexgorbatchev.com/pub/sh/current/scripts/shCore.js", function(){ loadScript("http://alexgorbatchev.com/pub/sh/current/scripts/shAutoloader.js", function(){ SyntaxHighlighter.config.bloggerMode = true; SyntaxHighlighter.autoloader( 'c# c-sharp csharp http://alexgorbatchev.com/pub/sh/current/scripts/shBrushCSharp.js', 'js jscript javascript http://alexgorbatchev.com/pub/sh/current/scripts/shBrushJScript.js' ); SyntaxHighlighter.all(); } ); } ); </script>
The invisible div forces the load of all scripts, you wan't to use. Without this div it could happen, that you would get an error saying: brush XYZ not found.
Infos about the autoloader script you can find here.
Starting a new blog
Today I started this new blog "Sharp Analytics". The first part was to find a name for this blog. It will be mainly about IT and programming with C# and WPF. Sharp Analytics was a name which stresses some part of working with PCs. Especially in programming I realize every day that it's better to do a smart analysis before you start working ;).
I am looking forward to write the next post. 'til then...
I am looking forward to write the next post. 'til then...
Subscribe to:
Posts (Atom)