|
Okay, I'm studying the suggested app from the 2nd message in this thread.
I see this magic word "SerialPortManager" in different files, and C# knows they are there.
When I try to put something in a different file, C# can't see it.
What's going on with this correct app that isn't going on with mine ?
I'll mark the SerialPortManager with bold type in these file clips.
File: SerialPortManager.cs
File: MainForm.cs
namespace SerialPortListener
{
public partial class MainForm : Form
{
SerialPortManager _spManager;
public MainForm()
{
InitializeComponent();
UserInitialization();
}
private void UserInitialization()
{
_spManager = new SerialPortManager();
(more stuff)
(more stuff)
(more stuff)
(more stuff)
(more stuff)
File: SerialPortManager.cs
namespace SerialPortListener.Serial
{
public class SerialPortManager : IDisposable
{
public SerialPortManager()
{
_currentSerialSettings.PortNameCollection = SerialPort.GetPortNames();
_currentSerialSettings.PropertyChanged += new System.ComponentModel.PropertyChangedEventHandler(_currentSerialSettings_PropertyChanged);
if (_currentSerialSettings.PortNameCollection.Length > 0)
_currentSerialSettings.PortName = _currentSerialSettings.PortNameCollection[0];
}
~SerialPortManager()
{
Dispose(false);
}
Sorry, no clue why the formatting goes into all italics in the second code snip
Anyway, which lines in his code are giving him the ability to share the names between files ? Why can't I share the name of this group of bytes between files ?
namespace SerialPortPractice_03
{
public partial class Form1 : Form
{
public byte[] This_Does_Not_Work = new byte[] { 0x01, 0x02, 0x03, 0x04 };
public byte[] A_Test_To_Experiment = new byte[] {
0xFF, 0xFE, 0xFD, 0xFC,
0x11, 0x22, 0x33, 0x44,
0x55, 0x66, 0x77
}
;
}
Really hate this, but until I figure out the secret, I'm going to have to adopt the use of one huge source file with all 17 commands typed out.
|
|
|
|
|
Ahhh. I think I see where you're having a problem. Each class there is in a separate namespace. In order to use a class from one namespace in another namespace, you need to make this visible in the class you are trying to use it in.
That's a quite confusing sentence, so a practical demo is in order here - there are two ways to see the class in a different namespace: the first way is to add a using statement before your class. So, in MainForm to see the SerialPortManager class, do this:
using SerialPortListener.Serial;
namespace SerialPortListener
{
public class MainForm : Form
{
private SerialPortManager portManager = new SerialPortManager();
....
}
} The other method to do this (in place of the using statement) is to fully qualify the classname by including the namespace in it like this:
namespace SerialPortListener
{
public class MainForm : Form
{
private SerialPortListener.Serial.SerialPortManager portManager = new SerialPortListener.Serial.SerialPortManager();
....
}
} If you are using Visual Studio and you have a class that is in a different unreferenced namespace, you should see a little blue square at the start of the class name (under the first letter). Either click this to bring up a menu or press Shift+Alt+F10; in both cases, it should let you choose whether to add the using statement or whether you want to fully qualify the class name.
|
|
|
|
|
Pete O'Hanlon wrote: Each class there is in a separate namespace.
Okay, so, the fact that all the files have the same line in them, near the top, i.e., this one...
namespace SerialPortPractice_03
namespace SerialPortPractice_03
...does not mean that they can see each other.
In other words, there is no "linker" (such as I am accustomed to having) which combines all the labels in different files into the same area in memory (even with the namespace line at the start) to allow one guy to call the other guy whenever he wants.
Am I close ?
|
|
|
|
|
C-P-User-3 wrote: Am I close ?
No. In the example you listed above, there were three separate namespaces. If your classes are in the same namespace, they can see each other.
|
|
|
|
|
Pete O'Hanlon wrote: No. In the example you listed above, there were three separate namespaces.
I'm going to double check that right now.
I was certain; like extremely certain; and made a deliberate effort; to make sure that every file had the same namespace.
Let me check that
Okay, the protocol file starts with these two lines...
using System;
namespace SerialPortPractice_03
The Form1.cs file starts off with these 9 (or 10 if you count the blank) lines...
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.IO.Ports;
namespace SerialPortPractice_03
Do I have the correct idea about the keyword namespace in my mind ?
|
|
|
|
|
Yes. They are in the same namespace.
|
|
|
|
|
Still trying to figure out what's going on.
I see the phrase, "SerialPortListener", by itself, and in another place with a dot and "Serial" after it, like this: SerialPortListener.Serial;.
I'm looking at this section, several times over...
Pete O'Hanlon wrote: using SerialPortListener.Serial;
namespace SerialPortListener
{
public class MainForm : Form
{
private SerialPortManager portManager = new SerialPortManager();
....
}
}
I see the "using" line with the name, and a dot, and the word "Serial" on one line, then in another line, I see the exact same word used with the namespace directive, then again with the private descriptor (sorry for my vocabulary) then in the same line, with the new keyword; but this time with empty parentheses appended.
It would help me greatly if I could get some sort of idea as to what bytes are being placed where, when these words are used.
By the way, thanks for all this time and direction. Hope I'm not annoying you or the gang here. One of these days I would like to help others like you guys have been helping me.
|
|
|
|
|
What's probably confusing you is that the namespaces and class names are all very close. Let's simplify this with an easy example. Suppose we have a very simple vehicle creating system. I'm going to arbitrarily break this up like this:
namespace WeMakeVehiclesForOthers
{
public class BaseVehicle
{
protected void Buy() {}
}
} Now, in a namespace that we are going to call Cars, we are going to add a specific manufacturer:
using WeMakeVehiclesForOthers;
namespace Cars
{
public class Ford : BaseVehicle
{
public void BuyCar()
{
Buy();
}
}
} Now finally, we have a set of car dealerships that want to sell custom Fords. They might look like this:
using Cars;
namespace Dealers
{
public class PetesDealers
{
private Ford ford = new Ford();
public void BuyFord()
{
ford.BuyCar();
}
}
} As you can see, you have full access to Ford and all the methods it has available. I hope this makes sense
|
|
|
|
|
Pete, Dave, anybody else, thank you.
King of the clueless, reigns supreme again.
Just learned something: in order for one method in one file to see another thing (anything) in another file, in C#, you can't just open a file and type in the same namespace.
No, you must put the cursor over the name of your project, then right click, then choose "Add", then choose "Class", then go through a drop-down menu and choose "Class" again, then give that class a name, then click something else (my brain isn't good enough to catalog the full procedure, but you get the idea) and then some more stuff, and when you follow that procedure, C# does ninety seven magic tricks and the names in one file are visible to the other files.
I am sorry, sorry, sorry for creating such needless useless questions and draining your time in such an absurdly obtuse manner.
Honest, I saw the other files, and thought I could just say "File", "New", "File", and start typing.
Be respectful; you are in the presence of the King Of The Clueless.
|
|
|
|
|
C-P-User-3 wrote: I have seen other apps run 921600 on this very machine right in front of my
eyes.
That baud rate has to be user defined. It's not going to be in the base Windows API or the .NET Framework. It's extremely rare to find any use for a RS232 port faster than 115200.
Frankly, with a baud rate like that, the cable would have to be sheilded in lead and a max of 3 feet long for it to work with any reliability.
|
|
|
|
|
Clarification: I'm using BlueTooth across a USB (i.e., Fake-out) UART.
This is the hardware which I've seen do 921600 Bits Per Second, with "Terminal by Br@y" and 230400 with "TERMite" and maybe Hyperterminal as well.
(Hyperterminal hates my guts; he's really got it in for me; don't know why.)
|
|
|
|
|
Total time waste. Sorry for the trail of the red herring.
I discovered the big liar in all this.
Well, not sure exactly who is lying, but I have at least dissected the lie from the truth.
The lie: the limit is 115200
The truth: If you open that port at a speed of 115200, he can, and will, and does, deliver a speed of 921600. It also works at even lower speeds.
To really grasp the magnitude of this, check out these results...
-- I opened the port at 1200 bps.
-- The other side was doing 921600.
-- It worked.
|
|
|
|
|
How can I dispatch 30 threads to do 30 things ?
How do those threads inform each other of what they are doing ?
I looked up the word "Semaphore" on the MSDN site, and here as well. Apparently, C# and embedded systems have markedly different definitions of that term.
Still newbee noclue.
I'm watching some YouTube videos on the topic, still learning, really interesting, I think that threading will do what I want it to do.
Input is welcome.
|
|
|
|
|
|
Thank you. This stuff is relevant to my interests !
|
|
|
|
|
I have found the paper very helpful. It has been updated a few time, especially with TPL. Sort of got back to it after reading up on TPL in Task Parallel Library: 1 of n[^]
|
|
|
|
|
hi ,
I got an object which is a generic, at runtime i pass the type for T and create the proper object. the generic object as follows
class parent <T>
{
string name;
T childObject;
}
I create the parent<x> in runtime using the reflection , for e.g.
Type type = x;
Dynamic response = Activator.CreateInstance(typeof(parent<>).MakeGenericType(type));
it works fine , but the problem is when I try to assign an object to response.childObject it gives me an exception saying that i'm missing cast and it cannot implicitly cast the object.
the object try to assign is also created using reflection,
ADDED LATER: I'm not sure this part will be important for this issue , but anyway , the object i'm trying to assign to response.childObject is also an object created by deserialization , means
for in order to deserialize this object i have to give the type , so that type also crated using reflection in a similar way described above.
i would really appreciate your help on this.
thanks in advance.
modified 31-Oct-12 12:43pm.
|
|
|
|
|
I dont know how it actual works if I am honest (as I found the question interesting) but my modifying your code to this
Type t = typeof(Parent<>);
int y = 1234;
Type type = y.GetType();
dynamic response = Activator.CreateInstance(t.MakeGenericType(type));
response.MyValue = 123;
public class Parent<T>
{
public string name = string.Empty;
public T MyValue;
}
I was able to assign a value to the property MyValue.
*Edit* Not sure if it helps but I've just read through this MSDN article on Type.MakeGenericType[^], I found this an interesting Question
Lobster Thermidor aux crevettes with a Mornay sauce, served in a Provençale manner with shallots and aubergines, garnished with truffle pate, brandy and a fried egg on top and Spam - Monty Python Spam Sketch
|
|
|
|
|
thanks , I also tried the value types and it works , but the problem came when i'm trying to assign reference type.
|
|
|
|
|
Type t = typeof(Parent<>);
Type type = typeof(Data);
dynamic response = Activator.CreateInstance(t.MakeGenericType(type));
Data es = new Data() { Name = "Fred", value = 213 };
response.value = es;
public class Parent<T>
{
public string name = string.Empty;
public T value;
}
public class Data
{
public string Name = string.Empty;
public int value = 0;
}
I have also tried it with the following and it still works can you expand your problem with some sample code? or a snippet?
Lobster Thermidor aux crevettes with a Mornay sauce, served in a Provençale manner with shallots and aubergines, garnished with truffle pate, brandy and a fried egg on top and Spam - Monty Python Spam Sketch
|
|
|
|
|
Thanks again , ok then I think I have to focus on the deserialzed object , unfortunately i haven't got the code snippet right now , but I will definitely post that code snippet soon.
thanks .
|
|
|
|
|
Your welcome
Lobster Thermidor aux crevettes with a Mornay sauce, served in a Provençale manner with shallots and aubergines, garnished with truffle pate, brandy and a fried egg on top and Spam - Monty Python Spam Sketch
|
|
|
|
|
hi ,
this is how i'm doing the deserialization
Type genericSyncObj = typeof(SyncObject<>);
Type syncObj = genericSyncObj.MakeGenericType(type);
IList customObjectList = (IList)Activator.CreateInstance((typeof(List<>).MakeGenericType(type)));
foreach (string value in pullRequest.Knowledge)
{
dynamic syncObject = JasonSerializer.Deserialize(value, syncObj, null);
customObjectList.Add(syncObject.Object);
}
and i'm getting the exception at here
dynamic responseSync = Activator.CreateInstance(typeof(SyncObject<>).MakeGenericType(type));
responseSync.Object = customObjectList[y] ;
thanks .
|
|
|
|
|
The problem is that customObject[y] is returned as an object which is why it fails.
if you then hard code a cast such as for example.
responseSync.Object = (SomeTestClass)customObject[y];
it works as you need it to do, but how to create this as a generic routine I'm not sure at the moment as (typeof(SomeTestClass))customObject[y] or even (typeof(SomeTestClass))CustomObject[y] is rejected by the compiler.
Lobster Thermidor aux crevettes with a Mornay sauce, served in a Provençale manner with shallots and aubergines, garnished with truffle pate, brandy and a fried egg on top and Spam - Monty Python Spam Sketch
|
|
|
|
|
thanks , yes this is the place where i'm stuck , need to cast in runtime , if you find a way please share it .
|
|
|
|
|